Integrated circuits are often designed to incorporate scan test circuitry that facilitates testing for various internal fault conditions. Such scan test circuitry typically comprises scan chains, which are chains of flip-flops that are used to form serial shift registers for applying test patterns at inputs to combinational logic of the integrated circuit and for reading out the corresponding results.
A given one of the flip-flops of the scan chain may be viewed as an example of what is more generally referred to herein as a “scan cell.” A scan cell may comprise a single flip-flop, or multiple flip-flops.
In one exemplary arrangement, an integrated circuit with scan test circuitry may have a scan shift mode of operation and a functional mode of operation. A flag may be used to indicate whether the integrated circuit is in scan shift mode or functional mode. In the scan shift mode, the flip-flops of the scan chain are configured as a serial shift register. A test pattern is then shifted into the serial shill register formed by the flip-flops of the scan chain. Once the desired test pattern has been shifted in, the scan shift mode is disabled and the integrated circuit is placed in its functional mode. Internal combinational logic results occurring during this functional mode of operation are then captured by the chain of scan flip-flops. The integrated circuit is then once again placed in its scan shift mode of operation, in order to allow the captured combinational logic results to be shifted out of the serial shift register formed by the scan flip-flops, as a new test pattern is being scanned in. This process is repeated until all desired test patterns have been applied to the integrated circuit.
As integrated circuits have become increasingly complex, scan compression techniques have been developed which reduce the number of test patterns that need to be applied when testing a given integrated circuit, and therefore also reduce the required test time. Additional details regarding compressed scan testing are disclosed in U.S. Pat. No. 7,831,876, entitled “Testing a Circuit with Compressed Scan Subsets,” which is commonly assigned herewith and incorporated by reference herein.
Nonetheless, a need remains for further improvements in scan test circuitry. For example, conventional scan test circuitry can be problematic when used in certain scan testing applications, such as scan testing of high-speed registers of a processor or other type of integrated circuit.
Illustrative embodiments of the invention provide improved circuitry and techniques for scan testing of integrated circuits. For example, in one or more such embodiments, scan test circuitry of an integrated circuit is configured to include at least one scan chain that comprises at least one scan cell, with the scan cell being configured to implement functional output multiplexing between data outputs of respective master and slave flip-flops of that scan cell. Such a scan cell advantageously avoids the above-noted problems associated with use of conventional master-slave scan cell arrangements in high-speed registers and other types of scan testing applications.
In one embodiment of the invention, an integrated circuit comprises scan test circuitry and additional circuitry subject to testing utilizing the scan test circuitry. The scan test circuitry comprises at least one scan chain having a plurality of scan cells, with the scan chain being configured to operate as a serial shift register in a scan shift mode of operation and to capture functional data from at least a portion of the additional circuitry in a functional mode of operation. At least a given one of the scan cells of the scan chain comprises multiplexing circuitry configured to select one of a plurality of data lines of the scan cell for application to a functional output of the scan cell.
The given scan cell may illustratively comprise a master flip-flop having a data input and a data output, and a slave flip-flop having a data input and a data output, with the data input of the slave flip-flop being coupled to the data output of the master flip-flop. The multiplexing circuitry in an arrangement of this type may comprise an output multiplexer configured to select one of the data output of the master flip-flop and the data output of the slave flip-flop for connection to the functional output of the scan cell responsive to a logic state of a test mode select signal.
In this or another embodiment of the invention, the given scan cell may further comprise a functional data input, a scan input, and a scan enable input. In such an arrangement, the multiplexing circuitry may further comprise an input multiplexer configured to select one of the functional data input and the scan input for connection to the data input of the master flip-flop responsive to a logic state of a scan enable signal applied to the scan enable input.
In this or another embodiment of the invention, a scan cell is configured to be arranged with a plurality of other scan cells into a scan chain having a scan shift mode of operation and a functional mode of operation. The scan cell comprises multiplexing circuitry configured to select one of a plurality of data lines of the scan cell for application to a functional output of the scan cell.
Such a scan cell configuration in one or more of the illustrative embodiments provides significantly improved scan testing performance, particularly in high-speed applications such as testing of integrated circuit registers.
Embodiments of the invention will be illustrated herein in conjunction with exemplary testing systems and corresponding integrated circuits comprising scan test circuitry for supporting scan testing of other internal circuitry of those integrated circuits. It should be understood, however, that embodiments of the invention are more generally applicable to any testing system or associated integrated circuit in which it is desirable to provide improved scan testing performance, particularly in high-speed applications such as those involving registers.
The particular configuration of testing system 100 as shown in
Embodiments of the invention may be configured to utilize compressed or noncompressed scan testing, and embodiments of the invention are not limited in this regard. However, the embodiment of the invention shown in
Referring now to
The scan chains 204 are arranged in parallel with one another between respective outputs of the decompressor 200 and respective inputs of the compressor 202, such that in the scan shift mode of operation, scan test input data from the decompressor 200 is shifted into the scan chains 204 and scan test output data is shifted out of the scan chains 204 into the compressor 202.
The decompressor 200 and compressor 202 may be combinational or sequential, and the functionality disclosed herein does not require any particular combinational or sequential compression arrangement.
The first scan chain 204-1 is of length n1 and therefore comprises n1 scan cells denoted 206-1 through 206-n1. More generally', scan chain 204-k is of length nk and therefore comprises a total of nk scan cells. Circuitry under test 207 in this embodiment comprises a plurality of combinational logic blocks, of which exemplary blocks 208, 210 and 212 are shown. The combinational logic blocks are illustratively arranged between primary inputs 214 and primary outputs 216 and separated from one another by the scan chains 204.
Combinational logic blocks such as 208, 210 and 212 may be viewed as examples of what are more generally referred to herein as “additional circuitry” that is subject to testing utilizing scan test circuitry in embodiments of the invention. By way of example, such blocks may represent portions of different integrated circuit cores, such as respective read channel and additional cores of a system-on-chip (SOC) integrated circuit in a hard disk drive (HDD) controller application. In other embodiments, the circuit blocks subject to testing by the scan chains may comprise other types of functional logic circuitry, in any combination, and the term “additional circuitry” is intended to be broadly construed so as to cover any such arrangements of logic circuitry.
The number K of scan chains 204 is generally much larger than a number N of scan test outputs of the compressor 202. The ratio of K to N provides a measure of the degree of scan test pattern compression implemented in the scan test circuitry 106. It should be noted, however, that the number of compressor outputs need not be the same as the number of decompressor inputs. For example, there may be N decompressor inputs and L compressor outputs, where N≠L but both N and L are much smaller than K.
The decompressor 200 receives compressed scan data from the tester 102 and decompresses that scan data to generate scan test input data that is shifted into the scan chains 204 when such chains are configured as respective serial shift registers in the scan shift mode of operation. The compressor 202 receives scan test output data shifted out of the scan chains 204, also when such chains are configured as respective serial shift registers in the scan shift mode of operation, and compresses that scan test output data for delivery back to the tester 102. Additional details regarding the operation of scan compression elements such as decompressor 200 and compressor 202 may be found in the above-cited U.S. Pat. No. 7,831,876. Again, scan compression elements such as decompressor 200 and compressor 202 may be eliminated in other embodiments.
In a typical implementation, the lengths of the scan chains 204 are balanced so that the same amount of time is needed to shill the desired set of scan test patterns into all of the scan chains. It may therefore be assumed without limitation that all of the scan chains 204 are of length n, such that n1=n2= . . . =nk=n.
The scan cell 300 as shown comprises a functional data input (D), a scan input (SI), a scan enable input (SE), a scan output (SO) and a clock input (CK). Also, the master flip-flop 302 has a data input (I) and a data output (Q), and the slave flip-flop 304 has a data input (I′) and a data output (Q′).
Notations such as D, SI, SO, SE, CK and so on will be used herein to denote not only the physical inputs and outputs of the scan cell, but also the corresponding signals associated with those inputs or outputs.
The data output of the master flip-flop 302 is coupled to the data input of the slave flip-flop 304. The data output of the master flip-flop 302 in this embodiment also drives a functional output 310 of the scan cell 300. This functional output is coupled to functional logic, which may be part of one of the logic blocks 208, 210 or 212.
The master flip-flop 302 has a clock input that receives a clock signal applied to the clock input CK of the scan cell 300. The stave flip-flop 304 has a clock input that receives a complemented version of the clock signal, as provided by the inverter 306.
It will be assumed in this embodiment of the invention that a scan enable signal applied to the scan enable input SE of the scan cell 300 is at a logic “1” level when the integrated circuit 104 is in a scan shift mode of operation and at a logic “0” level when the integrated circuit 104 is in the functional mode of operation, although in other embodiments of the invention the scan enable signal can take on other values for the scan shift and functional modes. Other types and combinations of operating modes and scan enable signaling may be used in other embodiments. For example, different portions of the integrated circuit 104 and its associated scan test circuitry 106 may be controlled using separate scan enable signals.
The input multiplexer 305 is therefore operative to connect the scan input SI of the scan cell 300 to the data input I of the master flip-flop 302 in the scan shift mode of operation, and to connect the functional data input D of the scan cell 300 to the data input I of the master flip-flop 302 in the functional mode of operation.
The timing diagram of
As mentioned previously, the scan cell 300 is configured such that the output of the master flip-flop 302 drives the functional output 310 of the scan cell. Such an arrangement is designed to allow the scan cell to operate in high-speed applications, by reducing the delay which would otherwise result if the output of the slave flip-flop were used to drive the functional output of the scan cell. The term “high-speed” in this context refers to those applications in which delay such as that associated with passage of a functional signal through an additional flip-flop can undermine operating performance.
However, we have found that such an arrangement can lead to problems during scan testing. More specifically, at the first rising edge of the clock signal CK after the scan enable signal SE goes low, as indicated generally by reference numeral 400 in
The scan cell 500 configured as shown in
Like the scan cell 300, the scan cell 500 comprises functional data input D, scan input SI, scan enable input SE, scan output SO and clock input CK. Also, the master flip-flop 502 has a data input I and a data output Q, and the slave flip-flop 504 has a data input I′ and a data output Q′. The data output Q of the master flip-flop 502 is coupled to the data input I′ of the slave flip-flop 504. The data output Q of the master flip-flop 502 in this embodiment also drives a data line 510 that is provided as one input to an output multiplexer 512.
The master flip-flop 502 has a clock input that receives a clock signal applied to the clock input CK of the scan cell 500. The slave flip-flop 504 has a clock input that receives a complemented version of the clock signal, as provided by the inverter 506.
It is again assumed in this embodiment that a scan enable signal applied to the scan enable input SE of the scan cell 500 is at a logic “1” level when the integrated circuit 104 is in a scan shift mode of operation and at a logic “0” level when the integrated circuit 104 is in the functional mode of operation. Other types and combinations of operating modes and scan enable signaling may be used in other embodiments.
The input multiplexer 505 is therefore operative to connect the scan input SI of the scan cell 500 to the data input I of the master flip-flop 502 in the scan shift mode of operation, and to connect the functional data input D of the scan cell 500 to the data input I of the master flip-flop 502 in the functional mode of operation.
As indicated above, the scan cell 500 comprises additional multiplexing circuitry relative to the scan cell 300. This additional multiplexing circuitry will now be described in greater detail. In the scan cell 500, data lines 510 and 511 corresponding to the Q and Q′ outputs of the respective master and slave flip-flops 502 and 504 are coupled to respective first and second inputs of a two-to-one output multiplexer 512. Responsive to a test mode select signal generated by logic gate 514, the output multiplexer 512 selects one of the data lines 510 and 511 of the scan cell 500 for application to a functional output 516 of the scan cell.
The logic gate 514 is illustratively implemented as a two-input OR gate which receives signals denoted Test Mode 1 and Test Mode 2 at its respective inputs. These test mode signals may be associated, for example, with different scan testing modes of the integrated circuit 104. In the present embodiment, if either or both of the Test Mode 1 and Test Mode 2 signals are at logic “1” signal levels, the multiplexer 512 selects the SO line 511 for application to the functional output 516 of the scan cell 500. If both of the Test Mode 1 and Test Mode 2 signals are at logic “0” signal levels, the multiplexer 512 selects the line 510 from the Q output of the master flip-flop 502 for application to the functional output 516 of the scan cell 500. Other types of test mode signals and corresponding logic circuitry for controlling multiplexer 512 can be used in other embodiments.
The output multiplexer 512 in the scan cell 500 can be advantageously utilized to eliminate the above-described garbage generation phase associated with the scan cell 300, thereby providing significantly improved scan testing performance. This performance improvement comes at the cost of additional delay in the functional path through the multiplexer 512, as well as reduced fault coverage for a portion of the functional path.
Although only a single scan cell 500 is shown in
A scan cell of the type shown in
It should be noted that other types of scan cells and functional output multiplexing arrangements may be used in other embodiments. The two-to-one multiplexer 512 as used in scan cell 500 is therefore just one example of what is more generally referred to herein as “multiplexing circuitry.”
As mentioned above, a scan cell configured as shown in
The tester 102 in the testing system 100 of
The insertion of scan cells to form scan chains in scan test circuitry of an integrated circuit design may be performed in a processing system 700 of the type shown in
Elements such as 710, 712, 714 and 716 are implemented at least in part in the form of software stored in memory 704 and processed by processor 702. For example, the memory 704 may store program code that is executed by the processor 702 to implement particular scan cell insertion functionality of module 710 within an overall integrated circuit design process. The memory 704 is an example of what is more generally referred to herein as a computer-readable medium or other type of computer program product having computer program code embodied therein, and may comprise, for example, electronic memory such as RAM or ROM, magnetic memory, optical memory, or other types of storage devices in any combination. The processor 702 may comprise a microprocessor, CPU, ASIC, FPGA or other type of processing device, as well as portions or combinations of such devices.
As indicated above, embodiments of the invention may be implemented in the form of integrated circuits. In a given such integrated circuit implementation, identical die are typically formed in a repeated pattern on a surface of a semiconductor wafer. Each die includes scan test circuitry as described herein, and may include other structures or circuits. The individual die are cut or diced from the wafer, then packaged as an integrated circuit. One skilled in the art would know how to dice wafers and package die to produce integrated circuits. Integrated circuits so manufactured are considered part of one or more embodiments of this invention.
Again, it should be emphasized that the embodiments of the invention as described herein are intended to be illustrative only. For example, other embodiments of the invention can be implemented using a wide variety of other types of scan test circuitry, with different types and arrangements of scan cells, multiplexing circuitry, logic gates and other circuit elements, than those previously described in conjunction with the illustrative embodiments. These and numerous other alternative embodiments of the invention within the scope of the following claims will be readily apparent to those skilled in the art.