1. Field of the Invention
The present invention relates to a semiconductor device, and particularly to a semiconductor device having a capability of generating chip identification information.
2. Description of the Background Art
The market of electronic commerce services provided/received through the Internet has been expanding. The electronic money service by means of IC cards is now entering the stage of spread/expansion. For these services, a higher security technology is always demanded. At the software level, an encryption technology based on a tough encryption algorithm has offered adequate security. Meanwhile, at the hardware level where a similar algorithm is physically implemented, the risk of allowing a secret key to be decrypted by an attacker such as hacker (cracker) has been pointed out. While a technique of storing an ID in a fuse or nonvolatile memory during production of a chip has conventionally been adopted, the risk of falsification of the data and/or replication of the chip itself has been pointed out.
Japanese Patent Laying-Open No. 2012-43517 and H. Fujiwara et al., “A Chip-ID Generating Circuit for Dependable LSI Using Random Address Errors on Embedded SRAM and On-Chip Memory BIST”, VLSI Circuits, 2011 disclose that, based on an address of a random defective cell which is caused by reduction of the voltage to be supplied to memory cells of a built-in SRAM, an ID specific to a chip is generated. K. Lofstrom et al., “IC Identification Circuit Using Device Mismatch”, ISSCC 2000 discloses that, based on a change of the output voltage of an inverter constituted of a resistor and a plurality of transistors connected in parallel, an ID specific to a chip is generated. The plurality of transistors have respective threshold voltages different from each other. These transistors are successively accessed and a change of the output voltage of the inverter is digitized. Accordingly, an ID specific to a chip is generated.
Y. Su et al., “A 1.6 pJ/bit 96% Stable Chip-ID Generating Circuit Using Process Variations”, ISSCC 2007 discloses a configuration where, based on data held by a cross-coupling-type NOR circuit arranged in the form of an array, an ID specific to a chip is generated. Respective threshold voltages of transistors constituting the cross-coupling-type NOR circuit are set so that they differ from each other in each cross-coupling-type NOR circuit. S. Okumura et al., “A 128-bit Chip Identification Generating Scheme Exploiting SRAM Bitcells with Failure Rate of 4.45×10−19”, ESSCIRS 2011 discloses that a pair of bit lines is set to a low level and thereafter a word line is raised and, based on the value of a data-holding node of a memory cell, an ID specific to a chip is generated. S. Chellappa et al., “Improved Circuits for Microchip Identification Using SRAM Mismatch”, CICC 2011 discloses a configuration where a boost voltage is applied to a word line after a pair of bit lines is set to a high level and, based on the value of a data-holding node of a memory cell, an ID specific to a chip is generated.
A semiconductor device having a capability of generating chip identification information in an embodiment includes: a memory cell array including a plurality of memory cells arranged in rows and columns; a test address storage unit configured to store a test address; a self-diagnostic circuit configured to output the test address based on a result of operational confirmation of the memory cell selected by the test address; and an identification information generation circuit configured to generate chip identification information based on the test address output by the self-diagnostic circuit.
The foregoing and other objects, features, aspects and advantages of the present invention will become more apparent from the following detailed description of the present invention when taken in conjunction with the accompanying drawings.
In the following, embodiments will be described with reference to the drawings. In the description of the embodiments, the number, amount, or the like mentioned therein is not necessarily limited to the exact number, amount, or the like unless otherwise specified. In the drawings for the embodiments, the same reference characters or reference numerals represent the same or corresponding components. Further, in the description of the embodiments, a description of the components denoted by the same reference characters or the like may not be repeated depending on the case.
Referring to
Semiconductor device 1 includes a control circuit 101, a voltage generation circuit 102, an SRAM macro 103, a memory BIST (Built-In Self Test: self-diagnostic circuit) 104, a test address storage unit 105, an ID generation circuit 106, and an internal bus 107. Control circuit 101 uses a signal Vcnt1 to control a power supply voltage VDD and a word line voltage VWL that are output from voltage generation circuit 102. Further, control circuit 101 uses a signal Tcnt1 to control the operation of memory BIST 104, and transmits/receives a signal sg101 to/from internal bus 107. It should be noted that semiconductor device 1 will also be referred to herein as “chip” depending on the case.
SRAM macro 103 includes a memory cell array (not shown) made up of a plurality of memory cells MC (see
Test address storage unit 105 stores a plurality of test addresses Taddr, which will be described later herein. Each test address Taddr is selected by a storage address Faddr. Test address storage unit 105 is configured by a nonvolatile memory device such as e-fuse, flash memory, or the like which will hold data even if supply of the power supply voltage to semiconductor device 1 is shut off. The e-fuse is a fuse which is short-circuited or fixed in a disconnected state by application of predetermined electric current.
Memory BIST 104 is a self-diagnostic circuit controlling the operation of the SRAM macro, and the operation of memory BIST 104 is controlled in accordance with signal Tcnt1 which is output from control circuit 101. In response to storage address Faddr which is output from memory BIST 104, test address storage unit 105 outputs, to the memory BIST, test address Taddr associated with this storage address Faddr. Memory BIST 104 outputs, based on test address Taddr, a memory address Raddr to SRAM macro 103. Further, memory BIST 104 outputs to SRAM macro 103 write data Din for memory cell MC which is selected by memory address Raddr.
Memory BIST 104 receives from SRAM macro 103 read data Dout of memory cell MC which is selected by memory address Raddr. Memory BIST 104 determines whether write data Din and read data Dout match or mismatch each other. When these data mismatch each other, memory BIST 104 outputs memory address Raddr as a fail address FTaddr.
ID generation circuit 106 generates chip identification information ID based on fail address FTaddr and the like, and outputs chip identification information ID to control circuit 101. In response to a request signal Req, control circuit 101 outputs chip identification information ID. The source of this request signal Req and the destination of chip identification information ID are a server (not shown) connected through the Internet to an information terminal device (such as PC, mobile phone, or the like) on which semiconductor device 1 is mounted. When the chip identification information ID transmitted to the server matches chip identification information registered in the server, an electronic commerce service is started via the Internet.
Referring to
An n-type transistor M2 has its gate connected to a word line WL, one of its source and drain connected to node N0, and the other of its source and drain connected to a bit line BL. An n-type transistor M5 has its gate connected to word line WL, one of its source and drain connected to node N1, and the other of its source and drain connected to a bit line /BL.
Referring to
Chip identification information ID is generated by semiconductor device 1 through four steps of the procedure for semiconductor device 1.
In step S1, semiconductor device 1 identified as a nondefective chip is sorted out. A nondefective chip satisfying a catalog specification for semiconductor device 1 is sorted out by an LSI tester 109 (see
In step S2, an acceleration test is performed on the nondefective chip. The acceleration test is a test in which data is written in and data is read from a memory cell under operating conditions beyond a set range of power supply voltage and a set range of temperature for example that are defined by the catalog specification. In the acceleration test, a predetermined number of addresses of memory cells whose write data and read data match each other are extracted as stable pass bit addresses PBAs. Further, a predetermined number of addresses of memory cells whose write data and read data do not match each other are extracted as stable fail bit addresses FBAs. While semiconductor device 1 is being operated within the catalog specification, both the memory cells selected by stable pass bit addresses PBAs and stable fail bit addresses FBAs operate normally.
In step S3, test addresses Taddr are stored in test address storage unit 105. Test addresses Taddr are made up of the extracted stable pass bit addresses PBAs and stable fail bit addresses FBAs. These stable pass bit addresses PBAs and stable fail bit addresses FBAs are written in test address storage unit 105 in such a manner that they are mixed together in the storage unit. These steps S1 to S3 are performed as a part of a chip manufacture process prior to delivery of semiconductor device 1.
In step S4, chip identification information ID is generated. Chip identification information ID is generated based on the result of confirmation of the operation of memory cells selected by stable pass bit address PBAs and stable fail bit address FBAs stored in test address storage unit 105. At this time, semiconductor device 1 is in the state of being mounted on an information terminal device.
Referring to
Internal bus 107 included in semiconductor device 1 is connected through a data transmission pass sg108 and a contact portion 108 to LSI tester 109. Here, contact portion 108 is schematically shown as being configured to electrically connect semiconductor device 1 and LSI tester 109 to each other. For example, the contact portion corresponds to a pad formed on semiconductor device 1 and a prober connected to LSI tester 109. Data transmission pass sg108 is a control circuit connected between the aforementioned pad and internal bus 107.
Stable pass bit addresses PBAs and stable fail bit addresses FBAs extracted in step S2 of
Referring to
In the acceleration test (step S2), for the nondefective chip sorted out in the DC/AC test (step S1), the operation of the chip is confirmed under severer measurement conditions. The power supply voltage and the measurement temperature for example are set in step S2 of
In step S201 of
In step S202, a first measurement condition for confirming the operation of SRAM macro 103 is set. In the following, the first measurement condition will also be referred to as “Test (Best)” depending on the case. As the measurement condition, the power supply voltage and the measurement temperature or the measurement timing for example are set. In
In step S203, for a memory cell of SRAM macro 103 for which the Test (Best) condition is set, whether its write data Din and read data Dout match (Pass) or mismatch (Fail) each other is determined. A memory cell address in which one or more I/O bits out of N bits of the I/O width of SRAM macro 103 are determined to be “Fail” is identified as stable fail bit address FBAs and accordingly extracted.
In step S204, the memory cell address determined to be “Fail” in step S203 is written as stable fail bit addresses FBAs in the memory of LSI tester 109.
In step S205, whether or not extraction of a predetermined number of stable fail bit addresses FBAs is completed is determined. For example, when eight stable fail bit addresses FBAs have been extracted (YES), the procedure proceeds to the next step S207. When the number of extracted stable fail bit addresses is less than eight (NO), the procedure proceeds to step S206 in which address Raddr of the memory cell whose operation is confirmed is incremented by one.
In step S207, a second measurement condition for confirming the operation of SRAM macro 103 is set. In the following, the second measurement condition will also be referred to as “Test (Worst)” depending on the case. In
In step S208, for a memory cell of SRAM macro 103 for which the Test (Worst) condition is set, whether its write data Din and read data Dout match (Pass) or mismatch (Fail) each other is determined. A memory cell address in which all of the N bits of the I/O width of SRAM macro 103 are determined to be “Pass” is identified as stable pass bit address PBAs and accordingly extracted.
In step S209, the memory cell address determined to be “Pass” in step S208 is written as stable pass bit address PBAs in the memory of LSI tester 109.
In step S210, whether or not extraction of a predetermined number of stable pass bit addresses PBAs is completed is determined. For example, when 248 stable pass bit addresses PBAs have been extracted (YES), the procedure proceeds to step S3. When the number of extracted stable pass bit addresses is less than 248 (NO), the procedure proceeds to step S211 in which address Raddr of the memory cell whose operation is confirmed is incremented by one.
In step S3, the extracted eight stable fail bit addresses FBAs and 248 stable pass bit addresses PBAs are written in test address storage unit 105 with their order rearranged appropriately.
Referring to
Regarding the first to third measurement conditions, respective measurement temperatures are different from each other and respective power supply voltages VDD are different from each other. In view of the set values of the measurement temperature and power supply voltage VDD, respective static noise margins (hereinafter also referred to as SNM depending on the case) when a memory cell is read under respective measurement conditions are understood to have a relation therebetween as follows. Specifically, where respective SNM for the first measurement condition (Test (Best)), the second measurement condition (Test (Worst)), and the third measurement condition (at the time of ID generation) are represented by SNM1, SNM2, and SNM3, they have a relation therebetween: SNM1>SNM3>SNM2.
Accordingly, a memory cell selected by stable fail bit address FBAs extracted under the first measurement condition (Test (Best)) in step S203 (see
Likewise, a memory cell selected by stable pass bit address PBAs extracted under the second measurement condition (Test (Worst)) in step S208 (see
In the detailed flow of step S2 shown in
Regarding the first to third measurement conditions shown in
Accordingly, a memory cell selected by stable fail bit address FBAs extracted in step S203 will surely be determined to be a fail bit in the step of generating chip identification information ID in step S4. Likewise, a memory cell selected by stable pass bit address PBAs will surely be determined to be a pass bit in step S4 as well.
Referring to
At time t0, word line WL is raised from the low level to the high level (not shown). At time tB, sense amplifier SA is activated by sense amplifier enable signal SAE (see
For the first to third measurement conditions, power supply voltage VDD is set at 0.9 V. In contrast, respective sense amplifier activation timings for the first measurement condition (Test (Best)), the second measurement condition (Test (Worst)), and the third measurement condition (at the time of ID generation) have a relation therebetween: tW<tT<tB. The voltage between bit line BL and bit line /BL after activation of word line WL increases with the lapse of time from time t0.
Accordingly, a memory cell selected by stable fail bit address FBAs extracted under the first measurement condition will surely be determined to be a fail bit under the third measurement condition under which the sense amplifier is activated at an earlier timing than that under the first measurement condition. Likewise, a memory cell selected by stable pass bit address PBAs extracted under the second measurement condition will surely be determined to be a pass bit under the third measurement condition under which the sense amplifier is activated at a later timing than that under the second measurement condition.
Referring to
In step S3 (test addresses are stored), stable pass bit addresses PBAs and stable fail bit addresses FBAs extracted in step S2 (acceleration test) are written in test address storage unit 105.
As shown in
Test address storage unit 105 stores the 256 pieces of address data as test addresses Taddr. Test addresses Taddr stored in test address storage unit 105 are associated respectively with storage addresses Faddr (0 to 255). The storage addresses Faddr are designated to thereby access stable fail bit address FBAs and stable pass bit address PBAs stored in test address storage unit 105.
In step S3, stable fail bit addresses FBAs and stable pass bit addresses PBAs stored in the tester memory region are randomly rearranged in test address storage unit 105. Here, the random rearrangement means that stable fail bit addresses FBAs and stable pass bit addresses PBAs are not grouped but mixed together.
Referring to
In steps S203 and S208 that are included in step S2 and shown in
As shown in
It has already been confirmed that the memory cell addresses located in the acceleration test region except for the unstable bit addresses UBAs are each one of stable fail bit address FBAs and stable pass bit address PBAs. Thus, when chip identification information ID is to be generated in step S4, an address in the acceleration test region except for the addresses stored in test address storage unit 105 can be selected to generate identification information specific to the chip.
Referring to
Stable fail bit address FBAs (S203) in step S2 shown in
In contrast, in step S2 shown in
In step S3, the extracted stable fail bit addresses FBAs and stable pass bit address PBAs are stored as test addresses Taddr in test address storage unit 105. In the example of
In step S4, test addresses Taddr are read successively from test address storage unit 105, and the operation of the memory cells in SRAM macro 103 that are selected by respective test addresses is confirmed. In this case, the memory cell addresses (ADDR#0, ADDR#3) in which two or more bits out of the I/O width have been determined to be “Fail” are extracted as fail addresses FTaddr.
The criteria for determining whether an address is a Fail address or a Pass address in step S2 (acceleration test) and step S4 (ID generation) shown in
In step S2, a memory cell address in which N2f or more bits out of the N bits of the I/O width are determined to be “Fail” under the first measurement condition (Test (Best)) is identified as stable fail bit address FBAs and accordingly extracted. In step S4, stable fail bit address FBAs in which N4f or more bits out of the N bits of the I/O width are determined to be “Fail” under the third measurement condition (ID generation) is identified as a fail address FTaddr and accordingly output.
Here, the number of bits N2f and the number of bits N4f are defined as follows.
N2f>N4f
N2f−N4f=ΔNf Formula 1
The number of bits N2f and the number of bits N4f are thus defined by Formula 1 so that chip identification information ID is stably generated in step S4 based on stable fail bit addresses FBAs extracted in step S2, even if the number of I/O bits determined to be “Pass” in stable fail bit address FBAs is ΔNf or less.
Likewise, in step S2, a memory cell address in which N2p or more bits out of the N bits of the I/O width are determined to be “Pass” under the second measurement condition (Test (Worst)) is identified as stable pass bit address PBAs and accordingly extracted. In step S4, stable pass bit address PBAs in which N4p or more bits out of the N bits out of the N bits of the I/O width are determined to be “Pass” under the third measurement condition (ID generation) is not output as a fail address FTaddr.
Here, the number of bits N2p and the number of bits N4p are defined as follows.
N2p>N4p
N2p−N4f=ΔNp Formula 2
The number of bits N2p and the number of bits N4p are thus defined by Formula 2 so that stable pass bit address PBAs extracted in step S2 will not be determined to be fail address FTaddr in step S4 even if the number of I/O bits determined to be “Fail” in stable pass bit address PBAs is ΔNp or less. Accordingly, unstable generation of chip identification information ID based on stable pass bit addresses PBAs is avoided.
Referring to
In
As a result of steps S1 to S3 performed before delivery, test addresses Taddr made up of a predetermined number of stable fail bit addresses FBAs and a predetermined number of stable pass bit addresses PBAs are stored in test address storage unit 105. Each test address Taddr is selected by storage address Faddr.
In step S401, in response to request signal Req from a server, test address Taddr is read. Memory BIST 104 outputs storage address Faddr to test address storage unit 105. Test address storage unit 105 outputs to memory BIST 104 test address Taddr selected by storage address Faddr.
In step S402, write data Din is written in SRAM macro 103. Memory BIST 104 outputs to SRAM macro 103 the write data Din as well as test address Taddr which is to be used as memory address Raddr. SRAM macro 103 writes the write data Din in the memory cell selected by memory address Raddr. After this, in step S403, SRAM macro 103 outputs the read data Dout of this memory cell.
In step S404, memory BIST 104 determines whether write data Din and read data Dout match (Pass) or mismatch (Fail) each other. In the case where these data match each other, the flow proceeds to step S406. In the case where these data mismatch each other, memory BIST 104 identifies this memory cell address as fail address FTaddr and outputs it to ID generation circuit 106. The memory cell address determined to be “Fail” matches stable fail bit address FBAs. Thus, stable fail bit address FBAs is output to ID generation circuit 106 and stable pass bit address PBAs is not output thereto.
In step S406, it is determined whether or not the above steps have been performed for all test addresses Taddr stored in test address storage unit 105. When the confirmation of the operation of the aforementioned memory cells has been completed by means of all test addresses Taddr, chip identification information ID is generated in step S408. ID generation circuit 106 generates chip identification information ID based on fail addresses FTaddr which have been output from memory BIST 104, and outputs it to control circuit 101.
The value of SNM for a memory cell selected by stable fail bit address FBAs stored in test address storage unit 105 is larger in the step of acceleration test (step S2) than in the step of generating ID (step S4). Accordingly, stable fail bit address FBAs which is determined to be “Fail” in the step of acceleration test will surely be determined to be “Fail” as well in the step of generating ID. Likewise, the value of SNM for a memory cell selected by stable pass bit address PBAs is larger in the step of generating ID than in the step of acceleration test. Accordingly, stable pass bit address PBAs which is determined to be “Pass” in the step of acceleration test will surely be determined to be “Pass” as well in the step of generating ID.
The first measurement condition for extracting stable fail bit address FBAs, the second measurement condition for extracting stable pass bit address PBAs, and the third measurement condition which is set for generation of ID are defined so that respective SNM in the steps satisfy the above-indicated relation. Before the determination as to whether a memory cell is “Pass” or “Fail” is made when ID is to be generated, the memory cell for which the determination is to be made is extracted in advance in the acceleration test.
The extracted stable fail bit address FBAs and stable pass bit address PBAs are stored as test address Taddr in test address storage unit 105. Accordingly, chip identification information ID which is generated based on the result of operational confirmation of test address Taddr stored in test address storage unit 105 is stably generated regardless of temperature variation and/or secular variation of the transistor.
By way of example, test address storage unit 105 stores eight stable fail bit addresses FBAs and 248 stable pass bit addresses PBAs in such a manner that these addresses are mixed together in the storage unit. ID generation circuit 106 generates chip identification information ID from fail addresses FTaddr which are successively output from memory BIST 104, namely the eight stable fail bit addresses FBAs. The 248 stable pass bit addresses PBAs are recorded in test address storage unit 105 in order to ensure the tamper resistance of the chip identification information.
Further, for generation of chip identification information ID, information about I/O bits which are “Fail” in fail bit address FBAs is also used. For example, in the case where the first I/O bit and the seventh I/O bit in fail bit address FBAs are “Fail,” data generated by encrypting this 2-bit information, which is information about the number of defective bits, is also added to chip identification information ID. The information about the I/O bits which are defective in the address of the memory cell is not recorded in test address storage unit 105. Accordingly, the temper resistance is further strengthened.
Referring to
The signals shown along the vertical axis of
Time t1 corresponds to step S401 of
Time t2 corresponds to step S402 of
Time t3 corresponds to step S403 of
Time t4 corresponds to steps S404 and S405 of
It should be noted that in response to setting of write enable signal Rwen to the low level at time t4, SRAM macro 103 writes data “b” in the memory cell at address location B (step S402). Namely, in SRAM macro 103, operational confirmation for the former memory address Raddr (address location A) (step S404) and output of fail address FTaddr (step S405) are performed in parallel with writing of data at the subsequent memory address Raddr (address location B) (step S402).
After a predetermined time from time t5, SRAM macro 103 outputs read data Dout at address location B.
At time t6, the data (b) written at address location B of SRAM macro 103 is compared with the read data (b) of address location B. Since these data match each other, the determination “Pass” (symbol “Fail” is set to the low level) is made in step S404. When the determination “Pass” is made, memory BIST 104 does not output the address data at address location B to ID generation circuit 106.
Referring to
At time t1, in response to setting of storage address Faddr to 0, test address storage unit 105 outputs test address Taddr (address location A) to memory BIST 104. Memory BIST 104 generates, based on test address Taddr of address location A, memory addresses Raddr of address locations “A−2” to “A+1” and write data Din of “D0” to “D3” successively in respective clock cycles from clock cycle C1 to clock cycle C4. In the period from clock cycle C1 to clock cycle C4, write enable signal Rwen is kept at the low level. Accordingly, the memory cell selected by each memory address Raddr is written with the corresponding data.
Further, memory BIST 104 generates memory addresses Raddr of address locations “A−2” to “A” and “A+1” successively in respective clock cycles from clock cycle C5 to clock cycle C8. In the period from clock cycle C5 to clock cycle C8, write enable signal Rwen is kept at the high level. Therefore, the memory cell selected by each address location is not written with write data D3 or write data D4.
In respective clock cycles started at time t6, time t7, and time t8, the data of the memory cells selected by memory addresses Raddr “A−2,” “A−1” and “A” are output as read data Dout. Of these data, data D01 which is output in clock cycle C6 is different from write data Din (D0) in clock cycle C1, and therefore, the determination “Fail” is made at time t7. However, address location “A−2” is not test address Taddr and fail address FTaddr is not output.
Meanwhile, data D21 which is output in clock cycle C8 is read data Dout which is output from the memory cell at address location “A” of test address Taddr. Therefore, data D21 is compared with write data D2 in clock cycle C3. Since these data do not match each other, the determination “Fail” is made at time t9. In response to the determination “Fail,” memory BIST 104 outputs to ID generation circuit 106 the address data of the address location A as fail address FTaddr.
These other timing settings for step S4 make it possible to perform the operational confirmation of a memory cell selected by test address Taddr in consideration of the test pattern dependency in a similar manner to extraction of stable fail bit address FBAs and stable pass bit address PBAs. At this time, if write data Din and read data Dout of a memory cell other than the memory cell selected by test address Taddr mismatch each other, the address of this memory cell is inhibited from being output as fail address FTaddr. Step S4 is thus performed in consideration of the test pattern dependency, which further improves the reliability of the result of the operational confirmation of a memory cell selected by test address Taddr. Accordingly, chip identification information ID can further stably be generated.
Referring to
<First Modification of First Embodiment>
Referring to
In the acceleration test (step S2) on semiconductor device 1 in the first embodiment, the measurement conditions are set as shown in
The circuit configuration of memory cell MC shown in
Memory cell MC which is the non-selected state at time ts has its node N0 and node N1 on which respective voltages are kept at the high level (VDD) and the low level (VSS), respectively.
At time ts, bit line BL and bit line /BL are both set to the low level. After this, in response to the rise of word line WL, memory cell MC is selected. The operation of selecting memory cell MC with bit line BL and bit line /BL both set at the low level is herein defined as “writing at Low/Low.” Respective voltages on node N0 and node N1 of memory cell MC which has been written at Low/Low is determined by the driving ability of transistors whose drain or source is connected to each node. Regarding
At time te, word line WL changes from the high level to the low level. Then, memory cell MC is set again in the non-selected state and accordingly holds the data having been written at Low/Low.
The data written at Low/Low and held on nodes N0 and N1 is determined by the driving ability of the transistors constituting memory cell MC and the leakage current, for example. In the modification of the first embodiment, the writing at Low/Low is done as an acceleration test. Based on the result of the test, test address Taddr is determined.
Referring to
Measurement Condition 1 and Measurement Condition 2 are conditions for the acceleration test by writing at Low/Low. Respective measurement temperatures of Measurement Condition 1 and Measurement Condition 2 are set at 125° C. and −40° C., respectively. Respective power supply voltages VDD are both set at 0.9 V.
In
The obliquely hatched rectangular units represent memory cells holding data “1” (high level) as a result of being written at Low/Low. The blank rectangular units represent memory cells holding data “0” (low level) as a result of being written at Low/Low. The rectangular units marked with symbol “U” represent memory cells which have become unstable as a result of being written at Low/Low, namely unstable memory cells whose data held as a result of being written at Low/Low is not constant.
Test address Taddr which is written in test address storage unit 105 is determined in the following manner. First, in step S1 shown in
Next, on the nondefective chip thus sorted out, a first acceleration test is performed under Measurement Condition 1. The result of the test is stored in the data table to which symbol “Test#1_0” is given. This acceleration test under Measurement Condition 1 is conducted N times (the result of the Nth test is stored in data table “Test#1_N−1” (not shown)). Based on respective results of the first to Nth tests, the result of the acceleration test under Measurement Condition 1 stored in a data table Test#1_N is stored in the tester memory region.
On the same chip, an acceleration test under Measurement Condition 2 is conducted N times. Based on respective results of the first to Nth tests, the result of the acceleration test under Measurement Condition 2 stored in a data table Test#2_N is stored in the tester memory region.
The combined results of the acceleration tests are stored in a data table Test#R. Where a rectangular unit in data table Test#1_N and a corresponding rectangular unit in data table Test#2_N both hold data “0,” data “0” is written in the corresponding rectangular unit in data table Test#R. Data “1” is written in a rectangular unit of data table Test#R in a similar manner. Where symbol “U” is written in at least one of a rectangular unit in data table Test#1_N and the corresponding rectangular unit in data table Test#2_N, symbol “U” is written in the corresponding rectangular unit in data table Test#R.
Finally, memory addresses Raddr each including no unstable memory cell marked with symbol “U” are extracted to serve as test addresses Taddr. In
Referring to
In step S402a, test address Taddr extracted in the acceleration test by writing at Low/Low is read in response to request signal Req from a server. Memory BIST 104 outputs storage address Faddr to test address storage unit 105. Test address storage unit 105 outputs to memory BIST 104 test address Taddr which is selected by storage address Faddr.
In step S403a, memory BIST 104 outputs to SRAM macro 103 test address Taddr to serve as memory address Raddr. At this time, write data Din is not output from memory BIST 104 to SRAM macro 103. After this, in step S403a, SRAM macro 103 outputs read data Dout of the memory cell.
In step S404a, memory BIST 104 outputs read data Dout to ID generation circuit 106. In step S405a, it is determined whether or not the above-described steps have been performed for all test addresses Taddr stored in test address storage unit 105. In the case where reading of all test addresses Taddr has not been completed, storage address Faddr is incremented in step S406a. When output of read data Dout of the memory cell is completed for all test addresses Taddr, chip identification information ID is generated by the ID generation circuit in step S407a.
In contrast to step S4 shown in
Referring to
The method for generating chip identification information ID shown in
In step S402b, in response to request signal Req from a server, memory BIST 104 sets memory address Raddr to an address other than test address Taddr. In step S403b, read data Dout of the memory cell which is selected by memory address Raddr is output. In step S404b, memory BIST 104 outputs this read data Dout to ID generation circuit 106. In step S405b, it is determined whether or not the number of read data Dout has reached a predetermined number thereof which is necessary for generating chip identification information ID. When the number of read data Dout has not reached the predetermined number, memory address Raddr is incremented by one in step S406b. When the number of read data Dout has reached the predetermined number, ID generation circuit 106 generates chip identification information ID in step S407b.
As to the first modification of the first embodiment, the configuration and the method for determining test address Taddr have been described based on the example where writing at Low/Low is done to select memory cell MC with bit line BL and bit line /BL both set at the low level. The method for determining the bias of the data holding characteristics of memory cell MC is not limited to the writing at Low/Low. For example, writing at High/High where memory cell MC is selected with bit line BL and bit line /BL set at the high level is also applicable. Further, the reproducibility of data held in a memory cell immediately after the power supply voltage is applied (power-on) can be confirmed, so that the address of the memory cell holding the reproducible data after power-on can be used as test address Taddr.
<Second Modification of First Embodiment>
Referring to
Semiconductor device 1 in the second modification of the first embodiment differs from semiconductor device 1 of the first embodiment shown in
In
An ECC code storage unit 105c stores, as error correction code Eccd, parity data corresponding to memory address Raddr. In response to input of memory address Raddr, ECC code storage unit 105c outputs, to error correction circuit 110, error correction code Eccd which is selected by memory address Raddr. SRAM macro 103 outputs, to error correction circuit 110, read data Dout of the memory cell selected by memory address Raddr which is output from memory BIST 104. Based on error correction code Eccd, error correction circuit 110 corrects the error in read data Dout, and outputs the resultant read data Doutc.
When chip identification information ID is to be generated, even if selected memory addresses include a memory address of an unstable memory cell, error correction circuit 110 appropriately corrects output data Dout of the memory cell. Accordingly, chip identification information ID can be generated stably.
Referring to
To SRAM macro 103 of semiconductor device 2, power supply voltage VDD and word line voltage VWL that are output from a voltage generation circuit 102a formed on a chip separate from semiconductor device 2 are supplied. Voltage generation circuit 102a is limited in its operation by signal Vcnt1 which is output from control circuit 101 of semiconductor device 2.
A test address storage unit 105a is formed by another chip (nonvolatile memory for example) which is separate from semiconductor device 2. In test address storage unit 105a, test address Taddr extracted in the acceleration test is written in a similar manner to that stored in test address storage unit 105 of semiconductor device 1 in the first embodiment and the modification of the first embodiment. Since semiconductor device 2 and test address storage unit 105a are formed as separate chips, the process for manufacturing semiconductor device 2 is simplified. Accordingly, the manufacturing cost of semiconductor device 2 can be reduced.
Referring to
In response to storage address Faddr which is output from memory BIST 104, test address storage unit 105 outputs to memory BIST 104 test address Taddr which is associated with this storage address Faddr. Based on test address Taddr, memory BIST 104 outputs memory address Raddr to ID-generation SRAM macro 103a. Further, memory BIST 104 outputs to ID-generation SRAM macro 103 write data Din to be written in the memory cell selected by memory address Raddr.
Memory BIST 104 receives from ID-generation SRAM 103a read data Dout of the memory cell selected by memory address Raddr. Memory BIST 104 determines whether write data Din and read data Dout match or mismatch each other and, when these data do not match each other, memory BIST 104 outputs memory address Raddr as fail address FTaddr.
Referring to
As shown in
For memory cell MCa having the SNM characteristic of
For memory cell MCa having the above-indicated conductance ratio, a sufficient SNM is ensured, and write data Din and read data Dout of memory cell MCa match each other. Accordingly, stable pass bit address PBAs can be extracted without changing the voltage supplied to SRAM macro 103a, namely without performing the acceleration test.
In contrast, for a memory cell MCa having the SNM characteristic of
In
Based on the result of the operational confirmation of ID-generation SRAM 103a by memory BIST 104, stable fail bit address FBAs and stable pass bit address PBAs are extracted. A predetermined number of extracted stable fail bit addresses FBAs and a predetermined number of extracted stable pass bit addresses PBAs are stored to serve as test addresses Taddr in test address storage unit 105. These steps are performed through the memory of LSI tester 109 shown in
Semiconductor device 3 in the third embodiment does not require the voltage generation circuit, which is effective in reducing the chip area. Further, the ID-generation SRAM enables stable generation of test addresses. Accordingly, stable generation of chip identification information is achieved while the chip area is prevented from increasing.
Although the present invention has been described and illustrated in detail, it is clearly understood that the same is by way of illustration and example only and is not to be taken by way of limitation, the scope of the present invention being interpreted by the terms of the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
2012-198732 | Sep 2012 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
6067262 | Irrinki | May 2000 | A |
6367042 | Phan | Apr 2002 | B1 |
7171596 | Boehler | Jan 2007 | B2 |
20100254205 | Yamauchi | Oct 2010 | A1 |
20120044777 | Fujiwara et al. | Feb 2012 | A1 |
Number | Date | Country |
---|---|---|
H0737399 | Feb 1995 | JP |
2003187595 | Jul 2003 | JP |
2006269023 | Oct 2006 | JP |
2012-043517 | Mar 2012 | JP |
2012073954 | Apr 2012 | JP |
Entry |
---|
Japanese Office Action dated Nov. 24, 2015, issued in Japanese Application No. 2012-198732 (English Translation provided). |
H. Fujiwara, et al., “A Chip-ID Generating Circuit for Dependable LSI Using Random Address Errors on Embedded SRAM and On-Chip Memory BIST”, Symposium on VLSI Circuits Digest of Techincal Papers 2011, pp. 76-77. |
Keith Lofstrom, et al., “IC Identification Circuit Using Device Mismatch”, IEEE International Solid-State Circuits Conference 2000. |
Y. Su, et al., “A 1.6pJ/bit 96% Stable Chip-ID Generating Circuit Using Process Variations”, IEEE International Solid-State Circuits Conference 2007, pp. 406-407, 611. |
Shunsuke Okumura, et al., “A 128-bit Chip Identification Generating Scheme Exploiting SRAM Bitcells with Failure Rate of 4.45x10EXP-19” ESSCIRS 2011, pp. 527-530. |
Srivatsan Chellappa et al., “Improved Circuits for Microchip Identification Using SRAM Mismatch”, CICC 2011. |
Number | Date | Country | |
---|---|---|---|
20140070212 A1 | Mar 2014 | US |