Compiler-oriented apparatus for parallel compilation, simulation and execution of computer programs and hardware models
First Claim
1. A parallel processor system with at least one node programmed to execute a distributed, compiler-oriented database, the parallel processor system including compilation, simulation and/or software execution operating modes, and comprising:
- at least two processors;
memory operationally connected to at least one processor wherein the memory is either local memory or shared memory;
interconnection mechanisms for connecting the at least two processors and the memory; and
re-configurable logic elements, wherein the programmed node is augmented to include a plurality of clients which may perform one or more of the following functions on the distributed, compiler-oriented database selected from a group of;
incremental analysis of source code into the database;
incremental elaboration and/or in-lining of previously analyzed information into the database to yield new or revised database entries;
incremental optimization which transform database contents to yield more efficient simulation, more efficient execution or more observable execution;
incremental code generation, assembly and linking which transform database contents to yield representations directly executable on a combination of programmable processors and reconfigurable logic elements;
runtime, I/O and file systems operations which provide for scheduling, communication and callbacks within and among directly executable simulations/executions;
debugging which provide for interactively starting, stopping and probing the state of simulation/execution;
profiling or event logging of simulation/execution in order to make simulation/execution result accessible to external tools or users; and
graphical interactive user interface transfers wherein the database may coherently cache information having utility on said at least one node.
1 Assignment
0 Petitions
Accused Products
Abstract
A distributed, compiler-oriented database is disclosed with operating modes including parallel compilation, parallel simulation and parallel execution of computer programs and hardware models. The invention utilizes a hardware apparatus consisting of shared memory multiprocessors, optionally augmented by processors with re-configurable logic execution pipelines or independently scheduled re-configurable logic blocks and a software database apparatus, manifest in the hardware apparatus, in order to efficiently support parallel database clients such as a source code analyzer, an elaborator, an optimizer, mapping and scheduling, code generation, linking/loading, execution/simulation, debugging, profiling, user interface and a file interface.
-
Citations
44 Claims
-
1. A parallel processor system with at least one node programmed to execute a distributed, compiler-oriented database, the parallel processor system including compilation, simulation and/or software execution operating modes, and comprising:
-
at least two processors; memory operationally connected to at least one processor wherein the memory is either local memory or shared memory; interconnection mechanisms for connecting the at least two processors and the memory; and re-configurable logic elements, wherein the programmed node is augmented to include a plurality of clients which may perform one or more of the following functions on the distributed, compiler-oriented database selected from a group of; incremental analysis of source code into the database; incremental elaboration and/or in-lining of previously analyzed information into the database to yield new or revised database entries; incremental optimization which transform database contents to yield more efficient simulation, more efficient execution or more observable execution; incremental code generation, assembly and linking which transform database contents to yield representations directly executable on a combination of programmable processors and reconfigurable logic elements; runtime, I/O and file systems operations which provide for scheduling, communication and callbacks within and among directly executable simulations/executions; debugging which provide for interactively starting, stopping and probing the state of simulation/execution; profiling or event logging of simulation/execution in order to make simulation/execution result accessible to external tools or users; and graphical interactive user interface transfers wherein the database may coherently cache information having utility on said at least one node. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 36, 37, 38, 39, 40, 41, 42, 43)
-
-
15. A parallel processor system with at least one node programmed to execute a distributed, complier-oriented database, the parallel processor system including compilation, simulation and/or software execution operating modes, and comprising:
-
at least two processor; memory operationally connected to at least one processor wherein the memory is either local memory or shared memory; and interconnection mechanisms for connecting the at least two processors and the memory; wherein the programmed node is augmented to include a plurality of clients which may perform one or more of the following functions on the distributed, compiler-oriented database selected from a group of; incremental analysis of source code into the database; incremental elaboration and/or in-lining of previously analyzed information into the data base to yield new or revised database entries; incremental optimization which transform database contents to yield more efficient simulation, more efficient execution or more observable execution; incremental code generation, assembly and linking which transform database contents to yield representations directly executable on a combination of programmable processors and reconfigurable logic elements; runtime I/O and file systems operations which provide for scheduling communication and callbacks within and among directly executable simulations/executions; debugging which provide for interactively starting, stopping and probing the state of simulation/execution; profiling or event logging of simulation/execution in order to make simulation/execution results accessible to external tools or users; and graphical interactive user interface transfers wherein the database may coherently cache information having utility on said at least one node. - View Dependent Claims (16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 44)
-
Specification