The present invention relates to a testing technique for a plurality of memories which are different in access data width and address decode logic and more specifically to the technique which can be effectively applied, for example, to a microcomputer which is provided with a plurality of on-chip memories or to a semiconductor integrated circuit such as so-called system LSI.
The Japanese Unexamined Patent Publication Nos. 2000-111618 and Heill (1999)-250698 are typical references describing the testing technique for a plurality of on-chip memories of a semiconductor integrated circuit of microcomputer and system LSI. These references also describe bit expansion of test data in the preceding stage of the on-chip memory.
Moreover, in the memory test, it is required to consider the influence of interference between memory cells, word line disturbance and bit line disturbance to ensure random access and therefore it is not practical to verify all cases because a large amount of testing time. Accordingly, as a method for effective verification, a method such as march pattern or walking pattern has been employed. In the verification method of this type, it is necessary to change the selecting direction of memory cells for physical allocation thereof depending on the predetermined rule wherein data is updated to the predetermined value while the memory cells of access unit are sequentially selected in the row direction for the memory cell array or while the memory cells are sequentially selected in the column direction.
However, in the conventional technique, it is not considered to convert in parallel the access data width to the inherent access data width for a plurality of memories of different access data width.
Moreover, in the prior art, it has been impossible, when a plurality of memories of different address decode logics are provided on the chip, to sequentially and uniformly update selection of memory cells in the column or raw direction with address increment because of difference of address decode logic even when address is inputted in common to such memories, in other words, because of difference of physical mapping of memory cells in the memory address space. Therefore, the memory test must have been performed with the method such as march pattern while the addresses are updated depending on the inherent address mapping of every on-chip memory. Accordingly, here rises a problem that test time of on-chip memory increases. Moreover, the similar problem occurs among a plurality of memories of different access data widths.
It is therefore an object of the present invention to provide a semiconductor integrated circuit device which can shorten the test time for a plurality of memories.
It is another object of the present invention to provide a testing method which can shorten the test time for a plurality of memories.
The aforementioned and other objects and novel features of the present invention will become apparent from the description of the present specification and the accompanying drawings of the present invention.
Typical inventions disclosed in the present specification of the present invention will be described briefly.
According to the means described above, even when the test data information is supplied in parallel to a plurality of memories of different access data widths, the bridge circuit is capable of converting the test data information to the inherent access data width of the corresponding memory. The test efficiency of on-chip memory can be improved in the point that the test data information can be supplied in parallel to a plurality of memories of different access data widths.
A semiconductor integrated circuit including a plurality of memories of different address decode logics and logic circuits for access control of the memories comprises the common test bus connected to the plural memories and a plurality of bridge circuits to convert the test address information from the common test bus to the inherent bit format of each memory and then to supply such test address information to the corresponding memory, thereby supplying in parallel the test address information to a plurality memories from the common test bus to enable the parallel tests.
According to the means described above, even when the test address information is supplied in parallel to plural memories of different address decode logics, the bridge circuit converts the test address information to the inherent bit format of the corresponding memory. The scan direction for respective memories for test address information can be unified to the particular direction depending on the inherent bit format. In this point, the memory test efficiency due to the march pattern for a plurality of on-chip memories can be improved.
It is also possible to employ both bridge circuit for the test data information and bridge circuit for test address information.
As a desirable profile of the present invention, the bridge circuit is recommended to include a comparing means for comparing the read information from the memory with the expected value information from the common bus and a latch means for latching defective information of memory depending on the comparison result from the comparing means. Thereby, it becomes possible to sequentially obtain in serial the parallel test result for plural memories from the latch means.
The latch means described above may be formed of an address latch means for latching faulty address and a fault flag means for latching comparison result of faults. Location of generated fault also becomes apparent.
The bridge circuit may include a shift register means for scan path which serially provides an output by inputting an output of the latch means. Thereby, result of parallel tests can be sequentially and serially obtained easily from the latch means.
According to the means described above, if an error due to mismatch of comparison is generated in any memory in the course of sequential progress of parallel tests accompanied by the address scan, while test data information is updated to a plurality of memories to update the test address information, an output of the gate means of the final stage changes. Therefore, continuation (Go)/stop (No-Go) of test can be determined while the parallel tests are performed to a plurality of memories by monitoring an output of the final stage.
According to this testing method, the test data information can be converted to the inherent access data width of the corresponding memory even when the test data information is supplied in parallel to a plurality of memories of different access data widths. Test efficiency for a plurality of memories of different access data widths can be improved in the point that the test data information can be supplied in parallel to a plurality of memories of different access data widths.
The testing method for testing in parallel a plurality of memories of different address decode logics via the common test bus comprises a process to supply the test address information to the common test bus, a process to input the test address information from the common test bus and to convert the test address information to the inherent bit format of the corresponding memory, a process to write the test data series to the corresponding memory using the converted test address information, a process to read the written test data from a plurality of memories, and a process to generate the memory error information by comparing the test data read from the memory with the expected value information in unit of memory.
According to the testing method described above, the test address information can be converted to the inherent bit format of the corresponding memory even when the test address information is supplied in parallel to a plurality of memories of different address decode logics. Accordingly, the address scan direction in respective memories for the test address information can be united to the particular direction depending on the inherent bit format. In this point, the memory efficiency due to the march pattern for a plurality of memories of different address decode logics can be improved.
A microcomputer 1 comprises an input/output circuit (IO) 2 in the periphery of semiconductor substrate and includes at its internal side a microprocessor (MPU) 3, a first logic circuit (LOG1) 4, a second logic circuit (LOG2) 5, a third logic circuit (LOG3) 6 and a memory block 7 which are connected in common with an internal bus 8. The microcomputer is further provided with a test controller 9 which is the typical element as a test circuit. The internal bus 8 propagates address, data and control signal. The logic circuits 3 to 5 are, although not particularly restricted, an error correction circuit as an accelerator of MPU3, an interface controller such as ATAPI and an encoding decode logic.
The single-port memories 11, 12, 13 are formed, although not particularly restricted, of SRAM (Static Random Access Memory), including, although not illustrated, a memory cell array where memory cells of static latch mode are allocated like a matrix, a word driver for driving the word lines connected to the selection terminals of memory cells, a row decoder for selecting the word lines to be driven with the word driver, a column switch circuit for selectively connecting the bit lines connected to the data input/output terminal of memory cells to the common data lines, a column decoder for generating a selection signal of the column switch circuit, a sense amplifier for amplifying storage information read to the common data lines from the memory cells, a data input/output buffer for inputting write data to the common data line and outputting the read data detected with the sense amplifier, an address buffer for receiving the address signal to be supplied to the raw decoder and column decoder, and a timing controller for controlling memory operations by receiving the memory selection signal and access control signals such as read and write signals.
The dual-port memories 14, 15 include, for every memory cell, the word lines and bit lines for one access port and the word lines and bit lines for the other access ports and also include the word line selection system and column line selection system in the single-port memory for every port.
The memories 11 to 15 are different respectively in the address decode logics. For example,
As illustrated in
The dual-port common test bus 33 is connected to the bridge circuits 24, 25 corresponding to the dual-port memories 14, 15 and when the dual-port memories 14, 15 are tested via the common test bus 31, it becomes possible to give the disturb information for the test object port via the dual-port common test bus 33 to the ports which are not the objects of test.
In
The input/output signals from the signal line 32 for transmission and reception of status (input/output signals from the terminals indicated by double □ in the figure) are as follows. br_async_in is a signal for asynchronously inputting an error signal. br_async_out is a signal for asynchronously transmitting an error signal. br_sync_in is an input signal for receiving a state of the bridge circuit in synchronization with the signal br_sck. br_sync_out is a transmitting signal for transmitting a state of the bridge circuit in synchronization with the signal br_sck.
The signals to be inputted or outputted via the memory-to-bridge bus 34 (input/output signals from the terminals indicated by □ with x in the figure) are as follows. A memory control signal, for example, m_resb is a reset signal, m_we is a write control signal, m_bs is a module selection signal, m_ck is a clock signal, m_d is a write data to the memory, m_a is an access address signal, and m_q is a read data from the memory.
The signals in the normal operations to be inputted or outputted via the internal bus 8 (input/output signals from the terminals indicated by □ in the figure) are as follows. A memory control signal, for example, resb is a reset signal, we is a write control signal, bs is a module selection signal, ck is a clock signal, d is an input data, a is an address signal, and q is a memory output data.
A multiplexer mux selects any one of the internal bus 8 or common test bus 31 to be connected to the bridge-to-memory bus 34 with a signal te. A selector sel selects the read data from the memory to be outputted to the internal bus 8 or to be supplied to a comparison circuit 38 for test described later with the signal te.
A data development circuit 35 develops a write data t_d as the test data information supplied in unit of four bits from the common test bus 31 into the number of parallel bits of the inherent data m_d, namely the access data width of the corresponding memory and then outputs this data to the subsequent stage. For example, a circuit for data-development to develop the test data information t_d of four bits to the data of 16 bits may be formed of an expanded route which outputs four parallel data of the test data information t_d by respectively expanding each bit of the test data information t_d to four bits. Accordingly, data development is performed in the mode that the test data information of four bits is repeated in the pattern of t_d. It is enough that the number of times of repetition for data development is determined to a fixed value depending on the access data width of the corresponding memory.
As address conversion circuit 36 converts the test address information t_a from the common test bus 31 to the inherent bit format of the corresponding memory and outputs this data to the subsequent stage. A kind of bit format to be converted, the bit format depending on the address scan direction may be designated with the signal br_sm. An overflow check circuit 37 detects whether the address converted with the address conversion circuit 36 has exceeded or not the address range of the corresponding memory. This overflow check circuit 37 inverts a module selection signal m_bs to the non-selection level when it is detected that the address has exceeded the address range.
During the memory test, the data m_d developed by the data development circuit 35 is written to the address m_a converted by the address conversion circuit 36. When the written data is read from the memory, it is inputted to the bridge circuit 21 (22, 23) as a return data m_q. The return data m_q is supplied to the comparison circuit 38 via the selector sel, while the expected value data br_ref is also supplied to the comparison circuit 38 via the development circuit 39 and both input data are judged whether these are matched or mismatched. The comparison output is inverted, when the data are mismatched, to the logical value “1” from the logical value “0”. In short, generation of test error is detected with such conversion. When generation of test error is detected, a test address information t_a for test is latched by an address latch circuit 40 as fault information, namely as an error information. As a result, a comparison result latch circuit 41 is set and an error flag EFLG which is an output of the comparison result latch circuit 41 is set to the logical level “1”. Respective latch operations are synchronized with the clock signal t_ck for test.
An external output of the fault information obtained is performed with a shift register 42 and a logical sum (OR) gate 43 forming a part of the scan path.
The logical sum gate 43 forms and outputs a logical sum of the comparison result of the comparison circuit 38 and the comparison result of the comparison circuit from the bridge circuit in the preceding stage. Accordingly, when the test address information is updated while the test data information is given to a plurality of memories 11 to 15 and when an mismatch error is detected by the comparison circuit 38 in any of the memories while the parallel tests including the address scan are sequentially performed, such change is reflected on an output signal br_async_out of the bridge circuit 25 in the final stage. By monitoring the output in the final stage via the test controller 9 by means of external tester, the test can be judged for continuation or suspension (Go/No go) while the parallel tests are being performed for a plurality of memories.
The shift register 42 is formed of a first FF chain 42A and a second FF chain 42B of the serial connection in which the flop-flop circuits are respectively allocated in serial. The second FF chain 42B latches in parallel the address information latched by the address latch circuit 40, while the first FF chain 42A latches the error flag EFLG. A fault information latched by the shift register 42 is supplied to the test controller 9 from the signal line 32 for transmission and reception of status through the bridge circuits in synchronization with the scan clock br_sck. It is enough that the scan path output operation of this fault information is performed after the test controller 9 has stopped continuation of test when generation of error is generated, for example, with the output signal br_async_out of the bridge circuit 25 of the final stage. The timing in which the latch data is loaded to the shift register 42 from the address latch circuit 40 and comparison result latch circuit 41 is synchronized with the first change of pulse of the scan clock br_sck. Thereafter, the shift register 42 does not fetch outputs of the latch circuits 40, 41 until the signal br_resb is reset and performs only the data shift operation in synchronization with the change of scan clock br_sck.
In the scan path output operation, a tester (not illustrated) to receive an output of the test controller 9 can identify the memory which generates an error from the scan clock br_sck count value when the logical value “1” is detected by monitoring the error flag EFLG from the signal br_async_out while it is counting the number of scan clocks br_sck. It is because the number of shift stages of the shift register 42 in the bridge circuits 21 to 25 is already known. Moreover, this tester can identify the memory address in relation to the error generation by obtaining the address information immediately before the error flag EFLG of the logical value “1” from the signal br_sync_out.
The input information from the common test bus 31 used for memory test (input signal from the terminals indicated by ▪ illustrated in the figure) is identical to that of
The signals inputted or outputted via the memory-to-bridge bus 34 (input/output signals from the terminals indicated by □ with x in the figure) are as follows. m_resb is a reset signal. A memory control signal corresponding to the first access port, for example, m_wep1 is a write control signal, m_bsp1 is a module selection signal. Moreover, corresponding to the first port, m_ckp1 is a clock signal, m_dp1 is data, m_ap1 is an address, and m_qp1 is read data from the memory. A memory control signal corresponding to the second access port, for example, m_wep2 is a write control signal, m_bsp2 is a module selection signal. Moreover, corresponding to the second access port, m_ckp2 is a clock signal, m_dp2 is data, m_ap2 is an address, and m_qp2 is read data from the memory.
Signals in the normal operations inputted or outputted via the internal bus 8 (input/output signals from the terminals indicated by □ in the figure) are as follows. resb is a reset signal. A memory control signal corresponding to the first access port, for example, wep1 is a write control signal, and bsp1 is a module selection signal. Moreover, corresponding to the first access port, ckp1 is a clock signal, dp1 is write data, ap1 is an address signal, and qp1 is read data. A memory control signal corresponding to the second access port, for example, wep2 is a write control signal, and bsp2 is a module selection signal. Moreover, corresponding to the second access port, ckp2 is a clock signal, dp2 is write data, ap2 is an address signal, and qp2 is read data.
A port selection circuit 50 selects, depending on the signal br_chport, the first access port or second access port to connect to the common test bus 31 and the first access port or second access port to connect to the dual-port common test bus 33. The multiplexer mux selects, with the signal te, whether the access port is used for test or ordinary operation. The selector sel selects, with the signal te, whether the read data from the memory is outputted to the internal bus 8 or is supplied to the comparison circuit 38 for test. The port selection circuit 51 selects, with the signal te, that anyone of the data m_qp1 and m_p2 is supplied to the comparison circuit 38.
The data development circuit 52 develops the write data t_d as the test data information supplied in the unit of 4 bits from the common test bus 31 to the number of parallel bits, namely the access data width of the inherent data m_dp1, m_dp2 of the corresponding memory. Moreover, the data development circuit 52 generates all-bit inverted data of the data t_d developed in response to the logical value “1” of td_d. The developed test data information is supplied to one access port selected in the port selection circuit with the signal br_chport and the inverted data is supplied to the other access port.
The address conversion circuit 53 converts the test address information t_a from the common test bus 31 to the inherent bit format of the corresponding memory and then outputs the converted data to the subsequent stage. A kind of bit format to be converted, namely the bit format corresponding to the address scan direction may be designated with the signal br_sm. Moreover, the address conversion circuit 53 generates an address of adjacent memory cell by inverting the least significant bit of the address t_a converted in response to the logical level “1” of the signal td_a. The test address information of which bit format is converted is supplied to one access port selected in the port selection circuit with the signal br_chport and the least significant bit inverted address information is then supplied to the other access port.
When the memory test is performed via one access port with the data development and address conversion function, the disturb information can be given from the other access port by designating the adjacent memory cells of the test object memory cells and thereby the port-to-port interference in the dual-port memory can be tested.
Even in the bridge circuit for dual-port memory of
According to the microcomputer 1 described above, following effects may be attained.
In this case, the latch circuit 41 of the error flag EFLG of scan path is allocated on the upstream side of the scan path upper than the error address latch circuit 40. Therefore, when the scan clocks are counted up until the error flag EFLG appears, the error generating memory can be identified based on such counted value and the error generating address in the error generating memory can also be identified with the just preceding address information. As described above, a fault generating location can be identified easily.
The present invention has been described based on the embodiment thereof but the present invention is never limited thereto and naturally allows various changes or modifications within the scope not departing from the claims thereof.
For example, the number of memories included in the memory block, storage capacity of memory, data access width and information storage system or the like may be changed as required. The memory is never limited to SRAM and a DRAM or a non-volatile memory may also be used. A circuit block other than the memory is not limited to an MPU illustrated in
The typical inventions disclosed in the present invention will be described as follows.
Namely, the bridge circuit can convert the test data information to the inherent access data width of the corresponding memory by also supplying in parallel the test data information to a plurality of memories of different access data widths. Moreover, the bridge circuit can convert the test address information to the inherent bit format of the corresponding memory by also supplying in parallel the test address information to a plurality of memories of different address decode logics. Therefore, the memory test efficiency due to the match pattern for a plurality of on-chip memories can also be improved in the point that the test data information can be supplied in parallel to a plurality of memories of different access data widths and in the point that the address scan direction in respective memories for the test address information can be uniformed to a particular direction according to the inherent bit format.
Number | Date | Country | Kind |
---|---|---|---|
2002-155107 | May 2002 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
4484303 | Provanzano et al. | Nov 1984 | A |
6336088 | Bauman et al. | Jan 2002 | B1 |
6587979 | Kraus et al. | Jul 2003 | B1 |
Number | Date | Country |
---|---|---|
11-250698 | Mar 1998 | JP |
2000-111618 | Sep 1998 | JP |
Number | Date | Country | |
---|---|---|---|
20030222283 A1 | Dec 2003 | US |