The present invention generally relates to hardware emulators, and more particularly to communication between programmable sub-cores in a hardware emulator.
Today's sophisticated SoC (System on Chip) designs are rapidly evolving and nearly doubling in size with each generation. Indeed, complex designs have nearly exceeded 50 million gates. This complexity, combined with the use of devices in industrial and mission-critical products, has made complete design verification an essential element in the semiconductor development cycle. Ultimately, this means that every chip designer, system integrator, and application software developer must focus on design verification.
Hardware emulation provides an effective way to increase verification productivity, speed up time-to-market, and deliver greater confidence in the final SoC product. Even though individual intellectual property blocks may be exhaustively verified, previously undetected problems appear when the blocks are integrated within the system. Comprehensive system-level verification, as provided by hardware emulation, tests overall system functionality, IP subsystem integrity, specification errors, block-to-block interfaces, boundary cases, and asynchronous clock domain crossings. Although design reuse, intellectual property, and high-performance tools all help by shortening SoC design time, they do not diminish the system verification bottleneck, which consumes 60-70% of the design cycle. As a result, designers can implement a number of system verification strategies in a complementary methodology including software simulation, simulation acceleration, hardware emulation, and rapid prototyping. But, for system-level verification, hardware emulation remains a favorable choice due to superior performance, visibility, flexibility, and accuracy.
A short history of hardware emulation is useful for understanding the emulation environment. Initially, software programs would read a circuit design file and simulate the electrical performance of the circuit very slowly. To speed up the process, special computers were designed to run simulators as fast as possible. IBM's Yorktown “simulator” was the earliest (1982) successful example of this—it used multiple processors running in parallel to run the simulation. Each processor was programmed to mimic a logical operation of the circuit for each cycle and may be reprogrammed in subsequent cycles to mimic a different logical operation. This hardware ‘simulator’ was faster than the current software simulators, but far slower than the end-product ICs. When Field Programmable Gate Arrays (FPGAs) became available in the mid-80's, circuit designers conceived of networking hundreds of FPGAs together in order to map their circuit design onto the FPGAs and the entire FPGA network would mimic, or emulate, the entire circuit. In the early 90's the term “emulation” was used to distinguish reprogrammable hardware that took the form of the design under test (DUT) versus a general purpose computer (or work station) running a software simulation program.
Soon, variations appeared. Custom FPGAs were designed for hardware emulation that included on-chip memory (for DUT memory as well as for debugging), special routing for outputting internal signals, and for efficient networking between logic elements. Another variation used custom IC chips with networked single bit processors (so-called processor based emulation) that processed in parallel and usually assumed a different logic function every cycle.
Physically, a hardware emulator resembles a large server. Racks of large printed circuit boards are connected by backplanes in ways that most facilitate a particular network configuration. A workstation connects to the hardware emulator for control, input, and output.
Before the emulator can emulate a DUT, the DUT design must be compiled. That is, the DUT's logic must be converted (synthesized) into code that can program the hardware emulator's logic elements (whether they be processors or FPGAs). Also, the DUT's interconnections must be synthesized into a suitable network that can be programmed into the hardware emulator. The compilation is highly emulator specific and can be time consuming.
Emulators contain a network of crossbar switches to facilitate communication between the different emulator components. A crossbar switch is an interconnect device that receives multiple inputs and maps the inputs to any of its desired outputs. For example, a 32×32 crossbar switch may be programmed to connect any of its 32 inputs to any of its 32 outputs. A crossbar switch may be used for inter-chip communication within the emulator, but also intra-chip to allow communication between components within a chip.
Although the tendency in the electronics industry is to provide smaller and smaller wires, in certain applications it is desirable to use larger wires. Larger wires offer less resistance and, consequently, are faster. Unfortunately, larger wires also increase cross-talk and require more spacing with respect to neighboring wires. The larger wires are particularly problematic with interconnections within a crossbar switch. More specifically, when using larger wires, the number of larger wires and the required spacing there between make the crossbar switch impractical.
Thus, a new communication scheme is needed in an emulation environment that lessens the dependency on crossbar switches.
A system and method are disclosed for communicating in a programmable core. The programmable core is within a single integrated circuit and is divided into multiple independent sub-cores. The sub-cores are coupled together using a multiplexer-based network.
In another aspect, the multiplexer-based network includes multiplexers associated with some of the sub-cores for sending data and demultiplexers associated with other sub-cores for receiving data.
In another aspect, the programmable core is an FPGA core.
In yet another aspect, a clock is included in the multiplexer-based network for synchronizing communication between the multiplexers and demultiplexers.
These features and others of the described embodiments will be more readily apparent from the following detailed description, which proceeds with reference to the accompanying drawings.
The emulator 12 includes multiple printed circuit boards 16 coupled to a midplane 18. The midplane 18 allows physical connection of the printed circuit boards into the emulator 12 on both sides of the midplane. A backplane may also be used in place of the midplane, the backplane allowing connection of printed circuit boards on one side of the backplane. Any desired type of printed circuit boards may be used. For example, programmable boards 20 generally include an array of FPGAs, or other programmable circuitry, that may be programmed with the user's design downloaded from the emulator host 14. One or more I/O boards 22 allow communication between the emulator 12 and hardware external to the emulator. For example, the user may have a preexisting processor board that is used in conjunction with the emulator and such a processor board connects to the emulator through I/O board 22. Clock board 24 generates any number of desired clock signals. And interconnect boards 26 allow integrated circuits on the programmable boards 20 to communicate together and with integrated circuits on the I/O boards 22.
Having illustrated and described the principles of the illustrated embodiments, it will be apparent to those skilled in the art that the embodiments can be modified in arrangement and detail without departing from such principles.
In view of the many possible embodiments, it will be recognized that the illustrated embodiments include only examples of the invention and should not be taken as a limitation on the scope of the invention. Rather, the invention is defined by the following claims. We therefore claim as the invention all such embodiments that come within the scope of these claims.
This is a 35 U.S.C. §371 U.S. National Stage of International Application No. PCT/EP2007/051652, filed Feb. 21, 2007, which was published in English under PCT Article 21(2), which in turn claims the benefit of U.S. Provisional Application No. 60/775,595, filed Feb. 21, 2006. Both applications are incorporated herein in their entirety.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2007/051652 | 2/21/2007 | WO | 00 | 5/20/2008 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2007/096376 | 8/30/2007 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
4697241 | Lavi | Sep 1987 | A |
4870302 | Freeman | Sep 1989 | A |
5036473 | Butts et al. | Jul 1991 | A |
5109353 | Sample et al. | Apr 1992 | A |
5259006 | Price et al. | Nov 1993 | A |
5551013 | Beausoleil et al. | Aug 1996 | A |
5596742 | Agarwal et al. | Jan 1997 | A |
5621650 | Agrawal | Apr 1997 | A |
5649176 | Selvidge et al. | Jul 1997 | A |
5659716 | Selvidge et al. | Aug 1997 | A |
5701111 | Trimberger | Dec 1997 | A |
5761484 | Agarwal et al. | Jun 1998 | A |
5802348 | Stewart et al. | Sep 1998 | A |
5847578 | Noakes et al. | Dec 1998 | A |
5850537 | Selvidge et al. | Dec 1998 | A |
5854752 | Agarwal | Dec 1998 | A |
5887158 | Sample et al. | Mar 1999 | A |
5943490 | Sample | Aug 1999 | A |
5960191 | Sample et al. | Sep 1999 | A |
6009531 | Selvidge et al. | Dec 1999 | A |
6051030 | Beausoleil et al. | Apr 2000 | A |
6167559 | Furtek et al. | Dec 2000 | A |
6961691 | Selvidge et al. | Nov 2005 | B1 |
7379859 | Goode | May 2008 | B2 |
20020161568 | Sample et al. | Oct 2002 | A1 |
20030025132 | Tobey | Feb 2003 | A1 |
20060168396 | LaMothe et al. | Jul 2006 | A1 |
Number | Date | Country |
---|---|---|
WO 0124066 | Apr 2001 | WO |
WO 02086723 | Oct 2002 | WO |
Number | Date | Country | |
---|---|---|---|
20080288236 A1 | Nov 2008 | US |
Number | Date | Country | |
---|---|---|---|
60775595 | Feb 2006 | US |