Embodiments of the disclosure relate generally to integrated circuit testing. More specifically, the disclosure provides a method and system for testing of memory.
Level-sensitive cells have been used for hold time padding when performing race-free, full process, voltage, and temperature (PVT) testing of memory. However, such testing of memory is not applicable to all memories or technologies. For example, a level-sensitive cell is generally designed for use with a specific memory and is not included in most technology libraries. Also, many memories require a dedicated pin (e.g., LSMODE) for testing that is held low during a functional mode and asserted high during voltage testing to invert the internal clock of the memory to provide interface timing (e.g., hold time). Further, the base (functional) clock (BCLK) of many built-in self-test (BIST) systems cannot be inverted, which precludes the use of falling edge clock D-type flip flops (DFFN) in the test logic path.
Aspects of the disclosure provide a level-sensitive register unit, including: a data latch for receiving data; a flip-flop including a first latch and a second latch, wherein an output of the data latch is coupled to an input of the first latch of the flip-flop; a first clock signal coupled to the data latch; and a second clock signal, wherein the second latch of the flip-flop is clocked by the second clock signal, and wherein the first latch of the flip-flop is clocked by an inverse of the second clock signal.
Another aspect of the disclosure is directed to a memory built-in self-test system, including: a memory; and a first level-sensitive register unit for writing data to the memory, the first level-sensitive memory unit including: a data latch for receiving data; a flip-flop including a first latch and a second latch, wherein an output of the data latch is coupled to an input of the first latch of the flip-flop; a clock signal coupled to the data latch; and a second clock signal, wherein the second latch of the flip-flop is clocked by the second clock signal, and wherein the first latch of the flip-flop is clocked by an inverse of the second clock signal.
A further aspect of the disclosure is directed to a method, the method including: clocking a level-sensitive register unit coupled to a memory with a first clock signal and a second clock signal, the level-sensitive register unit including a data latch coupled to a flip-flop including a first latch and a second latch, wherein the data latch is clocked by the first clock signal, the first latch of the flip-flop is clocked by an inverse of the second clock signal, and the second latch of the flip-flop is clocked by the second clock signal; and clocking the memory with the second clock signal, wherein a frequency of the first clock signal is 2× a frequency of the second clock signal.
These and other features of this disclosure will be more readily understood from the following detailed description of the various aspects of the disclosure taken in conjunction with the accompanying drawings that depict various embodiments of the disclosure.
It is noted that the drawings of the disclosure are not necessarily to scale. The drawings are intended to depict only typical aspects of the disclosure, and therefore should not be considered as limiting the scope of the disclosure. In the drawings, like numbering represents like elements between the drawings.
In the following description, reference is made to the accompanying drawings that form a part thereof, and in which is shown by way of illustration specific exemplary embodiments in which the present teachings may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the present teachings, and it is to be understood that other embodiments may be used and that changes may be made without departing from the scope of the present teachings. The following description is, therefore, merely illustrative.
A level-sensitive register unit 10 for test logic in accordance with embodiments of the disclosure is depicted in
When the level-sensitive register unit 10 is in a level-sensitive mode, latch L0 is clocked by the clock signal CCLK and holds data before a rising edge of BLCK reaches DFF 12. In a normal edge mode, the clock signal CCLK is tied to high and latch L0 is transparent. In this case, the level-sensitive register unit 10 operates as a D-type flip-flop.
In
According to embodiments of the disclosure, referring again to
As discussed above, the base (functional) clock (BCLK) of many BIST systems cannot be inverted, which precludes the use of falling edge clock D-type flip flops (DFFN) in conventional test logic paths. This issue is depicted, for example, in
A memory built-in self-test (MBIST) 40 for testing a memory 42 (e.g., a static random access memory (SRAM)) according to embodiments of the disclosure is depicted in
The MBIST 40 generally includes a controller and a test pattern generator for generating the address, data, and control values to create each test pattern that is to be applied to the memory 42 being tested. The MBIST 40 also includes a comparator for comparing the data read out of the memory 42 with expected data (e.g., the data generated by the test pattern generator). The written (expected) data and read data are compared and the results are reported (e.g., by a simple pass/fail status), or in more complex designs, more elaborate logic is implemented for diagnosing, debugging, and the like.
In
According to embodiments of the disclosure, as depicted in
As depicted in
Latch L0 in the level-sensitive register units 66A and 66B is clocked by a clock signal CCLK, which is used for hold time padding. In the level-sensitive register unit 66A, latch L2 is clocked by the inverse clock signal ˜BCLK and latch L1 is clocked by the clock signal BCLK. In the level-sensitive register unit 66B, latch L2 is clocked by the clock signal BCLK and latch L1 is clocked by the clock signal ˜BCLK.
In
At time T4, at the next rising edge of the clock signal BCLK, the data at the data input D of latch L1 of DFF 64 of the level-sensitive register unit 66B is passed to the output Q of latch L2 of DFF 64. The data is held at the output Q of latch L2 of DFF 64 until the next rising edge of the clock signal CCLK (time T5). As indicated in
According to embodiments of the disclosure, a specific level-sensitive cell is no longer required when testing a memory. Rather, a level-sensitive register unit may be provided using a conventional latch and DFF. In addition, the memory under test no longer requires a dedicated pin (e.g., LSMODE) for testing that is held low during a functional mode and asserted high during voltage testing to invert the internal clock of the memory to provide interface timing. Further, the limitation that the clock signal BCLK cannot be inverted at any node during memory testing is eliminated.
Aspects of the present disclosure are described above with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general-purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
As used herein, the term “configured,” “configured to” and/or “configured for” can refer to specific-purpose patterns of the component so described. For example, a system or device configured to perform a function can include a computer system or computing device programmed or otherwise modified to perform that specific function. In other cases, program code stored on a computer-readable medium (e.g., storage medium), can be configured to cause at least one computing device to perform functions when that program code is executed on that computing device. In these cases, the arrangement of the program code triggers specific functions in the computing device upon execution. In other examples, a device configured to interact with and/or act upon other components can be specifically shaped and/or designed to effectively interact with and/or act upon those components. In some such circumstances, the device is configured to interact with another component because at least a portion of its shape complements at least a portion of the shape of that other component. In some circumstances, at least a portion of the device is sized to interact with at least a portion of that other component. The physical relationship (e.g., complementary, size-coincident, etc.) between the device and the other component can aid in performing a function, for example, displacement of one or more of the device or other components, engagement of one or more of the device or other components, etc.
The descriptions of the various embodiments of the present disclosure have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.