An apparatus and method for self-testing a DDR memory interface are disclosed. In one aspect, a built-in-self-test (BIST) memory interface circuit includes a signal multiplier for receiving a first clock signal from a tester and outputs a multiplied clock signal. A first multiplexer is used for selecting between a test mode and a normal operating mode and provides an output signal. A delay magnitude generator is coupled to the signal multiplier to receive the multiplied clock signal and provides a second clock signal and a phase control signal. A plurality of digitally controlled delay line blocks are used for each receiving the second clock signal and the phase control signal and outputting a phase shifted data strobe output signal in response to receiving an internal data strobe input signal. A second multiplexer selects one of the internal data strobe input signals and a third multiplexer selects the phase shifted data strobe output signal that corresponds to the selected internal data strobe input signal. A phase detector determines a phase difference between the selected internal data strobe input signal and the selected phase shifted data strobe output signal and outputs a phase difference value.
|
1. An integrated circuit comprising:
A. double data rate bi-directional data leads;
B. a bi-directional strobe lead;
C. a double data rate clock input lead;
D. a system clock input lead;
E. a built-in self test output lead;
F a processing unit;
G. phase locked loop circuitry connected to the system clock input lead and having a test clock output;
H. multiplexer circuitry having an input connected to the test clock output, an input connected to the double data rate clock input lead, and an output; and
G. memory controller circuitry coupled to the processing unit and connected to the data leads and the strobe lead, when receiving data signals on the data leads the memory controller circuitry receiving a data strobe signal on the strobe lead that is aligned with the edges of the data signals, when sending data signals on the data leads the memory controller circuitry sending a data strobe signal on the strobe lead that is aligned with the center of the data signals, the memory controller including:
i. a delay element having an input connected to the output of the multiplexer, an internal data strobe in output lead, and a phase shifted internal data strobe out output lead; and
ii. built in self test circuitry having inputs connected to the internal data strobe in output lead, and the phase shifted internal data strobe out output lead, and an output connected to the built-in self test output lead.
2. The integrated circuit of
3. The integrated circuit of
4. The integrated circuit of
5. The integrated circuit of
|
This application is a divisional of prior application Ser. No. 12/903,819, filed Oct. 13, 2010, currently pending;
Which was a divisional of prior application Ser. No. 11/772,256, filed Jul. 2, 2007, now U.S. Pat. No. 7,834,615, granted Nov. 16, 2010.
The present invention relates generally to computer memory devices. In particular, it relates to a DDR memory interface having built-in self testing capability and method for testing the same.
Since the advent of personal computers, there has been an ongoing need for improved system performance and reduced cost of system on chip (SoC) design and manufacture. A vital aspect of the personal computers is the use of Synchronous Dynamic Random Access Memory (SDRAM) device. The SDRAM operates at a substantially higher speed compared to other types of conventional memory devices such as SRAM, DRAM, and the like. SDRAM is also used in a host of electronic devices including cell phones, PDAs, and gaming systems.
In conventional memory devices, a processor writes a data into an output port and the data appears at the output pins. There is no indication that new data is available. Further, data transmission is triggered by a rising or falling edge of a system clock. More advanced memory devices such as SDRAMs require synchronization techniques which notify a memory controller when new data is at an input port of an SoC and subsequently notify the SDRAM when new data is at an output port of an SoC. SDRAM employing dual data rate (DDR) technique operates at twice the operational speed of the conventional memory devices as data transmission is triggered by both the rising and falling edges of the system clock.
In some cases, synchronization is achieved by using an additional control signal called a strobe signal which is triggered upon the occurrence of a data input or a data output. In such cases, upon the occurrence of a data input, the SDRAM generates a strobe pulse which accompanies the data input, and the memory controller must read the data before a next strobe pulse occurs. In the case of a data output, the memory controller generates a strobe pulse after it writes new data which is subsequently captured by the SDRAM.
The high operating speed of a DDR SDRAM device poses many challenges for testing the I/O interface of the DDR SDRAM at the device testing stage. Typically, the memory interface circuit residing in the memory controller is tested using an (external) automated test equipment (ATE). However, conventional ATE is not able to handle memory devices operating higher than single data rate (i.e. operating at either rising or falling edges but not at both edges) due to process variations within the DDR interface. To modify the ATE to cater for DDR memory devices is not cost effective. To capture data using the strobe signal, the strobe signal is delayed by a certain phase to satisfy the data setup time requirement. Therefore, it is important that the data and strobe signals are aligned properly with respect to such requirements. The applications that use DDR memory interfaces are designed to expect a specific tolerance or phase relationship in alignment between the data and the strobe signals. Verifying the tolerance or phase relationship is important for determining if the DDR memory interface will perform as expected. However, it is difficult to verify the phase relationship between the data and strobe signals at the DDR memory interface. In addition, routing sensitive signals along the DDR memory interface causes signal degradation problems as well as requiring additional pins on the DDR memory device to be connected to the ATE. Another disadvantage with existing ATE is that it is limited to testing a substantially fewer number of memory devices simultaneously.
Therefore, there exists a need for a DDR memory interface having a built-in self testing capability that is capable of testing high speed data transmission and measuring the phase difference between the data and strobe signals with a substantially high degree of accuracy.
An apparatus and method for self-testing a DDR memory interface are disclosed. In one aspect, a built-in-self-test (BIST) memory interface circuit comprises a signal multiplier for receiving a first clock signal from a tester and outputs a multiplied clock signal. A first multiplexer is used for selecting between a test mode and a normal operating mode and provides an output signal. A delay magnitude generator is coupled to the signal multiplier to receive the multiplied clock signal and provides a second clock signal and a phase control signal. A plurality of digitally controlled delay line blocks are used for each receiving the second clock signal and the phase control signal and a shifted data strobe output signal in response to receiving an internal data strobe input signal. A second multiplexer selects one of the internal data strobe input signals and a third multiplexer selects the phase shifted data strobe output signals corresponding to the selected internal data strobe input signal. A phase detector determines a phase difference between the selected internal data strobe input signal and the selected phase shifted data strobe output signal.
Embodiments of the invention are herein described, purely by way of example, with references made to the accompanying drawings, in which:
A built-in self testing DDR memory interface circuit and method for testing the same are disclosed. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of various embodiments of the present invention. It will be evident, however, to one skilled in the art that the various embodiments may be practiced with appropriate variations and equivalences from these specific details.
In conventional memory devices, data is transmitted in response to a rising or falling edge of a system clock. In DDR SDRAM devices, data is transmitted on both the rising and falling edges of a clock signal thereby making the data transfer window substantially half the window size of that used in conventional memory devices. This narrow data window along with routing delays, variations of operating temperatures, voltages and physical geometries pose considerable problems in the integrity of data transfer. Hence, DDR memory devices require data transfer to take place instantaneously with the occurrence of a valid data to reduce or avoid memory access and propagation delays. Therefore, a data strobe signal (hereinafter referred to as DQS) is used to accompany data signals. DQS is generated within a memory controller and is derived from the DDR memory device functional clock, which in some applications is provided by an external clock reference. DQS is a non-continuous-running strobe for clocking data on the data lines and is transmitted externally along with the data signals (hereinafter referred to as DQ) to ensure that
DQS tracks the data signal DQ while subject to the same temperature and voltage conditions. The (DDR) memory controller within a SoC device uses on-chip delay locked loops (DLLs) to output DQS relative to the corresponding DQ. The DQS toggles whenever DQ is present on the data lines.
The phase relationship between DQ and DQS is important at the DDR SDRAM interface. During a read operation, DQS is edge-aligned with DQ and is transmitted by the SDRAM. Whereas during a write operation DQS is center-aligned with DQ and is transmitted by the memory controller. The alignment of DQ and DQS is challenging due to the bidirectional nature of DQS and is a crucial component of testing the DDR memory interface.
Referring to
Now referring to
Now referring to
In an example embodiment, the memory controller 322 of
Now referring to
When data is read from a DDR SDRAM device, the data (DQ) and strobe (DQS) signals are edge aligned, meaning they occur simultaneously. When the data signal is received at the SDRAM/SoC interface the edge of the DQS has not been adjusted to line up with the DQ in a data-valid region. The edge alignment between DQ and DQS signals is performed by the memory controller (as shown in
MUX1 430 is controlled by a select line signal TST_EN which is used for switching the MUX1 430 mode of operation between a functional mode (i.e. normal memory operation mode) when DQS input is selected and a test mode during which the test mode input TST_MI is selected. When DQS is selected, the memory controller is ready to read data. During test mode, TST_MI is selected, and the output of the PLL 410 of the memory interface circuit 400 is selected.
Further, as depicted in
The DLL 420 and the DCDL blocks 440 function together to produce a particular phase of the data strobe signal, so as to delay the rising edge of the strobe signal. For example, if a 90 degree phase adjustment is required, the data strobe signal is placed right in the center of the data signal (as shown in
The DSI* (where *=0 to 4) signals are internal signal names for the data strobe signal DQS. These DSI* signals are delayed so that the edges of these signals aligns with a certain position in a data valid region of the data signals. For example, if a 90 degree phase adjustment is needed, the DSI* is aligned in the center position of the data valid region. Therefore the DSO* (where *=0 to 4) signal is the phase delayed strobe output corresponding to the internal data strobe input, that would in the application be fed back into the particular sub system on the SoC chip that is requesting data from the DDR interface.
The bit select multiplexers MUX2 450 and MUX3 460, as shown in
The phase detector 470 measures the time between the rising edges of DSI and DSO and converts the measurement into the 9-bit digital code, which is brought out to top-level pins for datalogging and pass/fail determination. The 9-bit digital code at the output of the phase detector 470 is a representation of the time between the rising edge that enters the SoC device and the delayed rising edge that is created through the DLL and DCDL network. It may be noted that the PLL, DLL and DCDL blocks are part of the chip/system functional design, while the multiplexers (430, 450 and 460) and the phase detector 470 are specific to the test mode implementation.
In an embodiment, the 9-bit digital code is brought out in parallel to external pins on the SoC (320 of
There is also a calibration path (not shown) that routes the PLL output directly to the phase detector circuit 470. Typically, the accuracy of the phase detector 470 is within +/−35 pico seconds depending on variations in PLL manufacturing process, operating voltage and temperature. Thus, the measured value of the PLL clock can be used to compute a calibration value to adjust the DSI/DSO phase measurements.
The above-described method and apparatus illustrates a BIST technique for testing a memory interface circuit at a SDRAM interface. This technique provides many advantages and is particularly useful in testing the phase relationship between the data and strobe signals, without the use of external instrumentation. The phase detector circuit provides a highly accurate phase measurement (about +/−35 ps). Further, by making this measurement internally, signal degradation problems resulting from routing these sensitive signals along the device loadboard are avoided. The simple external stimulus (free running clock) permits testing of the DDR interface with a low-cost test solution. Also, the internal BIST circuitry helps to reduce the number of device pins that are required to connect to the tester, further providing simultaneous testing of higher numbers of SoC devices.
Although the present invention is described with reference to specific example embodiments as shown in
Accordingly, the specification and drawings are to be regarded in an illustrative rather than restrictive sense, and the scope of the invention is defined by the following appended claims.
Jarboe, Jr., James Michael, Panigrahi, Sukanta Kishore, Agrawal, Vinay, Nayak, Neeraj P.
Patent | Priority | Assignee | Title |
11899959, | Oct 13 2020 | Samsung Electronics Co., Ltd. | Method of testing memory device, memory built-in self test (MBIST) circuit, and memory device for reducing test time |
8228084, | Sep 29 2009 | CAVIUM INTERNATIONAL; MARVELL ASIA PTE, LTD | Systems and methods for self-testing of integrated devices during production |
9257200, | Jul 27 2012 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Bit error testing and training in double data rate (DDR) memory system |
Patent | Priority | Assignee | Title |
7292500, | Jul 29 2005 | AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED | Reducing read data strobe latency in a memory system |
7509223, | Apr 21 2006 | Altera Corporation | Read-side calibration for data interface |
7590879, | Jan 24 2005 | Altera Corporation | Clock edge de-skew |
7657803, | Jul 11 2006 | Samsung Electronics Co., Ltd. | Memory controller with a self-test function, and method of testing a memory controller |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Apr 04 2011 | Texas Instruments Incorporated | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Mar 25 2015 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Mar 13 2019 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Mar 22 2023 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Oct 11 2014 | 4 years fee payment window open |
Apr 11 2015 | 6 months grace period start (w surcharge) |
Oct 11 2015 | patent expiry (for year 4) |
Oct 11 2017 | 2 years to revive unintentionally abandoned end. (for year 4) |
Oct 11 2018 | 8 years fee payment window open |
Apr 11 2019 | 6 months grace period start (w surcharge) |
Oct 11 2019 | patent expiry (for year 8) |
Oct 11 2021 | 2 years to revive unintentionally abandoned end. (for year 8) |
Oct 11 2022 | 12 years fee payment window open |
Apr 11 2023 | 6 months grace period start (w surcharge) |
Oct 11 2023 | patent expiry (for year 12) |
Oct 11 2025 | 2 years to revive unintentionally abandoned end. (for year 12) |