Claims
- 1. A hardware acceleration system for functional simulation comprising:
a generic circuit board including logic chips, and memory, wherein the circuit board is capable of plugging onto a computing device and the system being adapted to allow the computing device to direct DMA transfers between the circuit board and a memory associated with the computing device, wherein the circuit board is capable of being configured with a simulation processor, said simulation processor capable of being programmed for at least one circuit design.
- 2. The system of claim 1, wherein an FPGA is mapped with the simulation processor.
- 3. The system of claim 1, wherein a netlist for a circuit to be simulated is compiled for the simulation processor.
- 4. The system of claim 1, wherein the simulation processor further includes:
at least one processing element; and at least one register file with one or more registers corresponding to said at least one processing element.
- 5. The system of claim 4, wherein the simulation processor further includes a distributed memory system with at least one memory bank.
- 6. The system of claim 5, wherein said at least one memory bank serves a set of processing elements and their associated registers.
- 7. The system of claim 5, wherein a register is capable of being spilled onto the memory bank.
- 8. The system of claim 4, further including an interconnect system that connects said at least one processing element with other processing elements.
- 10. The system of claim 4 wherein the processing element is capable of simulating any 2-input gate.
- 11. The system of claim 4, wherein the processing element is capable of performing RT-level simulation.
- 12. The system of claim 8, wherein the connection is made through the registers.
- 13. The system of claim 12, wherein the interconnect network is pipelined.
- 14. The system of claim 8, wherein the register file is located in proximity to its associated processing element.
- 15. The system of claim 5, wherein the distributed memory system has exclusive ports corresponding to each register file.
- 16. The system of claim 3, wherein the system is capable of processing a partition of the netlist at a time when the netlist is does not fit the memory on the board.
- 17. The system of claim 16, wherein the system is capable of simulating the entire netlist by sequentially simulating its partitions.
- 18. The system of claim 3, wherein the system is capable of processing a subset of simulation vectors that are used to test the circuit.
- 19. The system of claim 18, wherein the system is capable of simulating the entire set of simulation vectors by sequentially simulating each subset.
- 20. The system of claim 1, wherein the acceleration system is capable of being interchangeably used with a generic software simulator with the ability to exchange the state of all registers in the design
- 21. The system of claim 1, wherein both 2-valued and 4-valued simulation can be performed on the simulation processor.
- 22. The system of claim 1, further including an interface and opcodes, wherein said opcodes specify reading, writing and other operations related to simulation vectors.
- 23. The system of claim 1 wherein the simulation processor further includes:
at least one arithmetic logic unit; zero or more signed multipliers; a distributed register system with least one register each associated with said ALU and said multiplier.
- 24. The system of claim 23, wherein said system includes a carry register file for each ALU, wherein a width of the register is same as a width of the corresponding register.
- 25. The system of claim 24, further including a pipelined carry-chain interconnect connecting the registers.
- 26. A method for performing logic simulation for a circuit comprising:
a) compiling a netlist corresponding to the circuit to generate a set of instructions for a simulation processor; b) loading the instructions onto the on-board memory corresponding to the simulation processor; c) transferring a set of simulation vectors onto the on-board memory; d) streaming a set of instructions corresponding to the netlist to be simulated onto an FPGA on which the simulation processor is configured; e) executing the set of instructions to produce a set of result vectors; and f) transferring the result vectors onto a host computer.
- 27. The method of claim 26, wherein if an instruction is wider than a bus connecting the on-board memory to the FPGA, the instruction is time-multiplexed.
- 28. A method of compiling a netlist of a circuit for a simulation processor, said method comprising:
a) representing a design for the circuit as a directed graph, wherein nodes of the graph correspond to hardware blocks in the design; b) generating a ready-front subset of nodes that are ready to be scheduled; c) performing a topological sort on the ready-front set; d) selecting a hitherto unselected node; e) completing an instruction and proceeding to a new instruction if no processing element is available; f) selecting a processing element with most free registers associated with it to perform an operation corresponding to the selected node; g) routing operands from registers to the selected processing element; and i) repeating steps d-h until no more nodes are left unselected.
- 29. The method of claim 28 wherein a node is selected based on a selection heuristic including a largest number of registers freed by scheduling the node and a largest number of fanout of the node.
- 30. The method of claim 28, wherein when a register file is full a register is selected to be spilled and stored onto memory to be loaded when a demand arises.
- 31. The method of claim 30, wherein if in step f no registers are available, then registers are spilled to the memory banks
- 32. The method of claim 30 wherein a register is selected to be spilled is a register that is an output of a node scheduled earlier based on a selection heuristic including a largest number of registers freed by scheduling the node and a largest number of fanout of the node.
RELATED APPLICATIONS
[0001] This Application claims priority from co-pending U.S. Provisional Application Serial No. 60/335,805, filed Dec. 5, 2001, which is incorporated in its entirety by reference.
Provisional Applications (1)
|
Number |
Date |
Country |
|
60335805 |
Dec 2001 |
US |