This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2007-269795, filed on Oct. 17, 2007, the entire contents of which are incorporated herein by reference.
1. Field of the Invention
The present invention relates to a semiconductor memory device and in particular a semiconductor memory device arranged with an interface for testing.
2. Description of the Related Art
In the Japanese Laid Open Patent 2001-184899, an interface circuit for testing a memory mounted with a logic circuit is disclosed arranged with a control circuit for controlling programming and reading of data of a first in first out circuit responsive to an operation mode instruction signal which shows the input and output of data.
Furthermore, the above stated interface circuit only controls the programming and reading of test data to a first in first out circuit in response to an operation mode instruction signal which shows the input and output of data and does not disclose technology for storing the data for testing itself in an interface circuit and performing a test operation.
A semiconductor memory device related to an embodiment of the present invention includes a memory cell array including a plurality of memory cells, a first interface part having a predetermined number of pins, a second interface part having a smaller number of the pins than the first interface part, a data pattern latch part which stores an externally input or preliminarily set data pattern, a comparison part which compares the data pattern input from the data pattern latch part with data which is read from the memory cell array, and a comparison result output part arranged in the second interface part, and which outputs a comparison result of the comparison part.
First, an outline of a semiconductor memory device test will be explained. A NAND type flash memory will be explained as an example of the semiconductor memory device.
The tester 2 stores a test program based on the specifications of the NAND type flash memory chip, supplies the variety of signals (e.g. power supply voltage, I/O command, control command and test data etc) to the plurality of NAND type flash memory chips on the test board 3 based on this test program and performs an operation test (programming, reading, erasure etc). Then, the tester 2 receives a reply signal of an operation test result (for example, a comparison result of read data) from each NAND type flash memory chip and indicates whether each NAND type flash memory chip is normal or defective.
The test board 3 is arranged with a plurality of pins (not shown in the diagram) for connecting the plurality of NAND type flash memory chips which are detachable. These pins are input with a variety of signals (e.g. power supply voltage, I/O command, control command and test data etc) which are supplied from the tester 2 via the above stated cable 4 and reply signals are output from each NAND type flash memory chip.
The control pad 11 is a pad for receiving various control commands from external host equipment or the above stated tester 2. The input/output pad 12 is a pad for the input and output of data in units of 8 bits (herein referred to as 8 bit data) and is comprised from a plurality of I/O pads.
The input/output buffer 13 retains various control commands which are input from the control pad 11, data which is input from the input/output pad 12 or data which is input from the column decoder 19, inputs the retained control commands or data according to an operation within the NAND type flash memory chip 10 and outputs the retained data according to an operation of an external equipment or the above stated tester 2.
The command buffer 14 retains various control commands which are input from the control pad 11 and outputs these retained control commands to the control circuit 15. In addition, the command buffer 14 retains data which is input from the input/output buffer 13 and outputs the retained data to the control circuit 15.
The control circuit 15 performs sequential control operations such as data read, data program and data erasure based on various control commands which are input from the command buffer 14 according to an operation mode. In addition, the control circuit 15 outputs a control signal for generating a voltage necessary for various operation modes to the voltage generation circuit 16. Furthermore, the control circuit 15 resets each part within the NAND type flash memory chip 10 based on a power on reset command input from the power on reset circuit 22.
The voltage generation circuit 16 generates various voltages Vpp (programming voltage, verify voltage, programming bus voltage, read voltage etc) according to an operation mode and supplies these voltages to the row decoder 18 and the sense amplifier 20. The voltage generation circuit 16 is controlled by the control circuit 15.
The address buffer 17 stores address data input from the input/output buffer 13, outputs a row address to the row decoder 18 and outputs a column address to the column decoder 19.
The row decoder 18 selects a word line of the memory cell array 21 based on a row address input from the address buffer 17 and drives the selected word line.
The column decoder 19 connects the sense amplifier 20 with a data bus based on a column address input from the address buffer 17, inputs programming data to a latch circuit of the sense amplifier 20 and selects a column address which outputs read data from the latch circuit of the sense amplifier 20.
At the time of data input, the sense amplifier 20 programs data which is input from the input/output buffer 13 to nonvolatile memory cells within the memory cell array 21 which are selected by the row decoder 18 and the column decoder 19. In addition, at the time of data input, the sense amplifier 20 reads the data which is stored in the nonvolatile memory cells (not shown in the diagram) within memory cell array 21 which are selected by the row decoder 18 and the column decoder 19 and outputs the data to the input/output buffer 13.
The memory cell array 21 is comprised by arranging a plurality of NAND cell units (not shown in the diagram). Each NAND cell unit includes a plurality of electrically reprogrammable nonvolatile memory cells and a selection gate transistor for connecting both ends of the nonvolatile memory cells to a bit line and a source line respectively. Control gates of the nonvolatile memory cells are each respectively connected to different word lines. Gates of the selection gate transistors are connected to selection gates which run parallel to the word lines. A group of NAND cell units which share a word line is comprised of a memory block which is the unit of data erasure. A plurality of these memory blocks is included within the memory cell array 21.
The power on reset circuit 22 outputs a power on reset command to the control circuit 15 when a power supply from external host equipment or the above stated tester 2 is switched on.
Next, the construction related to inputs and outputs within the NAND type flash memory chip 10 shown in
The control pad 11 includes pads 11a to 11e which respectively input a chip enable/CE, a write enable/WE, a read enable/RE, a command latch enable/CLE and address latch enable/ALE as control commands. In addition, input buffers 32a to 32e are connected between the input/output buffer 13, the command buffer 14, the address buffer 17 and the pads 11a to 11e. The input/output pad 12 includes I/O 0 to I/O 7 pads 12a to 12h which input and output data in units of 8 bits. The power supply pad 31 includes a pad 31a which inputs a power supply voltage VCC and a pad 31b which inputs a power supply voltage VSS.
Furthermore, in
During the command input time period T1 shown in
Next, during the address input time period T2 shown in
Next, during the data input time period T3 shown in
In addition, during the data input period T4 shown in
As stated above, command input, address input, data input and data output are carried out using a total of fifteen pads comprising two power supply pads 31, eight input/output pads 12 and five control pads 11 in the case of the NAND type flash memory chip 10. In the NAND type flash memory chip 10, a control signal is generated by a command input which is input from the tester 2 and each test of a data program operation, data read operation and data erase operation is performed by a combination of each operation shown in
In addition, as stated above, because a total of fifteen pads are arranged in the NAND type flash memory chip 10, for example, in the case where twenty NAND type flash memory chips 10 as shown in
Below, the embodiments of the present invention will be explained while referring to the diagrams. A NAND type flash memory chip will be explained as an example of the semiconductor memory device related to the embodiments. Furthermore, the same structural elements have the same symbols and to prevent repetition between embodiments a number of explanations will be omitted.
In the First embodiment an example of an interface for testing which includes a test pad within a NAND type flash memory chip and an example of reducing the number of pins on a test board 3 will be explained.
In
In the interface for testing 43, test signal switching circuits 44a to 44e which are connected to each input line of the control pad 11 are switched by a test signal TEST and each input line after input buffers 32a to 32e is connected to the input/output buffer 13, command buffer 14 and address buffer 17, or each input line on the side of the test pad 41 is connected to the input/output buffer 13, command buffer 14 and address buffer 17. In the interface for testing 43, in the case where a test mode signal is input from the TMODE pad 41, the test signal switching circuits 44a to 44e are switched by a test signal TEST and each line on the test pad 41 side becomes connected to the input/output buffer 13, the command buffer 14 and the address buffer 17.
Data and clock signals which are input via input buffers 42a to 42c from the test pad 41 are each input to the input/output buffer 13, the command buffer 14 and the address buffer 17 respectively via the test signal switching circuits 44a to 44e by the interface for testing 43. Also, the interface for testing 43 output data which is input via an IO bus for testing 45 connected to the input/output buffer 13 to the TIO pad 41a.
The test pad 41 and the interface for testing 43 are arranged as an interface part (second interface part) for serially inputting and outputting data in one bit units from the tester 2 and performing a test. A test mode in which a test is performed by serially inputting and outputting data in one bit units is called an [X1 mode] in the first and later embodiments. Therefore, in the NAND type flash memory chip 10 related to the first embodiment, there are three pads for testing and compared to the fifteen pads shown in
The test board 3 which connects the NAND type flash memory chip 10 arranged with pads used in testing is exemplary shown in
The [X1 mode] which is performed in the NAND type flash memory 10 related to the first embodiment will be explained with reference to
Each data format at the time of inputting a data code shown in
When a data code shown in
In addition, depending on whether the [Interface Bit] is “High” or “Low”, the NAND type flash memory chip 10 interprets the [Data Code] which is subsequently input differently. In the [Data Code] example shown in
When a data code shown in
The waveform in the case where a command 00h is input based on the data format shown in
In the waveform exemplarily shown in
The data format when a data code is output is different to a data format when a data code is input. Whether the state of a data code is made an input state or an output state is determined in the following way. The data code which in input at the next eleven bits is interpreted within the NAND type flash memory chip 10 as a data output state by setting an interface command, that is, a read enable RE bit, to “High” within the [Interface Bit], as shown in
The data format when a data code is output is comprised by a [Start Bit] (one bit, fixed as “High”), [Interface Bit] (one bit), [Dummy Bit] (one bit) and [Data Code] (eight bits) as shown in
Next, a circuit construction of a data input/output part 50 within the NAND type flash memory chip 10 is shown in
The IO bus selector 52 includes switches SW1 to SW3. The 10 bus selector 52 selects a bus SAIO_BUS which is connected to an external sense amplifier, an ID_BUS which is connected to a chip ID register and a bus STATUS_BUS which is connected to a status register, via switches SW1 to SW3 and outputs to an IO bus IO_BUS.
The X8 output buffer 53 outputs eight bit data to I/O pads I/O 0 to I/O 7 by synchronizing with a clock by a read enable/RE which is input from the interface for testing 43 via a test signal switching circuit 44.
The X1 mode data output part 54 includes an X8 latch circuit 54a, a time division circuit 54b and an X1 output buffer 54c.
The X8 latch circuit 54a latches eight bit data which is input from IO bus IO_BUS by synchronizing with a clock by a Dummy Bit which is input from the interface for testing 43 via the test signal switching circuit 44.
The time division circuit 54b selects bit by bit eight bit data which is latched by the X8 latch circuit 54a, and outputs to the X1 output buffer 54c based on a bit which is selected by a REX1 signal input from the interface for testing 43. The REX1 signal is generated from a clock signal/TCLK from the fourth bit to the eleventh bit among the above stated eleven bit structure.
Therefore, in the data input/output part 50 in
In the second embodiment, an example in which the number of test pins of a NAND type flash memory chip and time for testing is reduced will be explained.
An X1 mode data output part 61 includes the X8 latch circuit 54a, the time division circuit 54b, the X1 output buffer 54c, a data pattern latch circuit 61a and a comparator 61b.
The data pattern latch circuit 61a latches data patterns (a110 pattern “00”, a111 pattern “FF”, checker board pattern “55” “AA” etc) for testing in units of eight bits. The data patterns for testing are input in advance and latched before the NAND type flash memory chip 10 is tested by the tester 2.
The comparator 61b compares eight bit data latched by the X8 latch circuit 54a with eight bit data latched by the data pattern latch circuit 61a and outputs a flag FLG which shows the comparison result to the X1 output buffer 54c. The comparator 61b outputs a flag, FLG=0, when all of the eight bit data matches, and outputs a flag, FLG=1, when none of the bits among the eight bits matches. The comparator 61b outputs flags FLG which are the comparisons and comparison results of eight bit data for each cycle of the above stated I/O 0 to I/O 7, when the input of an RE_comp clock signal from the interface for testing 43 starts.
In addition, in the X8 latch circuit 54a, eight bit data which is input from the IO bus IO_BUS is sequentially latched in eight cycles from the clock from the above stated Dummy Bit up to the clock from the I/O 0 to I/O 6 within the above stated data code. That is, in the X8 latch circuit 54a, eight pairs of eight bit data are sequentially latched in eight cycles.
Next, the test operations in the data input/output part 60 within the NAND type flash memory chip 10 related to the second embodiment will be explained while referring to an example of a waveform shown in
In
Next, in
At this time, in the test operation related to the first embodiment shown in
Unlike the operation in
Furthermore, the data format which is input in the command input time period shown in
Therefore, in the NAND type flash memory chip 10 related to the second embodiment, the number of pads for testing can be reduced, the number pins of the test board 3 and the costs of the tester 2 can be significantly reduced and it is also possible to realize a reduction in the time required for testing.
In the third embodiment, it is possible to reduce the number of test pins of a NAND type flash memory chip. In the third embodiment, an example which makes a test of sixteen bit data possible and reduces the time required for testing will be explained.
An X1 mode data output part 71 includes the X8 latch circuit 54a, the time division circuit 54b, the X1 output buffer 54c, a shift register for a data pattern 71a and the comparator 61b.
The shift register for a test pattern 71a stores two eight bit data patterns and alternately outputs the two eight bit patterns via the shift register to the comparator 61a.
By using the shift register for data patterns 71a it is possible to compare two types of certain data pattern, A and B, with a sixteen bit structure shown in
In the fourth embodiment the number of test pins of a NAND type flash memory chip can be reduced. In addition, an example in which it is possible to output detailed fail bit data as a test result and reduce the time required for testing will be explained.
An X1 mode data output part 81 includes the X8 latch circuit 54a, the time division 54b, the X1 output buffer 54c, the shift register for data patterns 71a, the comparator 61b and a shift register 81a.
The shift register 81a stores comparison results for eight cycles of 8 bit data and sequentially outputs fail bit data FBD which shows in detail comparison results for eight cycles of 8 bit data, to the time division circuit 54b in a clock cycle of a fail bit read signal RE_fb input from the interface for testing 43.
The time division circuit 54b switches usual data which is input from the X8 latch circuit 54a with the fail bit data FBD which is input from the shift register 81a and outputs to the X1 output buffer 54c according to a selection signal SELDAT which is input from the interface for testing 43.
The comparator 61b sequentially outputs flags FLG which shows comparison results for 8×8 bit data, to the X1 output buffer 54c in 8 cycles, and sequentially outputs comparison results for 8 bit data (8 bit data which includes comparison results for each bit of data) to the shift register 81a.
Next, a test operation with the NAND type flash memory chip 10 related to the fourth embodiment will be explained while referring to the flowchart shown in
When a test operation begins in
Next, the shift register 81a stores 8 bit data which is input from the comparator 61b (step S102). Then, the comparator 61b and the shift register 81a repeat processing of the above stated steps S101 and S102 for 8 cycles (step S103). The shift register 81a sequentially stores 8 bit data which input from the comparator 61b whether there are no matches (defective bits) or not within the 8 bit data by repeating this 8 cycle operation. Two types of data, namely data “0” which shows a match and data “1” which shows a non-match are included for each compared bit in the 8 bit data stored in the shift register 81a. In addition, the comparator 61b sequentially outputs flags FLG which shows comparison results of 8×8 bit data, to the X1 output buffer 54c.
Next, the shift register 81a determines whether there are defective bits in the 8 cycles of comparison processing of 8×8 bit data (step S104). If there are no defective bits (step S104: NO), the process shifts to step S107. In addition, if the shift register 81a determines that there are defective bits (step S104: YES), the process shifts to step S105.
Next, the shift register 81a outputs by time division the stored 8 bit data as fail bit data FBD with an 11 bit structure according to a clock cycle of a fail bit read signal RE_fb input from the interface for testing 43 (step S105). Then, the shift register 81a repeats for 8 cycles the output process by time division of the fail bit data FBD in the above stated step S105. (step S106).
Next, the comparator 61b confirms whether a data comparison process has been performed up to the last column with the same page (step S107). If the process has not been performed up to the last column (step S107: NO), the process returns to step S101 and the processes from step S101 to step S106 are repeated. In addition, if the process has been performed up to the last column (step S107: YES), then the test operation is complete.
Next, specific examples of a comparison operation of 8 bit data and an output operation of fail bit data FBD by the test operation described above will be explained while referring to
In
In
In
In
Specifically, as shown in
Next, third from the left 8 bit data within the 8×8 bit data, that is, no defective bits are included in the 8 bit data stored in the address #2 within the shift register 81a. As a result, fail bit data FBD of 8 bits which are all data “0”, is output as a data code with an 11 bit structure. The remaining 5×8 but data are similarly output by a data code format with an 11 bit structure. When these fail bit data FBD are output the Dummy Bit is set at “1”.
As above, in the fourth embodiment, at the time of a test operation, flags FLG which show the presence of defective bits are output as an 8 bit data comparison result and detailed fail bit data FBD which shows the location of this defective bits occurs are also output. As a result, it is possible to know in which 8 bit data defective bits are included during a comparison process of 8×8 bit data and it is also possible to know where this defective bit occurs.
Next, another example of a test operation in the fourth embodiment will be explained by referring to the flowchart in
When the test operation begins in
Next, the shift register 81a stores only 8 bit data which includes a defective bit among the 8 bit data which is input from the comparator 61b (step S202). Then, the comparator 61b and the shift register 81a repeat processing of the above stated steps S201 and S202 for 8 cycles (step S203). The shift register 81a sequentially stores only 8 bit data which has a non-match (defective bit) within the 8 bit data among the 8 bit data which input from the comparator 61b by repeating this 8 cycle operation. Two types of data, namely data “0” which shows a match and data “1” which shows a non-match are included for each compared bit in the 8 bit data stored in the shift register 81a. In addition, the comparator 61b sequentially outputs flags FLG which show comparison results of 8×8 bit data, to the X1 output buffer 54c.
Next, the shift register 81a determines whether there are defective bits in the 8 cycles of comparison processing of 8×8 bit data (step S204). If there are no defective bits (step S204: NO), the process shifts to step S208. In addition, if the shift register determines that there are defective bits (step S204: YES), the process shifts to step S205.
In step S205, the shift register 81a further determines whether there are defective bits in the stored 8 bit data. If there are no defective bits (step S205: MO), the process shifts to step S207. In addition, if the shift register determines that there are defective bits (step S205: YES), the process shifts to step S206.
In step S206, the shift register 81a outputs by time division the 8 bit data which includes defective bits as fail bit data FBD. Then, the shift register 81a repeats for 8 cycles the output process by time division of the fail bit data FBD in the above stated step S206. (step S207).
Next, the comparator 61b confirms whether a data comparison process has been performed up to the last column within the same page (step S208). If the process has not been performed up to the last column (step S208: NO), the process returns to step S201 and the processes from step S201 to step S207 are repeated. In addition, if the process has been performed up to the last column (step S208: YES), then the test operation is complete.
Next, the comparison operation of 8 bit data and a specific example of an output operation of fail bit data FBD by the above stated test operation will be explained while referring to
In
In
In
In
Specifically, as shown in
Next, the seventh 8 bit data from the left within the 8×8 bit data, that is, one defective bit is included in the 8 bit data stored in the address #6 within the shift register 81a. File bit data FBD of 8 bits which includes data “1” (normal bit is “0”) which shows the location where this defective bit occurs, is output as a data code with an 11 bit structure. When these fail bit data FBD are output the Dummy Bit is set at “1”.
As above, in the fourth embodiment, at the time of another test operation, flags FLG which show the presence of defective bits are output as an 8 bit data comparison result and only detailed fail bit data FBD which shows the location of this defective bit are output. As a result, it is possible to further reduce the time required for testing.
In the fifth embodiment the number of test pins of a NAND type flash memory chip can be reduced. In addition, an example in which it is possible to output address data of a defective bit as a test result and reduce the time required for testing will be explained.
An X1 mode data output part 91 includes the X8 latch circuit 54a, the time division circuit 54b, the X1 output buffer 54c, the shift register for data patterns 71a, the comparator 61b and the shift register 81a.
The comparator 61b sequentially outputs flags FLG which shows comparison results for 8×8 bit data, to the X1 output buffer 54c and the shift register 81a in 8 cycles.
The shift register 81a stores only address data of a defective bit among the flags FLG which are input from the comparator 61b and outputs address data of the stored defective bit as fail bit address data FBA after reading of the data from the memory cell array 21 is complete. This fail bit address data FBA is output to the time division circuit 54b via an output FBA bus.
Next, a test operation within the NAND type flash memory chip 10 related to the fifth embodiment will be explained while referring to the flowchart in
When the test operation begins in
Next, the shift register 81a reads and stores only address data of 8 bit data which includes a defective bit among the 8 bit data which is input from the comparator 61b (step S302). Then, the comparator 61b and the shift register 81a repeat processing of the above stated steps S301 and S302 for 8 cycles (step S303). The shift register 81a sequentially stores only address data of 8 bit data which has a non-match (defective bit) within the 8 bit data among the 8 bit data which input from the comparator 61b by repeating this 8 cycle operation.
Next, the comparator 61b confirms whether a data comparison process has been performed up to the last column within the same page (step S304). If the process has not been performed up to the last column (step S304: NO), the process returns to step S301 and the processes from step S301 to step S303 are repeated. In addition, if the process has been performed up to the last column (step S208: YES), then the process shifts to step S305.
Next, when a X1 shift register read command is input, the output bus FBA of the shift register 81a is selected as the input of the time division circuit 54b (step S302). The shift register 81a outputs address data in 8 bit units to the time division circuit 81a via the FBA bus according to a RE_fb clock signal input from the interface for testing 43, outputs by time division the stored 8 bit data as fail bit data with an 11 bit structure (step S306) and the present test operation is complete.
Next, a specific example of an 8 bit data comparison operation and an output operation of a data code will be explained while referring to
In
In
In
After outputting of a data code is complete, address data of defective bits stored in the shift register 81a is sequentially output as fail bit address data FBA according to a clock cycle of a fail bit read signal RE_fb input from the interface for testing 43. In this case, the address data is output as data of 13 Bits when the page length in a memory block within the memory cell array 21 is for example, 8 Kbytes. Therefore, because address data can not be output once in one cycle (11 clocks), an address is output in two cycles (11 clocks×2).
As stated above, in the fifth embodiment, at the time of a test operation, a flag FLG which shows the presence or not of a defective bit as a comparison result of 8 bit data is output and address data which shows the location where this defective bit occurs is output as fail bit address data FBA. As a result, it is possible to know in which 8 bit data defective bits are included during a comparison process of 8×8 bit data and it is also possible to know where this defective bit occurs. As a result, it is possible to reduce costs of the tester 2 and also reduce the time required for testing.
In the sixth embodiment, an example in which the number of test pins of a NAND type flash memory chip are reduced, is explained. In addition, an example in which the time required for a test and the time required for outputting a test result of a memory block which has many defective bits is reduced is also explained.
In the data input/output part 100 in the NAND type flash memory chip 10 related to the sixth embodiment, it is assumed that almost all the bits in a page are determined in advance to be defective bits similar to defective ROW in the memory cell array 21. In this case, by inverting and reading the data within this page, it is possible to reduce the output time of a test result in the case where there are many defective bits, reduce the time required for a test and also output details of the defective bits.
The data input/output part 100 includes an inversion and change determination circuit 102 which has a function to invert read data. The inversion and change determination circuit 102 determines whether an inversion and change of read data is required based on the number of defective bits included in the data read from a certain page in the memory cell array 21. Furthermore, an X1 mode data output part 101 includes an inversion and change circuit 101a. The inversion and change circuit 101a is activated in the case where it is determined in the inversion and change determination circuit 102 that an inversion and change are required and inverts and changes data patterns read from the shift register for data patterns 71a.
The inversion and change determination circuit 102 determines that it is necessary to invert and change read data in the case where defective bits (FLG=1) which are included in flags FLG which show comparison results for 8×8 bit data stored in the shift register 81a are a predetermined number, (for example, more than half of the total) and activates the inversion and change circuit 101a.
In the sixth embodiment, a test mode signal TEST 2 is input from the tester 2 as a test mode for initiating the inversion and change determination circuit 102. In addition, when the test mode signal TEST 2 is input, a control signal INVJD is input to the comparator 61b from the interface for testing 43. This control signal INVJD is a signal which sets a column address range when the comparator 61b reads data from a page within the memory cell array 21. A column address range is specified, for example, as a column address a number of columns from the head column in a page and a column address a number of columns form the last column. That is, by reading data from a plurality of column addresses with are separated within a page rather than reading data from adjacent column address it is possible to increase accuracy when the number of defective bits included in a page is determined. Furthermore, the column address range in which data is read is not limited and can be appropriately changed according to page capacity for example within a memory cell array.
When the control signal INVJD (“High”) is input from the interface for testing 43, 8 bit data is sequentially read from a plurality of columns within the above stated page and the comparator 61b compares this data with a data pattern read from the shift register for data patterns 71a. The comparator 61b stores a comparison result of this 8 bit data in the shift register 81a. At this time, the inversion and change circuit 101a is not activated and the data pattern which is read from the shift register for data patterns 71a is input to the comparator 61b without being inverted.
The inversion and change determination circuit 102 determines whether it is necessary to invert and change read data depending on whether the number of defective bits which are included in flags FLG which show comparison results for 8×8 bit data of separated plurality of column addresses stored in the shift register 81a are a predetermined number, (for example, more than half of the total).
Next, a test operation within the NAND type flash memory chip 10 related to the sixth embodiment will be explained while referring to the flowchart in
In
When the control signal INVJD (“High”) is input 8 bit data of each column address from the column address #0 and last column address of a page within the memory cell array 21 is sequentially read and the comparator 61b compares this data with a data pattern read from the shift register for data patterns 71a (step S402). The comparator 61b stores flags FLG (8 bit) which show comparison results for 8×8 bit data in the shift register 81a.
Next, the inversion and change determination circuit 102 determines whether a page is ROW defective or not depending on whether flags FLG (FLG=1) which include defective bits among flags FLG of 8 bits are more than half the total based on flags FLG (8 bits) which show comparison results for 8×8 bit data stored in the shift register 81a (step S403). If the inversion and change determination circuit 102 determines that the page is ROW defective (step S403: YES), the process shifts to step S404 and activates the inversion and change circuit 101a. In addition, if the inversion and change determination circuit 102 determines that the page is not ROW defective (step S403: NO), the process shifts to step S405.
Below, operations after step S405 in the case where the inversion and change circuit 101a is initiated in step S404 will be explained.
In step S405, the 8 bit data which is to be compared is read from the page which is determined to be ROW defective in the memory cell array 21 and the comparator 61b reads an 8 bit data pattern from the shift register for data patterns 71 a compares this with the data from the ROW defective page. In this case, the data which is read from the shift register for data patterns 71a is inverted and changed by the inversion and change circuit 101a. That is, “0” of a data pattern is inverted to “1” and “1” is inverted to “0”. Therefore, in a comparison result of 8 bit data, matching bits (below referred to as normal bits) become “1” and non-matching bits (below referred to as defective bits) become “0”. In addition, the flags FLG which show comparison results of 8 bit data which includes defective bit become “0” and the flags FLG which show comparison results of 8 bit data which do not include defective bit become “1”.
Next, the comparator 61b outputs comparison results of 8 bit data which show the above comparison results to the shift register 81a and also output flags FLG which show these comparison results to the X1 output buffer 54c. The shift register 81a correlates only the 8 bit data which includes normal bits among the comparison results of 8 bit data which are input from the comparator 61b, with the addresses #0 to #7 and stores them (step S406).
Next, the comparator 61b and the shift register 81a repeat the processes in the above stated steps S405 and S406 for 8 cycles (step S407). By the operations in these 8 cycles the shift register 81a correlates only the 8 bit data which includes normal bits among the 8 bit data which is input from the comparator 61b, with the column addresses #0 to #7 and sequentially stores them.
Next, the shift register 81a determines whether there are defective bits in the comparison process of 8×8 bit data performed for 8 cycles (step S408). In this case, “1” shows a normal bit with the 8 bit data and if this “1” is included (step S408: YES) the process shifts to step S409.
In step S409 the shift register 81a further confirms whether there are defective bits in each 8 bit data stored in the column addresses #0 to #7 (step S408). In this case, “1” shows a normal bit with the 8 bit data and if this “1” is included (step S409: YES) the process shifts to step S410.
In step S410, the shift register 81a outputs by time division 8 bit data which includes defective bits as fail bit data FBD. Then, the shift register 81a repeats this output process by time division of the fail bit data FBD in the above stated step S410 for 8 cycles (step S411). In this case, a defective bit is set as “0” and a normal bit is set as “1” for each fail bit data FBD over the 8 cycles and output as a data code with the above stated 11 bit structure. In this data code the above stated Dummy Bit is set at “1”. When this Dummy Bit is set at “1” indicates that this is an output of fail bit data FBD.
Next, the comparator 61b confirms whether the data comparison process has been performed up to the last column with the same page (step S412). If the process has not been performed up to the last column (step S412: NO), the process returns to step S405 and the processes in steps S405 to step S411 are repeated. In addition, if the comparison process has been performed up to the last column (step S412: YES), then the test operation is complete.
In addition, operations after step S405 in the case where the inversion and change circuit 101a is not initiated in step S404 will be explained.
In step S405, the 8 bit data which is to be compared is read from a page within the memory cell array 21 and the comparator 61b reads an 8 bit data pattern from the shift register for data patterns 71a and compares this with the data to be compared. Then the comparator 61b outputs comparison results of the 8 bit data to the shift register 81a and also outputs flags FLG (1 bit data) which show the comparison results of this 8 bit data to the X1 output buffer 54c. In this case, the data pattern which is read from the shift register for data patterns 71a is not inverted. Therefore, in the comparison results of the 8 bit data, a normal bit becomes “0” and a defective bit becomes “1”. In addition, a flag FLG becomes “1” when it includes a defective bit and “0” when it does not include a defective bit.
Next, the shift register 81a correlates only 8 bit data which includes a defective bit among the 8 bit data which is input from the comparator 61b, with the column addresses #0 to #7 and stores them (step S406). Then, the comparator 61b and the shift register 81a repeat the processes in the above stated steps S405 and S406 for 8 cycles (step S407). By the operations in these 8 cycles the shift register 81a correlated only the 8 bit data which includes a defective bit among the 8 bit data which is input form the comparator 61b, with the column addresses #0 to #7 and sequentially stores them. In addition, the comparator 61b sequentially outputs flags FLG which show comparison results of 8×8 bit data to the X1 output buffer 54c.
Next, the shift register 81a determines whether there are defective bits in the comparison process of 8×8 bit data over 8 cycles (step S408). If there are no defective bits (step S408: NO), the process shifts to step S412. In addition, if there are defective bits (step S408: YES), the process shifts to step S409.
In step S409, the shift register 81a further confirms whether there are defective bits in each stored 8 bit data. If there are no defective bits (step S409: NO), the process shifts to step S411. In addition, if there are defective bits (step S409: YES), the process shifts to step S410.
In step S410 the shift register 81a outputs by time division 8 bit data which includes defective bits as fail bit data FBD. Then, the shift register 81a repeats for 8 cycles the output process by time division of the fail bit data FBD in the above stated step S410 (step S411).
Next, the comparator 61b confirms whether the data comparison process has been performed up to the last column within the same page (step S412). If the comparison process has not been performed up to the last column (step S412: NO), the process returns to step S405 and the processes in steps S405 to S411 are repeated. In addition, if the comparison process has been performed up to the last column (step S412: YES), then the test operation is complete.
Next, a specific example of the comparison operation of 8 bit data and the output of fail bit data FBD by the above stated test operation will be explained by referring to
In the comparison process of the first 8×8 bit data in
Next, a test mode signal TEST 2 is input to the interface for testing 43 and the inversion and change determination circuit 102 from a control circuit and the inversion and change determination circuit 102 is initiated. In the inversion and change determination circuit 102 this page is determined as ROW defective based on a comparison result of the above stated first 8×8 bit data and the inversion and change circuit 101a is activated.
Next, the data which is to be compared is read from a page determined to be ROW defective and the comparator 61b reads a data pattern from the shift register for data patterns 71a and compares them. In this case, because the data which is read from the shift register for data patterns 71a is inverted and changed by the inversion and change circuit 101a, the comparator 61b reads the data as inverted and changed data. Therefore, in the comparison result of 8 bit data, ALL=0 and a flag FLG=0.
In this case the comparator 61b sequentially outputs flags FLG which show comparison results of 8×8 bit data to the X1 output buffer 54c and the shift register 81a according to a RE_comp clock signal input from the interface for testing 43. In addition, the shift register 81a correlates the addresses #0 to #7 and the flags FLG which are comparison results of 8×8 bit data input from the comparator 61b are latched. Then, the shift register 81a outputs by time division fail bit data FBD of the stored 8×8 bit data according to a clock cycle of fail bit read signal RE_fb input from the interface for testing 43.
In
The comparison result of 8×8 bit data of a page which is determined as ROW defective is output as an a data code with an 11 bit structure which includes fail bit data FBD with an 8 bit structure, as above. As a result, it is possible to reduce a comparison result output cycle.
In
The case where there are defective bits in the comparison process of the next 8×8 bit data is shown in
However, in this case also, because it is a comparison with an inverted 8 bit data pattern, the “0” in the diagram is a defective bit and “1” is a normal bit. In this case, only 3×8 bit data which includes normal bits among the 8×8 bit data is latched with addresses #0, #1 and #6 in the shift register 81a. Then, the shift register 81a outputs by time division the fail bit data FBD for each stored 8 bit data according to a clock cycle of a fail bit read signal RE_comp which is input from the interface for testing 43.
In
In
Specifically, as is shown in
Next, the seventh 8 bit data from the left among the 8×8 bit data in the diagram, that is, one normal bit is included in the 8 bit data stored in address #6 within the shift register 81a. 8 bit fail bit data FBD which includes data “1” (defective bit is “0”) which shows the location of this normal bit is output as a data code with an 11 bit structure. When these fail bit data FBD are output, a Dummy Bit is set at “1”.
The remaining output processes by time division of flags FLG which show comparison results (all are defective bits) of 8×8 bit data in the diagram, are performed in the same way as described above.
In the sixth embodiment, at the time of a test operation, it is possible to output in a short time a comparison result of data within a page which is determined in advance to have many defective bits. As a result, it is possible to reduce the test time required for outputting data. Furthermore, in the sixth embodiment, a comparison process of data was carried out assuming that “1” was a normal bit and “0” was a defective bit, however, even in the case where a normal bit is “0” and a defective bit is “1” the above stated data comparison process can be applied.
Furthermore, in the sixth embodiment, an example was shown where the shift register 81a outputs by time division fail bit data FBD of the stored 8×8 bit data according to a clock cycle of a fail bit read signal RE_fb which is input form the interface for testing 43. The shift register 81a stores a flag which shows the location where a defective bit occurs within the 8 bit data and detailed fail bit data FBD which shows the location where a defective bit occurs may also be output according to a fail bit read signal RE_fb. In addition, the shift register 81a stores only address data which shows the location where a defective bit occurs within the 8 bit data may also output only this stored address data as fail bit address data FBA according to a fail bit read signal RE_fb.
Number | Date | Country | Kind |
---|---|---|---|
2007-269795 | Oct 2007 | JP | national |