This application is directed, in general, to an electronic device, and, more specifically, to testing thereof.
A complex integrated circuit (IC) device often includes test circuitry. Such circuitry may be used to test the device at the end of the manufacturing line, or may be used after the device is shipped and installed by a system integrator to ensure continued proper operation of the device.
A scan chain is sometimes used in the test circuitry. The scan chain typically includes a number of scan cells arranged such that a scan cell at a later stage of the chain receives the output of a scan cell at an earlier stage of the chain. A multiplexer located between the scan cells receives the prior cell's output and a functional bit from device logic that may be tested using the scan chain. When a scan is enabled, the multiplexer selects the output of the previous scan cell for input to the later scan cell. When the scan is disabled, the multiplexer selects the functional bit. Thus, test data may be serially loaded into the scan chain, and input to the logic under test. Internal values produced by the logic under test may then be serially shifted out of the scan chain for evaluation.
One aspect provides a scan cell. The scan cell includes first, second and third data inputs and a control input. The first, second and third data inputs are configured to receive respective first, second and third data bits. The control input is configured to receive a control signal. Latching logic is configured to latch an input value to a scan cell output. Selection logic is configured to select the input value from between the first, second and third data bits, depending on a state of the control signal.
Another embodiment provides an integrated circuit (IC). The IC includes a functional block and a scan cell coupled thereto. The scan cell includes first, second and third data inputs and a control input. The first, second and third data inputs are configured to receive respective first, second and third data bits. The first data bit is received from the functional block. The control input is configured to receive a self-test signal. Latching logic is configured to latch an input value to a scan cell output. Selection logic is configured to select the input value from between the first, second and third data bits depending on a state of the self-test signal.
Another embodiment is a method of forming an integrated circuit. The method includes forming over a semiconductor substrate a scan cell that includes first, second and third data inputs. The first, second and third data inputs are configured to receive respective first, second and third data bits. Latching logic is configured to receive an input value at a latch input and to latch the input value to a scan cell output. Selection logic is configured to receive a self-test signal and to select the input value from between the first, second and third data bits depending on a state of the self-test signal.
Yet another embodiment is a library of standard logic elements. The library includes a standard logic element corresponding to a scan cell. The scan cell includes first, second and third data inputs and a control input. The first, second and third data inputs are configured to receive respective first, second and third data bits. The control input is configured to receive a control signal. Latching logic is configured to latch an input value to a scan cell output. Selection logic is configured to select the input value from between the first, second and third data bits, depending on a state of the control signal.
Reference is now made to the following descriptions taken in conjunction with the accompanying drawings, in which:
Herein a digital signal may be equivalently described having a value of TRUE or “1”. A digital signal may also be equivalently described having a value of FALSE or “0”. Herein when an input to a logical element is described as being “configured” to receive a particular input, the input may include any number of gates, transistors or interconnects suitably configured to provide the desired input functionality. Herein a data bit is a bit of a serial data stream or a parallel data word that conveys information, as opposed to a clock or a control bit that exerts control over the function of one or more logic elements such as a multiplexer. Herein a multiplexer delay is a delay subjected on a data bit presented at a data input of a multiplexer. A multiplexer is any combination of gates, transistors, interconnects, etc. configured to select between first and second data inputs under the control of a selector control signal presented at a selector input. Herein a data input is an input configured to receive a data bit, as opposed to a selector signal or a clock signal. Herein, a signal may be referred to as “asserted” or “unasserted”. An asserted signal is one that has a logic value selected to result in a stated effect. The signal may be referred to as unasserted when the signal has a logic value that does not result in the stated effect. An asserted signal may be a logical “1” or a logical “0” depending on the specific configuration of logical elements.
Scan chains are conventionally used at the end of a manufacturing line to test various portions of an IC device. Test data provided by an end-of-line tester may be serially shifted into the scan chain. Internal functional data that results from the test data may be loaded into the scan chain. The internal data may then be serially shifted out of the scan chain and evaluated.
In some cases, however, it may also be desirable to test a functional block, e.g. a memory or combinatorial logic, of the device after the device has shipped to a customer. Conventionally such testing may be done using built-in self-test (BIST) circuitry that includes a BIST engine designed to provide various test vectors to the functional block to ensure accurate operation. The test vectors are typically provided in the form of parallel data, such as a word of data to be loaded into a memory. In such cases it may be desirable or necessary to integrate the BIST circuitry with the scan chain. It may also be desirable or necessary to retain the ability to provide test data to the functional block in serial fashion via a scan chain to provide end-of-line test capability. However, conventional scan chains are not equipped to accommodate both serial and parallel data without increasing the latency of a critical data path.
This disclosure includes embodiments that provide the novel ability of a scan chain to support both serial and parallel loading of test data without increasing critical data latency. Thus, a single scan chain may support both end-of-line testing and BIST testing without reducing performance of the IC during normal operation. Self-test of the functional block after installation of the IC is therefore possible with little or no performance penalty and without the need for redundant test circuitry.
Turning to
Selection logic 310 receives the BISTE input, SIN, and test_DIN signals, and optionally the SE signal, if present. The latching logic 320 receives one or more clocks, represented as CLK(s). In some embodiments the selection logic 310 receives the DIN signal, while in other embodiments the latching logic receives the DIN signal. A dashed line denotes the optional routing of the DIN signal in
A serial scan bit sequence SIN enters the scan chain 410 via the scan cell 300-a. The Q output of each scan cell 300 is received by the selection logic 310 (
Each scan cell 300 additionally receives a corresponding DIN bit from a functional block 430 that is controlled by the functional block controller 420. The functional block 430 may be, e.g. a combinatorial logic block or a memory. During normal operation, the functional block 430 receives control signals (not shown) to store and retrieve data used within the IC 400.
During a test of the functional block 430, e.g. an end-of-line test, the SE signal is asserted and the SIN path provides a serial bit sequence to load the scan chain 410 with a desired bit pattern. The bit pattern may be input in parallel to the functional block 430 via q0, q1, . . . qn. The scan chain 410 may subsequently retrieve in parallel a response pattern from the functional block 430. The response pattern may then be serially shifted out from the scan chain 410 via SOUT for evaluation.
During a self-test, e.g. after installation in an end product, the functional block controller 420 may control the scan chain 410 to load parallel data therein, such as a 16-bit test vector. The functional block controller 420 may then control the functional block 430 to store the test vector output by the Q-outputs of the individual scan cells 300. The functional block controller 420 may further control the functional block 430 to retrieve a response vector therefrom and store the individual bits of the response vector in each corresponding scan cell 300. The response vector may then be serially scanned out of the scan cell for evaluation by the functional block controller 420 or other means.
In the illustrated embodiment the scan cell 500 includes selection logic 510 and latching logic 520. The selection logic 510 includes a first multiplexer 530 and a second multiplexer 540. The latching logic 520 includes a D flip-flop 550. The first multiplexer 530 selects between SIN and test_DIN under control of the BISTE signal. For example, the first multiplexer 530 may be configured to select SIN when BISTE is unasserted (e.g. FALSE) and test_DIN when BISTE is asserted (e.g. TRUE). The second multiplexer 540 selects between the output of the first multiplexer 530 and the DIN bit under control of SE and BISTE. Thus, the DIN bit is subject to only a single multiplexer delay before the latching logic, while the SIN and test_DIN bits are subjected to two multiplexer delays. An OR gate 560 and the second multiplexer 540 are configured such that when either SE or BISTE are asserted, the output of the first multiplexer 530 (SIN or test_DIN) is selected for input to the flip-flop 550. When both SE and BISTE are unasserted the multiplexer 540 selects DIN for input to the flip-flop 550.
Those skilled in the pertinent art will appreciate that the OR gate 560 may be implemented equivalently by a NOR gate or a De Morgan equivalent logic element. For example, the operation of the OR gate 560 and the multiplexer 540 may be provided by a NOR gate in combination with reversing the logical sense at the selector input to the multiplexer 540. In another example the OR gate may be replaced by a NAND gate with negated inputs, in combination with reversing the sense of the SE and BISTE signals and reversing the sense of the selector input to the multiplexer 540. For the purpose of the disclosure and the claims the OR gate encompasses these and any other logic elements that are configured to control the multiplexer 540 to select the output of the multiplexer 530 in the event that one or both of the BISTE and SE signals is asserted.
Advantageously the configuration of the scan cell 500 results in little or no additional latency of the DIN signal relative to the conventional scan cell 100. Other possible configurations, such as for example selecting between the SIN and DIN signals using the first multiplexer 530, would add a multiplexer delay to the DIN signal, increasing the critical path length of the DIN signal and reducing the maximum clock speed of the IC 400. In contrast, the scan cell 500 advantageously shifts the additional multiplexer delay to the SIN and test_DIN signals. While the additional multiplexer delay of these signals may in some cases reduce the maximum possible rate of shifting in serial test data or loading parallel test data to the scan chain 410, in many cases it will be more desirable to accept the delay of these test signals while maintaining the full clock rate of the normal operation of the IC 400.
The embodiment of the selection logic 510 illustrated in
By inspection of the truth table it is evident that:
In the illustrated embodiment the scan cell 600 includes selection logic 610 and latching logic 620. The selection logic 610 includes a multiplexer 630. The latching logic 620 includes a two-phase clocked flip-flop 640. The flip-flop 640 receives the DIN signal via a D1 input. The data presented at the D1 input is clocked to the Q1 output at an active edge of the A clock. The multiplexer 630 is configured to select between the SIN and test_DIN signals depending on the logic value of BISTE. For example, as illustrated the multiplexer 630 selects SIN when BISTE is unasserted, and selects test_DIN when BISTE is asserted. Thus, the DIN bit is subject to no delay by the selection logic, while the SIN and test_DIN bits are subjected to a single multiplexer delay. The flip-flop 640 receives the output of the multiplexer 630 at a D2 input. The output of the multiplexer 630 is clocked to the Q1 output of the flip-flop 640 at an active edge of the B clock. The value of Q1 is clocked to the Q2 output at an active edge of the C clock. Thus, in the present embodiment the C clock does not play a role in determining which of SIN, DIN and test_DIN appears at the Q1 and Q2 outputs, but shifts the value of the Q1 output to the Q2 output consistent with the operation of the functional abstraction 230 of
As described with respect to the scan cell 500, the DIN signal experiences little or no additional latency in the scan cell 600, as compared to the conventional scan cell 200. The SIN and test_DIN signals experience an additional multiplexer delay. But as described previously, it may be preferable that these signals are delayed so that the IC 400 may be clocked during normal operation at a greater clock frequency than possible if the DIN signal were delayed.
The scan cells 500, 600 may be conveniently implemented as library cells in a library of standard logic elements used by an automated design tool. Those skilled in the pertinent art appreciate that automated design tools include various elements of a computational system, including data entry means such as keyboards, data storage elements such as disk drives, semiconductor memory and the like, computational elements such as processors and coprocessors, and networking means. The automated design tool may employ hard and soft macros to implement the various logic elements that are provided by the library.
Turning to
In a step 810, first, second and third data inputs of a first scan cell, e.g. the scan cell 300b, are configured to receive respective first, second and third data bits. In a step 820 latching logic is configured to receive an input value at a latch input and to latch the input value to a scan cell output. In a step 830 selection logic is configured to select the input value from between the first, second and third data bits depending on a state of a self-test signal.
In an optional step 840 a functional block, e.g. the functional block 430, is configured to output a first parallel data word including the first data bit. In an optional step 850 a functional block controller, e.g. the functional block controller 420, is configured to output the self-test signal and a second parallel data word that includes the second data bit. In an optional step 860, a second scan cell, e.g. the scan cell 300-a, is configured to provide the third data bit to the first scan cell.
Those skilled in the art to which this application relates will appreciate that other and further additions, deletions, substitutions and modifications may be made to the described embodiments.
This application is related to U.S. patent application Ser. No. ______ (attorney docket No. L09-0408US2) filed concurrently with the present application and incorporated herein by reference.