The present invention is related to the following commonly-owned, co-pending U.S. patent applications filed on even date herewith, the entire contents and disclosure of each of which is expressly incorporated by reference herein as if fully set forth herein. U.S. patent application Ser. No. 11/768,777, for “A SHARED PERFORMANCE MONITOR IN A MULTIPROCESSOR SYSTEM”; U.S. patent application Ser. No. 11/768,645, for “OPTIMIZED COLLECTIVES USING A DMA ON A PARALLEL COMPUTER”; U.S. patent application Ser. No. 11/768,781, for “DMA SHARED BYTE COUNTERS IN A PARALLEL COMPUTER”; U.S. patent application Ser. No. 11/768,784, for “MULTIPLE NODE REMOTE MESSAGING”; U.S. patent application Ser. No. 11/768,697, for “A METHOD AND APPARATUS OF PREFETCHING STREAMS OF VARYING PREFETCH DEPTH”; U.S. patent application Ser. No. 11/768,532, for “PROGRAMMABLE PARTITIONING FOR HIGH-PERFORMANCE COHERENCE DOMAINS IN A MULTIPROCESSOR SYSTEM”; U.S. patent application Ser. No. 11/768,857, for “METHOD AND APPARATUS FOR SINGLE-STEPPING COHERENCE EVENTS IN A MULTIPROCESSOR SYSTEM UNDER SOFTWARE CONTROL”; U.S. patent application Ser. No. 11/768,547, for “INSERTION OF COHERENCE REQUESTS FOR DEBUGGING A MULTIPROCESSOR”; U.S. patent application Ser. No. 11/768,795; for “DMA ENGINE FOR REPEATING COMMUNICATION PATTERNS”; U.S. patent application Ser. No. 11/768,799, for “METHOD AND APPARATUS FOR GRANTING PROCESSORS ACCESS TOA RESOURCE”; U.S. patent application Ser. No. 11/768,800, for “METHOD AND APPARATUS FOR EFFICIENTLY TRACKING QUEUE ENTRIES RELATIVE TO A TIMESTAMP”; U.S. patent application Ser. No. 11/768,572, for “BAD DATA PACKET CAPTURE DEVICE”; U.S. patent application Ser. No. 11/768,593, for “EXTENDED WRITE COMBINING USING A WRITE CONTINUATION HINT FLAG”; U.S. patent application Ser. No. 11/768,805, for “A system and method for PROGRAMMABLE BANK SELECTION FOR BANKED MEMORY SUBSYSTEMS”; U.S. patent application Ser. No. 11/768,905, for “AN ULTRASCALABLE PETAFLOP PARALLEL SUPERCOMPUTER”; U.S. patent application Ser. No. 11/768,810, for “DATA EYE MONITOR METHOD AND APPARATUS”; U.S. patent application Ser. No. 11/768,812, for “A CONFIGURABLE MEMORY SYSTEM AND METHOD FOR PROVIDING ATOMIC COUNTING OPERATIONS IN A MEMORY DEVICE”; U.S. patent application Ser. No. 11/768,559, for “ERROR CORRECTING CODE WITH CHIP KILL CAPABILITY AND POWER SAVING ENHANCEMENT”; U.S. patent application Ser. No. 11/768,552, for “STATIC POWER REDUCTION FOR MIDPOINT-TERMINATED BUSSES”; U.S. patent application Ser. No. 11/768,527, for “COMBINED GROUP ECC PROTECTION AND SUBGROUP PARITY PROTECTION”; U.S. patent application Ser. No. 11/768,669, for “A MECHANISM TO SUPPORT GENERIC COLLECTIVE COMMUNICATION ACROSS A VARIETY OF PROGRAMMING MODELS”; U.S. patent application Ser. No. 11/768,813, for “MESSAGE PASSING WITH A LIMITED NUMBER OF DMA BYTE COUNTERS”; U.S. patent application Ser. No. 11/768,619, for “ASYNCRONOUS BROADCAST FOR ORDERED DELIVERY BETWEEN COMPUTE NODES IN A PARALLEL COMPUTING SYSTEM WHERE PACKET HEADER SPACE IS LIMITED”; U.S. patent application Ser. No. 11/768,682, for “HARDWARE PACKET PACING USING A DMA IN A PARALLEL COMPUTER”; and U.S. patent application Ser. No. 11/768,752, for “POWER THROTTLING OF COLLECTIONS OF COMPUTING ELEMENTS”.
1. Field of the Invention
The present invention generally relates to computer systems generally, and, more particularly, to a novel implementation of a system and method for performing debugging operations of digital chips implemented in computer systems that is subject to software or hardware failures.
2. Description of the Prior Art
While bringing up an electronic system, the root cause for any given bug needs to be determined. In some cases, it is very hard to determine whether the hardware or the software is at fault. If the suspicion is on the hardware (or on very subtle interactions between the software and the hardware), conventional methods of debugging use probes external to the chips (such as oscilloscopes or logic analyzers). These probes give only a limited view of the state internal to the chips. To get a better view of the logical state and its evolution in time, several prior microprocessor designs have invested chip area in trace arrays. This additional chip area for trace arrays is useful in chip bring-up and debug, but adds cost to every production chip, where the trace array goes unused. While a definite improvement over external probing by logic analyzers, trace arrays still only give a limited view of the internal state of the microprocessor. This limitation stems both from the limited set of pre-selected on-chip signals that can be routed to the trace array (as determined and fixed at design time), and from the limited depth of any hardware-implemented array, so that the selected signals can be followed only for a limited length of time.
It would be highly desirable to provide a system and method for facilitating the debugging of various IC chips, by allowing the user to construct a cycle-by-cycle view of a very large part of the state of a digital chip, without design-imposed limitations on signal selection, and at a minimal overhead in chip area and cost.
Further desirable would be to provide a system and method for facilitating the debugging of various IC chips, by allowing the user to construct a cycle-by-cycle view of a very large part of the state of a digital chip that are under control of software.
It is therefore an object of the present invention to provide a novel system and method for facilitating the debugging of various IC chips, by allowing the user to construct a cycle-by-cycle view of a very large part of the state of a digital chip that are under control of software.
That is, the present invention teaches a technique for constructing a cycle-by-cycle view of any part of the state of a digital chip, using a combination of on-chip circuitry and software. The chip state can be followed for a length of time that is limited only by the amount of storage space of external computers. The subset of the digital chip state to be viewed is not subject to pre-determined restrictions (such as special on-chip wiring), other than that the state is contained in scannable latches, such as commonly already required for manufacturing test of the chip.
In one advantageous embodiment of this invention, flexibility is provided for enabling choice of the chip state of interest at bring-up time (as opposed to at design time). The lack of restrictions (other than data volume) for the length of time over which the chip state can be followed is another principal advantage of this invention.
The additional on-chip circuitry required to implement this invention constitutes only minimal additional chip area, as it is largely shared with existing Logic Built In Test (LBIST) circuitry for chip manufacturing test.
Accordingly, in one embodiment of the invention, there is provided an apparatus and method for evaluating a state of an electronic chip in a computing system having a plurality of integrated circuits (ICs), each IC including one or more processor elements for controlling operations of IC sub-units, and each the IC supporting multiple frequency clock domains. The method comprises:
generating a synchronized set of enable signals in correspondence with one or more IC sub-units for starting operation of one or more IC sub-units according to a determined timing configuration;
counting, in response to one signal of the synchronized set of enable signals, a number of main processor IC clock cycles; and,
upon attaining a desired clock cycle number, generating a stop signal for each unique frequency clock domain to synchronously stop a functional clock for each respective frequency clock domain; and,
upon synchronously stopping all on-chip functional clocks on all frequency clock domains in a deterministic fashion, scanning out data values at a desired IC chip state.
According to a further embodiment of the invention, there is provided an apparatus for evaluating a state of an electronic chip in a computing system having a plurality of integrated circuits (ICs), each IC including one or more processor elements for controlling operations of IC sub-units, each said IC supporting multiple frequency clock domains, the apparatus comprising:
a first circuit means for generating a synchronized set of enable signals in correspondence with one or more IC sub-units for starting operation of one or more IC sub-units according to a determined timing configuration;
a second circuit means responsive to one signal of the synchronized set of enable signals to start counting a number of main processor IC clock cycles and, upon attaining a desired clock cycle number, generating a stop signal for each unique frequency clock domain to synchronously stop a functional clock for each respective frequency clock domain,
wherein all on-chip functional clocks are synchronously stopped on all frequency clock domains in a deterministic fashion to place the IC in a state for scanning out IC chip state data values from the IC.
Advantageously, while the invention is described in the context of a microprocessor chip, the invention can be broadly applied to many other digital chips.
The objects, features and advantages of the present invention will become apparent to one skilled in the art, in view of the following detailed description taken in combination with the attached drawings, in which:
Referring now to drawings, and more particularly to
A control system software running on an external computer and the operating system running on the microprocessor chip to be tested include facilities to: silence all processes that would lead to non-deterministic execution (such as interrupts, daemons, messages), initialize all necessary arrays, etc.; program the requested cycle for the clock stop in a register; start the program execution; wait until the microprocessor stops at the requested cycle; control the microprocessor scan-out mechanism so that the latch states of interest are scanned out; and, relate the scanned-out data to the design data of the microprocessor so that the collected scan-out data is mapped to the contents of each specific latch. These process steps may be repeated for any desired number of iterations, with each iteration stopping at a next successive clock cycle, until (or past) the point where the bug manifests itself.
The successive lists of latch states so obtained are rearranged into a time-ordered succession of states for every individual latch, and processed in a form suitable for display on a conventional waveform viewer, such as a viewer a designer may have used for logic verification of the original chip design. This gives a familiar view to the logic designers, who can then graphically follow the progression of the program and chip state as a function of time until (or past) the point in time that the bug manifests itself.
According to the invention, in one embodiment, the chip design provides circuitry that ensures that execution of a given program can be performed in an exactly reproducible fashion on a cycle-by-cycle basis. Hardware facilities to implement this include, for example, a set of synchronized reset/enable signals applied so that all chip sub-units start operation synchronized with the main chip clock. Furthermore, non-deterministic state left in the chip from previous program executions (for example, in un-initialized memory arrays) should not affect the execution of the present program. A facility is provided either in hardware or in software to initialize such arrays in preparation for cycle-reproducible runs.
In further view of
In this fashion, new chip configurations will only be admitted to the chip at a strictly deterministic point in time with respect to all functional clock edges. The Unit_Enable signals 111 output from the synchronization register 105 are forwarded to the respective on-chip units via as many pipeline stages as required, without affecting this synchronicity and repeatability. It is further understood that the Unit_Enable signals 111 additionally comprise the Reset/Enable signals for all on-chip processor cores.
As part of the initialization sequence, the control system may copy the chip configuration state (signals 102) into a register device, e.g., Config0 register, 106, and will next drive the allow_processor_control signal (101) to a ‘1’. Multiplexer 107 will normally transmit the contents of Config0 register to multiplexer 103, and when the allow_processor_control signal (101) is driven to a ‘1’, multiplexer 103 will transmit the chip configuration state signals to the synchronization complex of multiplexer 104 and synchronization register 105.
Thus, from this point onward, software running on the on-chip processors can configure the on-chip units, as required, by modifying the contents of Config0 register 106. For example, unused units can be put in quiescent state. As before, each change in configuration state will become visible as a changed set of Unit_Enable signals 111 at a strictly deterministic point in time with respect to all functional clock edges.
Such state changes via Config0 register 106 are under control of the software running on an on-chip processor. In case of multiple on-chip processors, at least one on-chip processor will need to be and stay operational to do so. It is understood that this one processor cannot reset itself via Config0 register 106, as it would not be able to enable itself again.
To allow a full chip reset under on-chip program control, a further set of circuits is provided such that a processor can reset and re-enable itself. In the preferred embodiment, this device is implemented by a configuration register element Config1 register 108 as shown in
On subsequent clock_x8 cycles, the down-counter will decrement, until it reaches zero and stop. Upon reaching zero, comparator 110 will switch multiplexer 107 back to transmitting Config0 register 106, which, in the example, will lead to the processor(s) being re-enabled. As before, the re-enable of the processors will happen at a strictly deterministic and strictly repeatable point in time with respect to all functional clock edges.
The implementation of a clock stop on a software-programmable cycle number can in principle be achieved by a simple counter mechanism. However, additional clock control circuitry is added to ensure that all on-chip functional clocks are stopped in deterministic fashion, as now described with respect to
In particular,
Thus, according to the logic employed by the clock_stop synchronizer module 204, a same fixed and deterministic offset will occur at the issuance of each clock_stop_cmd signal. This gating (stopping) logic is designed to ensure that clock stopping across many synchronous domains of different frequencies will occur in a deterministic fashion and without glitches. This includes ensuring that slower frequencies will see their full pulse-width clock as their final signal.
Thus, in one example chip design, where functional clocks have frequency divisions of 1.5, 2, 3, 4, 6, 8 with respect to the fastest processor clock, the offset is the least common multiple (LCM) of these clock divisions (e.g., LCM=24). With this LCM offset, the functional clock domains will stop with all clock edges in the same phase relationship as in the cycle in which the clk_stop_cmd was raised. The exact offset is tuned per clock domain to compensate for additional pipelining in the distribution of the clock gating signals. In the end, the clock gating signals 215 that shut down the functional clocks will arrive at all clock splitter elements 206 of all functional clock domains synchronously (only one of which is shown in
Returning to
Having described a teaching of the invention that ensures that execution of a given program is exactly reproducible on a cycle-by-cycle basis; and ensures that all clocks on the chip are able to stop on the chip synchronously on a specific clock cycle count number since starting the execution of a program, there is now provided additional teachings of the invention for ensuring that the chip may be brought into a scan state with stopped clocks, while preserving the contents of the latches; and, ensuring that the latch states can be scanned out of the chip.
For example, upon completion of a synchronous clock stop on all clock domains, the chip exists in a state that is ready to scan out all master/slave latch data. In the example chip design, scanning the chip is performed under JTAG control, with the on-chip scan chains configured as Test Data Registers according to the IEEE 1149.1-1990/IEEE 1149.1a-1993 standard (also commonly known as JTAG standard) incorporated by reference as if fully set forth herein. The distribution of the scan clocks (derived off the rising and falling edges of the JTAG TCK clock—not shown) utilizes existing scan clock paths implemented for manufacturing test, thus again driving no additional area. In the example chip design, scannable latches are partitioned across several separate scan chains, one per synchronous clock domain. This provides fine granularity and short scan times. However, the scan-out could alternatively be done at coarser granularity, at the designer's discretion, up to a single large chain spanning the whole chip.
Great care needs to be taken in software initialization that the device under test (DUT) can execute programs repeatably in a cycle-accurate fashion. One example chip design in which the present invention may be implemented includes multiple microprocessor cores and a memory subsystem, which includes a double data rate (DDR) DRAM controller. For this example chip design, the following steps are executed to initialize the chip in a mode that ensures cycle reproducibility:
In a first step, the DUT performs its standard initialization. For this step, the DUT may interact with the control system block (
For instance, in a next step, performed by one or more processors (e.g., up to four of more processor cores in a multiprocessor system), the DUT detects that it is requested to have a cycle reproducible run. In response, the DUT soft-initializes processor state for all processor cores on-chip that are not affected by a device reset signal (e.g., instruction and data cache are invalidated, branch history table is cleared).
Then, in a next step, all of the on-chip processors enter a local barrier. That is, when each individual processor is done performing the tasks described herein, they signal to the that they are done, and then enter a wait state until all processors are done. In other words, the local barrier is a stopping point, where the processors that finished more quickly than others wait for the others to catch up.
Then, one processor core is selected as the initialization core, while the other processor cores enter a spin loop, waiting to be reset. That is, three of the processor cores are idled, and one “chosen” processor core continues through the following steps a1-e1, terminating itself at step e1 in the manner as described. This selected processor core then performs the following steps: a1) the DUT records the DDR calibration settings. The settings need to saved to a non-DDR, non-volatile memory (e.g., SRAM); b1) the DUT soft-initializes any hardware latches that are not affected by a device reset signal (e.g. on the example chip: clear lockbox state, Invalidate L2 cache and flush L3 cache to DDR); c1) DUT places the DDR controller in self-refresh; d1) the DUT increments a value (on the example chip: in non-volatile SRAM memory) that indicates that it has been reset; and, e1) the DUT pulls device reset. This accomplished through the full chip reset mechanisms under on-chip program control provided by devices 107, 108, 109, 110 as described herein with respect to
After the processors are synchronously re-enabled, the DUT should be prevented from accessing any asynchronous external devices. Continuing, as performed by one or all processors, as required, the DUT detects that this is the second run-through of the initialization sequence (via the value that was incremented prior to the reset that was performed at sub-step d1 above)). Then, the DUT performs a modified initialization sequence including, but not limited to steps of: a2) setting up a reproducible mode for correcting errors in memory. I.e., as the automatic memory error correction paths (e.g., DDR memory errors) take longer to process memory accesses than occurrences without memory errors, for reproducibility, the memory controllers need to be placed in a mode where all memory accesses are forced down the correction path. Alternatively, for reproducibility, the memory controllers need to be placed in a mode that forces a fatal error when any correctable memory errors occur; b2) restoring the DDR calibration settings stored from step a1) above; c2) disabling DDR auto-calibration; d2) configuring the DDR refresh to be deterministic; e2) removing DDR memory out of self-refresh mode; and, f2) At this point, the node may now access DDR memory.
Continuing further with the software programming there is next implemented a step of: enabling the DUT clock_stop unit, writing to the clock_stop unit registers (202) with the cycle number to stop at, and enabling the clock_stop synchronizer 204 by setting guard bit 405. Then, under control of the program that sensitizes the suspected bug (taking anywhere from one to four processor cores), the DUT launches the loaded kernels and program automatically. The DUT will continue execution until the pre-programmed cycle count is reached and the clock_stop_cmd fires. The clockstop synchronizing logic halts the clocks to the DUT, as described herein above, freezing the DUT from a software perspective. After the DUT has reached its stop clock point, the control system module 50 (
The above software implemented steps are run repeatedly for any desired number of iterations, with each iteration stopping at a next successive clock cycle, until (or past) the point where the bug manifests itself.
When the entire run is done, a text description is read in that relates the information collected in the scan files to the design latch names in the logical description of the chip design. Using a library that allows the writing of wave information to be viewed by a conventional waveform viewer, all the latch names and the wave form information are written out into a wave trace file. The waveform viewer thus displays to the logic designer the evolution of the chip state, leading up to the bug, in a familiar format, very much like the waveforms viewed during the logic verification stage of the chip design.
In operation of the foregoing, it is understood that gathering even a single cycle's worth of latch data takes time (boot time plus time-to-failure). So determining the “cycle-of-interest” is a critical step. Thus numerous scenarios can be formulated to find the cycle of interest as quickly as possible: In a first search variation, a gross linear search starting at cycle ‘0’ may be performed first until inactivity is detected on the node (e.g., cycle X=cycle X+n. where n is some large number of cycles). Afterward, a binary search may be performed between cycle ‘0’ and cycle ‘X’. If cycle X/2 compares to cycle X then a ‘left’ branch of the binary search tree may be taken; otherwise, the ‘right’ branch is followed. Implementing this search scheme will enable quick convergence on the precise cycle where inactivity starts. It takes at most log 2(X) scans to determine the cycle. It is understood that a comparison of the latches may be the full chip, or a subset of latches.
In a second variation, a paired binary search may be performed. It may become necessary to generate a waveform of a particular failing chip, for example, to compare a working chip to a failing chip, running the same code on each. Thus, node A should always compare to node B. Thus, there is performed a gross linear search starting at cycle ‘0’ until node A's scan does not compare to node B's scan (e.g., while cycle X.a=cycle X.b, then X=X+n. where n is some large number of cycles). Afterward, a binary search between cycle ‘0’ and cycle ‘X’ is performed. If the scans on both nodes compare at cycle X/2, then a ‘right’ branch of the binary search tree is taken; otherwise, the ‘left’ branch of the binary search tree is taken.
In a third variation, instability is sought. That is, it may become necessary to generate a waveform of a particular sequence of codes that are intermittent/timing sensitive. In this variation, thus, a gross linear search is performed starting at cycle ‘0’ scanning ‘Y’ times per cycle until at least 1 of those ‘Y’ scans results in a miscompare (e.g., while cycle X.1=cycle X.2. X=X+n. where n is some large number of cycles). Then a binary search is performed between between cycle ‘0’ and cycle ‘X’. Then, a ‘Y’ number of scans are taken and compared at cycle X/2. If those scans all compare, then take the ‘right’ branch of the binary search tree is followed; otherwise, the ‘left’ branch is taken.
The present invention may be advantageously employed in a novel Massively Parallel High Performance computing system such as described in commonly-owned, co-pending U.S. patent application Ser. No. 11/768,905, having a plurality of computing “nodes”, each computing node comprising an ASIC that integrates all the functions of a computer into a single compute chip, enabling dramatic reduction of node size and power consumption. In a supercomputer, this can be further leveraged to increase node density thereby decreasing the overall cost/performance for the machine. The ASIC of this particular implementation, which may function as both a compute node and an I/O node in the computing system, include four processing cores, each having a “double” floating point unit, that includes two coupled standard floating point units. In one embodiment, the processor core is a PowerPC450 embedded core available from IBM microelectronics, although future versions of this core may be used as technology improves. The node further incorporates other elements and functions into the ASIC including, but not limited to: an embedded DRAM, an integrated external DDR2 memory controller, DMA, 10 Gb Ethernet functionality as well as all the network link cut-through routing buffers and routing control block that allow any two nodes to communicate with low latency. The compute node, in one embodiment, includes four embedded cores, such as the PPC450, each capable of being utilized for message handling and computation operations. Also included in a node is a “scratch” SRAM, provided to serve as a background communication mechanism with a host system. All four cores have equal access to the SRAM which is critical for the independent exchange of messages between each core and the host system. There is additionally provided at the node two DDR-2 controllers which enable use of the low cost commodity DDR-2 external memory.
Furthermore, as part of the Massively Parallel High Performance computing system, a Control Network, which may comprise a combination of a 1 Gb Ethernet and a IEEE 1149.1 Joint Test Access Group (JTAG) network, is implemented to provide complete low-level debug, diagnostic and configuration capabilities for all nodes in the entire machine, and which is under control of a remote independent host machine, called the “Service Node”. Preferably, use of the Control Network operates with or without the cooperation of any software executing on the nodes of the parallel machine. Nodes may be debugged or inspected transparently to any software they may be executing. The Control Network provides the ability to address all nodes simultaneously or any subset of nodes in the machine. This level of diagnostics and debug is an enabling technology for massive levels of scalability for both the hardware and software.
The present invention has been described with reference to flow diagrams and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each flow and/or block of the flow diagrams and/or block diagrams, and combinations of flows and/or blocks in the flow diagrams and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, embedded processor or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions specified in the flow diagram flow or flows and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function specified in the flow diagram flow or flows and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer-readable or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions specified in the flow diagram flow or flows and/or block diagram block or blocks.
While there has been shown and described what is considered to be preferred embodiments of the invention, it will, of course, be understood that various modifications and changes in form or detail could readily be made without departing from the spirit of the invention. It is therefore intended that the invention be not limited to the exact forms described and illustrated, but should be constructed to cover all modifications that may fall within the scope of the appended claims.
The U.S. Government has a paid-up license in this invention and the right in limited circumstances to require the patent owner to license others on reasonable terms as provided for by the terms of Contract. No. B554331 awarded by the Department of Energy.
Number | Name | Date | Kind |
---|---|---|---|
4777595 | Strecker et al. | Oct 1988 | A |
5063562 | Barzilai et al. | Nov 1991 | A |
5142422 | Zook et al. | Aug 1992 | A |
5349587 | Nadeau-Dostie et al. | Sep 1994 | A |
5353412 | Douglas et al. | Oct 1994 | A |
5452432 | Macachor | Sep 1995 | A |
5524220 | Verma et al. | Jun 1996 | A |
5634007 | Calta et al. | May 1997 | A |
5659710 | Sherman et al. | Aug 1997 | A |
5708779 | Graziano et al. | Jan 1998 | A |
5761464 | Hopkins | Jun 1998 | A |
5796735 | Miller et al. | Aug 1998 | A |
5809278 | Watanabe et al. | Sep 1998 | A |
5825748 | Barkey et al. | Oct 1998 | A |
5890211 | Sokolov et al. | Mar 1999 | A |
5917828 | Thompson | Jun 1999 | A |
6023732 | Moh et al. | Feb 2000 | A |
6061511 | Marantz et al. | May 2000 | A |
6072781 | Feeney et al. | Jun 2000 | A |
6122715 | Palanca et al. | Sep 2000 | A |
6185214 | Schwartz et al. | Feb 2001 | B1 |
6219300 | Tamaki | Apr 2001 | B1 |
6263397 | Wu et al. | Jul 2001 | B1 |
6295571 | Scardamalia et al. | Sep 2001 | B1 |
6311249 | Min et al. | Oct 2001 | B1 |
6324495 | Steinman | Nov 2001 | B1 |
6333653 | Floyd et al. | Dec 2001 | B1 |
6356106 | Greeff et al. | Mar 2002 | B1 |
6366984 | Carmean et al. | Apr 2002 | B1 |
6442162 | O'Neill et al. | Aug 2002 | B1 |
6466227 | Pfister et al. | Oct 2002 | B1 |
6564331 | Joshi | May 2003 | B1 |
6594234 | Chard et al. | Jul 2003 | B1 |
6598123 | Anderson et al. | Jul 2003 | B1 |
6601144 | Arimilli et al. | Jul 2003 | B1 |
6631447 | Morioka et al. | Oct 2003 | B1 |
6647428 | Bannai et al. | Nov 2003 | B1 |
6662305 | Salmon et al. | Dec 2003 | B1 |
6735174 | Hefty et al. | May 2004 | B1 |
6775693 | Adams | Aug 2004 | B1 |
6799232 | Wang | Sep 2004 | B1 |
6861867 | West et al. | Mar 2005 | B2 |
6880028 | Kurth | Apr 2005 | B2 |
6889266 | Stadler | May 2005 | B1 |
6894978 | Hashimoto | May 2005 | B1 |
6954887 | Wang et al. | Oct 2005 | B2 |
6986026 | Roth et al. | Jan 2006 | B2 |
7007123 | Golla et al. | Feb 2006 | B2 |
7058826 | Fung | Jun 2006 | B2 |
7065594 | Ripy et al. | Jun 2006 | B2 |
7143219 | Chaudhari et al. | Nov 2006 | B1 |
7191373 | Wang et al. | Mar 2007 | B2 |
7239565 | Liu | Jul 2007 | B2 |
7280477 | Jeffries et al. | Oct 2007 | B2 |
7298746 | De La Iglesia et al. | Nov 2007 | B1 |
7363629 | Springer et al. | Apr 2008 | B2 |
7373420 | Lyon | May 2008 | B1 |
7401245 | Fischer et al. | Jul 2008 | B2 |
7454640 | Wong | Nov 2008 | B1 |
7454641 | Connor et al. | Nov 2008 | B2 |
7461236 | Wentzlaff | Dec 2008 | B1 |
7463529 | Matsubara | Dec 2008 | B2 |
7539845 | Wentzlaff et al. | May 2009 | B1 |
7613971 | Asaka | Nov 2009 | B2 |
7620791 | Wentzlaff et al. | Nov 2009 | B1 |
7640124 | Konishi et al. | Dec 2009 | B2 |
7698581 | Oh | Apr 2010 | B2 |
20010055323 | Rowett et al. | Dec 2001 | A1 |
20020078420 | Roth et al. | Jun 2002 | A1 |
20020087801 | Bogin et al. | Jul 2002 | A1 |
20020100020 | Hunter et al. | Jul 2002 | A1 |
20020129086 | Garcia-Luna-Aceves et al. | Sep 2002 | A1 |
20020138801 | Wang et al. | Sep 2002 | A1 |
20020156979 | Rodriguez | Oct 2002 | A1 |
20020184159 | Tadayon et al. | Dec 2002 | A1 |
20030007457 | Farrell et al. | Jan 2003 | A1 |
20030028749 | Ishikawa et al. | Feb 2003 | A1 |
20030050714 | Tymchenko | Mar 2003 | A1 |
20030050954 | Tayyar et al. | Mar 2003 | A1 |
20030074616 | Dorsey | Apr 2003 | A1 |
20030105799 | Khan et al. | Jun 2003 | A1 |
20030163649 | Kapur et al. | Aug 2003 | A1 |
20030177335 | Luick | Sep 2003 | A1 |
20030188053 | Tsai | Oct 2003 | A1 |
20030235202 | Van Der Zee et al. | Dec 2003 | A1 |
20040003184 | Safranek et al. | Jan 2004 | A1 |
20040019730 | Walker et al. | Jan 2004 | A1 |
20040024925 | Cypher et al. | Feb 2004 | A1 |
20040073780 | Roth et al. | Apr 2004 | A1 |
20040103218 | Blumrich et al. | May 2004 | A1 |
20040210694 | Shenderovich | Oct 2004 | A1 |
20040243739 | Spencer | Dec 2004 | A1 |
20050007986 | Malladi et al. | Jan 2005 | A1 |
20050053057 | Deneroff et al. | Mar 2005 | A1 |
20050076163 | Malalur | Apr 2005 | A1 |
20050160238 | Steely et al. | Jul 2005 | A1 |
20050216613 | Ganapathy et al. | Sep 2005 | A1 |
20050251613 | Kissell | Nov 2005 | A1 |
20050270886 | Takashima | Dec 2005 | A1 |
20050273564 | Lakshmanamurthy et al. | Dec 2005 | A1 |
20060050737 | Hsu | Mar 2006 | A1 |
20060080513 | Beukema et al. | Apr 2006 | A1 |
20060206635 | Alexander et al. | Sep 2006 | A1 |
20060248367 | Fischer et al. | Nov 2006 | A1 |
20070055832 | Beat | Mar 2007 | A1 |
20070133536 | Kim et al. | Jun 2007 | A1 |
20070168803 | Wang et al. | Jul 2007 | A1 |
20070174529 | Rodriguez et al. | Jul 2007 | A1 |
20070195774 | Sherman et al. | Aug 2007 | A1 |
20080147987 | Cantin et al. | Jun 2008 | A1 |
Number | Date | Country | |
---|---|---|---|
20090006894 A1 | Jan 2009 | US |