A clock applying circuit for a synchronous memory is comprised of a clock input for receiving a clock input signal, apparatus connected to the synchronous memory for receiving a driving clock signal, and a tapped delay line for receiving the clock input signal and for delivering the clock driving signal to the synchronous memory in synchronism with but delayed from the clock input signal, the delay being a small fraction of the clock period of the clock input signal.
|
9. A method of enabling synchronous memory data output comprising:
delaying a clock input signal in an adjustable delay line to generate a data output driving clock signal; and enabling output data with the driving clock signal, the data being output to an output terminal at the same time as or a minimum time following an edge of the clock input signal.
17. A synchronous dynamic random access memory comprising:
means for delaying a clock input signal in an adjustable delay line of a delay locked loop to generate a data output driving clock signal; and means for enabling output data with the driving clock signal, the data being output to an output terminal at the same time as or a minimum time following an edge of the clock input signal.
16. A method of enabling synchronous random access memory data output comprising:
delaying a clock input signal in an adjustable delay line of a delay locked loop to generate a data output driving clock signal; and enabling output data with the driving clock signal, the data being output to an output terminal at the same time as or a minimum time following an edge of the clock input signal.
1. A synchronous memory comprising:
a clock input signal; an adjustable delay line for generating a data output driving clock signal from the clock input signal; and a data output buffer enabled by the driving clock signal for outputting data to an output terminal, the data being output to the output terminal at the same time as or a minimum time following an edge of the clock input signal.
8. A synchronous dynamic random access memory comprising:
a clock input signal; a delay locked loop comprising an adjustable delay line for generating a data output driving clock signal from the clock input signal; and a data output buffer enabled by the driving clock signal for outputting data to an output terminal, the data being output to the output terminal at the same time as or a minimum time following an edge of the clock input signal.
2. synchronous memory as claimed in
3. synchronous memory as claimed in
4. synchronous memory as claimed in
6. synchronous memory as claimed in
7. synchronous memory as claimed in
10. A method of enabling synchronous memory data output as claimed in
11. A method of enabling synchronous memory data output as claimed in
12. A method of enabling synchronous memory data output as claimed in
13. A method of enabling synchronous memory data output as claimed in
14. A method of enabling synchronous memory data output as claimed in
15. A method of enabling synchronous memory data output as claimed in
|
This application is a Continuation of Application Ser. No. 10/279,217, filed Oct. 23, 2002, which is a Continuation of Application Ser. No. 09/977,088, filed Oct. 12, 2001, which is a Continuation of Application Ser. No. 09/761,274, filed Jan. 16, 2001, now U.S. Pat. No. 6,314,052, which is a Continuation of Application Ser. No. 09/392,088 filed Sep. 8, 1999, now U.S. Pat. No. 6,205,083 which is a Continuation of Application Ser. No. 08/996,095 filed Dec. 22, 1997, now U.S. Pat. No. 6,067,272, which is a Continuation of Application Ser. No. 08/319,042, filed Oct. 6, 1994, now U.S. Pat. No. 5,796,673. The entire teachings of the above applications are incorporated herein by reference.
This invention relates to the field of semiconductor memories, and in particular to a circuit for applying a clock to a synchronous memory such as a synchronous dynamic random access memory (SDRAM).
An SDRAM, shown in block diagram in
A signal at the output of the memory array and support circuitry 3 is applied to output buffers, represented by output buffer 8, which is enabled by the clock signal to drive data onto data terminals 10 of the SDRAM. However, due to the delays caused by the internal buffering and the interconnect wire on the integrated circuit chip that distributes the clock signal, the clock signal arrives at the enable terminal of the buffers delayed from the clock input signal. This delayed clock signal is illustrated in
Assuming that the system is responsive to the rising edge of the clock signal, the delay between the rising edges is shown in
Prior to the present invention, there were either of two solutions used to deal with this problem: (a) making the clock buffer circuitry between the clock input terminal 1 and the output buffer circuit enable terminal as fast as possible, and (b) using a phase locked loop (PLL) to drive the enable terminal of the output buffer.
Implementing the first solution results in a limit to the operating frequency of the part. There will always be a limit to the operating frequency of the part, because there will always be significant delay associated with the clock buffer and distribution circuitry and delays introduced by parasitic resistance and capacitance of the interconnection conductors used to distribute the buffered clock signal to the output buffers, which is evident from FIG. 1. Thus as shown in
The second solution provides considerable improvement over the first. An on chip oscillator is used in a phase locked loop (PLL) which is synchronized with the input clock signal. The internal clock signal can be either multiplied in frequency or adjusted to remove internal clock skew as much as possible.
A system implementing the second solution is shown in
Thus the already buffered (and delayed) clock signal is applied to the PLL and is compared with the input clock signal. Since the operation of the PLL is to synchronize the two signals, the clock signal to be distributed to the enable inputs of the output buffers, represented by the timing diagram ICLK in
However it has been found that the PLL solution also suffers from problems. It is complex, requiring an on-chip oscillator with feedback control of the frequency depending on the monitored status of the on-chip oscillator relative to the input clock. It requires significant stand-by power due to its extra circuitry, and it requires considerable start-up time for the on-chip oscillator to synchronize and lock to the input clock frequency. It also requires use of an analog oscillator in a digital circuit, which requires significantly different and complex fabrication techniques.
The present invention minimizes the elapsed time between a clock edge that is input to a synchronous memory such as an SDRAM and the time at which the same clock edge eventually triggers the output buffer of the SDRAM to drive valid data onto the output terminals of the SDRAM. The present invention utilizes a delay locked loop (DLL) instead of the phase locked loop used in the second solution described above. The DLL allows higher clock frequency operation while requiring less standby current and start-up time than the system that uses the PLL. No oscillator is required as is required using the PLL, and the entire system can be fabricated using digital integrated circuit technology, rather than a mixture of analog and digital technology.
In accordance with an embodiment of the invention, a clock applying circuit for a synchronous memory is comprised of a clock input for receiving a clock input signal, apparatus connected to the synchronous memory for receiving a driving clock signal, and a tapped delay line for receiving the clock input signal and for delivering the clock driving signal to the synchronous memory in synchronism with but delayed from the clock input signal, the delay being a small fraction of the clock period of the clock input signal. The fraction can be negligibly small.
In accordance with another embodiment, a clock applying circuit is comprised of a synchronous dynamic random access memory (SDRAM) comprised of a memory array and an output buffer connected to the memory array, the memory array having a clock input signal terminal and the output buffer having an enable terminal for receiving a driving clock signal, a clock input for receiving a clock input signal, a tapped delay line comprised of a series of delay elements and having an input, apparatus for applying the clock input signal to the clock input signal terminal and to the input of the tapped delay line, apparatus for receiving output signals of plural ones of the delay elements and for providing one of the output signals of the delay elements as the driving clock signal, apparatus for applying the driving clock signal to the enable terminal of the output buffer, and apparatus for selecting said one of the output signals having a predetermined one of the rising and falling edge time which follows a corresponding rising or falling edge of the clock input signal by a clock skew delay time of the SDRAM between said clock input signal terminal of the memory array and the output buffer.
A better understanding of the invention will be obtained by reading the description of the invention below, with reference to the following drawings, in which:
Turning to
A delay comparator 31 has one input that receives the input clock signal, and another input that receives the driving clock signal. The comparator 31 outputs a control signal which has a value that depends on the differential between the input clock signal and the driving clock signal. That control signal is applied to the control inputs of multiplexer 27, and determines which of the inputs to it are passed through it to output 29 and forms the driving clock signal. The value of the control signal is such that the delay between the input clock signal and the driving clock signal is minimized in the positive sense (i.e. the leading edge of the driving clock signal will always be at the same time or later than the leading edge of the input clock signal).
In this manner the output buffer of the memory will be enabled either no or a minimum time following the input clock.
In another embodiment, the feedback signal (i.e. the driving clock signal) is delayed by a delay circuit 33, referred to herein as a delay model, which use similar elements as the real circuit path taken by the input clock signal, including buffers, logic gates, interconnect conductors, etc. The result is a signal for comparison by the delay comparator 31 which is delayed by a value which tracks the real circuit's performance as operating conditions vary. It's use in a memory can allow the memory to operate at high speeds and maintains its capability as operating conditions such as temperature vary.
While the system requires some time on start-up to adapt itself to a stable operating condition, the start-up modes on most synchronous memories should be sufficient for the output buffer to receive a properly adjusted clock signal. Due to the nature of the delay locked loop, there will be a minimum frequency below which the internal function of the clock will be uncertain. If such frequencies are contemplated, external control circuitry can be used to disable the delay locked loop, such as by using a register bit which when set enables the delay locked loop and when reset disables the delay locked loop. Then the chin operates with the digital locked loop disabled, the start-up time and minimum frequency requirements will be ignored.
If the delay locked loop derived clock is used only for the output buffer, any chip mode registers can be set and data can be written to memory before the delay locked loop has adapted. If the chip enters a power down mode while retaining supply voltage levels, the last tap position can be preserved so that normal operation can be quickly re-enabled.
During a standby state of the memory, the delay locked loop can be disabled, and the delay chain settings can be maintained, as long as the power is applied, allowing the part to enter a low power mode. Upon exit from the standby state into an active state, the system will enter a faster lock since the delay chain settings are maintained.
The delay locked loop can be disabled and the regular buffered version of the system can be used as in the prior art, enabling the output buffer with the prior art form of delayed clock signal, which can allow the system to be tested or operated using a low frequency clock.
The driving clock signal can be used as the clock for the entire memory system, it can be used for only parts of the memory system and the input clock signal used for others, or can be used only to enable the output buffer with the input clock signal used for the remainder of the memory system.
The present invention is not limited for use in conjunction with an SDRAM which was used as an example, but can be used in conjunction with other synchronous memories such as synchronous static random access memories, video random access memories, synchronous graphics random access memories, synchronous read only memories. In addition, other designs of the delay locked loop may be used than the one described herein.
A person understanding this invention may now conceive of alternative structures and embodiments or variations of the above. All of those which fall within the scope of the claims appended hereto are considered to be part of the present invention.
Gillingham, Peter B., Foss, Richard C., Allan, Graham
Patent | Priority | Assignee | Title |
10013371, | Jun 24 2005 | GOOGLE LLC | Configurable memory circuit system and method |
7196554, | Jul 07 2003 | Polaris Innovations Limited | Integrated clock supply chip for a memory module, memory module comprising the integrated clock supply chip, and method for operating the memory module under test conditions |
7515453, | Jun 24 2005 | GOOGLE LLC | Integrated memory core and memory interface circuit |
7535749, | Apr 06 1990 | Mosaid Technologies, Inc. | Dynamic memory word line driver scheme |
7580312, | Jul 31 2006 | GOOGLE LLC | Power saving system and method for use with a plurality of memory circuits |
7581127, | Jul 31 2006 | GOOGLE LLC | Interface circuit system and method for performing power saving operations during a command-related latency |
7590796, | Jul 31 2006 | GOOGLE LLC | System and method for power management in memory systems |
7599205, | Sep 02 2005 | GOOGLE LLC | Methods and apparatus of stacking DRAMs |
7599246, | Oct 06 1994 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Delay locked loop implementation in a synchronous dynamic random access memory |
7609567, | Jun 24 2005 | GOOGLE LLC | System and method for simulating an aspect of a memory circuit |
7730338, | Jul 31 2006 | GOOGLE LLC | Interface circuit system and method for autonomously performing power management operations in conjunction with a plurality of memory circuits |
7761724, | Jul 31 2006 | GOOGLE LLC | Interface circuit system and method for performing power management operations in conjunction with only a portion of a memory circuit |
8019589, | Jul 31 2006 | GOOGLE LLC | Memory apparatus operable to perform a power-saving operation |
8023314, | Apr 05 1991 | Mosaid Technologies Incorporated | Dynamic memory word line driver scheme |
8041881, | Jul 31 2006 | GOOGLE LLC | Memory device with emulated characteristics |
8055833, | Oct 05 2006 | GOOGLE LLC | System and method for increasing capacity, performance, and flexibility of flash storage |
8060774, | Jun 24 2005 | GOOGLE LLC | Memory systems and memory modules |
8077535, | Jul 31 2006 | GOOGLE LLC | Memory refresh apparatus and method |
8080874, | Sep 14 2007 | GOOGLE LLC | Providing additional space between an integrated circuit and a circuit board for positioning a component therebetween |
8081474, | Dec 18 2007 | GOOGLE LLC | Embossed heat spreader |
8089795, | Feb 09 2006 | GOOGLE LLC | Memory module with memory stack and interface with enhanced capabilities |
8090897, | Jul 31 2006 | GOOGLE LLC | System and method for simulating an aspect of a memory circuit |
8111566, | Nov 16 2007 | GOOGLE LLC | Optimal channel design for memory devices for providing a high-speed memory interface |
8112266, | Jul 31 2006 | GOOGLE LLC | Apparatus for simulating an aspect of a memory circuit |
8130560, | Nov 13 2006 | GOOGLE LLC | Multi-rank partial width memory modules |
8154935, | Jul 31 2006 | GOOGLE LLC | Delaying a signal communicated from a system to at least one of a plurality of memory circuits |
8169233, | Jun 09 2009 | GOOGLE LLC | Programming of DIMM termination resistance values |
8209479, | Jul 18 2007 | GOOGLE LLC | Memory circuit system and method |
8244971, | Jul 31 2006 | GOOGLE LLC | Memory circuit system and method |
8280714, | Jul 31 2006 | GOOGLE LLC | Memory circuit simulation system and method with refresh capabilities |
8327104, | Jul 31 2006 | GOOGLE LLC | Adjusting the timing of signals associated with a memory system |
8335894, | Jul 25 2008 | GOOGLE LLC | Configurable memory system with interface circuit |
8340953, | Jul 31 2006 | GOOGLE LLC | Memory circuit simulation with power saving capabilities |
8359187, | Jun 24 2005 | GOOGLE LLC | Simulating a different number of memory circuit devices |
8369182, | Oct 06 1994 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Delay locked loop implementation in a synchronous dynamic random access memory |
8370566, | Oct 05 2006 | GOOGLE LLC | System and method for increasing capacity, performance, and flexibility of flash storage |
8386722, | Jun 23 2008 | GOOGLE LLC | Stacked DIMM memory interface |
8386833, | Jun 24 2005 | GOOGLE LLC | Memory systems and memory modules |
8397013, | Oct 05 2006 | GOOGLE LLC | Hybrid memory module |
8438328, | Feb 21 2008 | GOOGLE LLC | Emulation of abstracted DIMMs using abstracted DRAMs |
8446781, | Nov 13 2006 | GOOGLE LLC | Multi-rank partial width memory modules |
8566516, | Jul 31 2006 | GOOGLE LLC | Refresh management of memory modules |
8566556, | Feb 09 2006 | GOOGLE LLC | Memory module with memory stack and interface with enhanced capabilities |
8582339, | Sep 01 2005 | GOOGLE LLC | System including memory stacks |
8588017, | Oct 20 2010 | SAMSUNG ELECTRONICS CO , LTD | Memory circuits, systems, and modules for performing DRAM refresh operations and methods of operating the same |
8595419, | Jul 31 2006 | GOOGLE LLC | Memory apparatus operable to perform a power-saving operation |
8601204, | Jul 31 2006 | GOOGLE LLC | Simulating a refresh operation latency |
8615679, | Jun 24 2005 | GOOGLE LLC | Memory modules with reliability and serviceability functions |
8619452, | Sep 02 2005 | GOOGLE LLC | Methods and apparatus of stacking DRAMs |
8631193, | Feb 21 2008 | GOOGLE LLC | Emulation of abstracted DIMMS using abstracted DRAMS |
8631220, | Jul 31 2006 | GOOGLE LLC | Adjusting the timing of signals associated with a memory system |
8638638, | Oct 06 1994 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Delay locked loop implementation in a synchronous dynamic random access memory |
8671244, | Jul 31 2006 | GOOGLE LLC | Simulating a memory standard |
8675429, | Nov 16 2007 | GOOGLE LLC | Optimal channel design for memory devices for providing a high-speed memory interface |
8705240, | Dec 18 2007 | GOOGLE LLC | Embossed heat spreader |
8730670, | Dec 18 2007 | GOOGLE LLC | Embossed heat spreader |
8745321, | Jul 31 2006 | GOOGLE LLC | Simulating a memory standard |
8751732, | Oct 05 2006 | GOOGLE LLC | System and method for increasing capacity, performance, and flexibility of flash storage |
8760936, | Nov 13 2006 | GOOGLE LLC | Multi-rank partial width memory modules |
8762675, | Jun 23 2008 | GOOGLE LLC | Memory system for synchronous data transmission |
8796830, | Sep 01 2006 | GOOGLE LLC | Stackable low-profile lead frame package |
8797779, | Feb 09 2006 | GOOGLE LLC | Memory module with memory stack and interface with enhanced capabilites |
8811065, | Sep 02 2005 | GOOGLE LLC | Performing error detection on DRAMs |
8819356, | Jul 25 2008 | GOOGLE LLC | Configurable multirank memory system with interface circuit |
8868829, | Jul 31 2006 | GOOGLE LLC | Memory circuit system and method |
8972673, | Jul 31 2006 | GOOGLE LLC | Power management of memory circuits by virtual memory simulation |
8977806, | Oct 15 2006 | GOOGLE LLC | Hybrid memory module |
9047976, | Jul 31 2006 | GOOGLE LLC | Combined signal delay and power saving for use with a plurality of memory circuits |
9171585, | Jun 24 2005 | GOOGLE LLC | Configurable memory circuit system and method |
9507739, | Jun 24 2005 | GOOGLE LLC | Configurable memory circuit system and method |
9542352, | Feb 09 2006 | GOOGLE LLC | System and method for reducing command scheduling constraints of memory circuits |
9542353, | Feb 09 2006 | GOOGLE LLC | System and method for reducing command scheduling constraints of memory circuits |
9632929, | Feb 09 2006 | GOOGLE LLC | Translating an address associated with a command communicated between a system and memory circuits |
9727458, | Feb 09 2006 | GOOGLE LLC | Translating an address associated with a command communicated between a system and memory circuits |
Patent | Priority | Assignee | Title |
4754164, | Jun 30 1984 | UNISYS CORPORATION, DETROIT, MICHIGAN, A CORP OF DETROIT | Method for providing automatic clock de-skewing on a circuit board |
5223755, | Dec 26 1990 | XEROX CORPORATION, A CORP OF NEW YORK | Extended frequency range variable delay locked loop for clock synchronization |
5287319, | May 23 1990 | Sharp Kabushiki Kaisha | Nonvolatile semiconductor memory device |
5311483, | Nov 20 1990 | OKI SEMICONDUCTOR CO , LTD | Synchronous type semiconductor memory |
5319755, | Apr 18 1990 | Rambus, Inc. | Integrated circuit I/O using high performance bus interface |
5440515, | Mar 08 1994 | Motorola Inc. | Delay locked loop for detecting the phase difference of two signals having different frequencies |
5544203, | Feb 17 1993 | Texas Instruments Incorporated | Fine resolution digital delay line with coarse and fine adjustment stages |
5553276, | Jun 30 1993 | International Business Machines Corporation | Self-time processor with dynamic clock generator having plurality of tracking elements for outputting sequencing signals to functional units |
5604775, | Sep 29 1994 | NEC Electronics Corporation | Digital phase locked loop having coarse and fine stepsize variable delay lines |
5796673, | Oct 06 1994 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Delay locked loop implementation in a synchronous dynamic random access memory |
6067272, | Oct 06 1994 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Delayed locked loop implementation in a synchronous dynamic random access memory |
6205083, | Dec 22 1997 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | Delayed locked loop implementation in a synchronous dynamic random access memory |
JP214094, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jan 17 2003 | Mosaid Technologies Incorporated | (assignment on the face of the patent) | / | |||
Jun 18 2008 | GILLINGHAM, PETER, MR | Mosaid Technologies Incorporated | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 021240 | /0300 | |
Feb 09 2009 | Mosaid Technologies Incorporated | Mosaid Technologies Incorporated | CHANGE OF ADDRESS OF ASSIGNEE | 022542 | /0876 | |
Dec 23 2011 | Mosaid Technologies Incorporated | ROYAL BANK OF CANADA | U S INTELLECTUAL PROPERTY SECURITY AGREEMENT FOR NON-U S GRANTORS - SHORT FORM | 027512 | /0196 | |
Dec 23 2011 | 658868 N B INC | ROYAL BANK OF CANADA | U S INTELLECTUAL PROPERTY SECURITY AGREEMENT FOR NON-U S GRANTORS - SHORT FORM | 027512 | /0196 | |
Dec 23 2011 | 658276 N B LTD | ROYAL BANK OF CANADA | U S INTELLECTUAL PROPERTY SECURITY AGREEMENT FOR NON-U S GRANTORS - SHORT FORM | 027512 | /0196 | |
Jan 01 2014 | Mosaid Technologies Incorporated | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 032439 | /0638 | |
Jun 11 2014 | ROYAL BANK OF CANADA | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | RELEASE OF SECURITY INTEREST | 033484 | /0344 | |
Jun 11 2014 | ROYAL BANK OF CANADA | CONVERSANT IP N B 276 INC | RELEASE OF SECURITY INTEREST | 033484 | /0344 | |
Jun 11 2014 | ROYAL BANK OF CANADA | CONVERSANT IP N B 868 INC | RELEASE OF SECURITY INTEREST | 033484 | /0344 | |
Jun 11 2014 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | ROYAL BANK OF CANADA, AS LENDER | U S PATENT SECURITY AGREEMENT FOR NON-U S GRANTORS | 033706 | /0367 | |
Jun 11 2014 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CPPIB CREDIT INVESTMENTS INC , AS LENDER | U S PATENT SECURITY AGREEMENT FOR NON-U S GRANTORS | 033706 | /0367 | |
Aug 20 2014 | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | CHANGE OF ADDRESS | 033678 | /0096 | |
Jul 31 2018 | ROYAL BANK OF CANADA, AS LENDER | CONVERSANT INTELLECTUAL PROPERTY MANAGEMENT INC | RELEASE OF U S PATENT AGREEMENT FOR NON-U S GRANTORS | 047645 | /0424 |
Date | Maintenance Fee Events |
May 14 2007 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Aug 08 2007 | ASPN: Payor Number Assigned. |
Mar 10 2011 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Mar 14 2011 | ASPN: Payor Number Assigned. |
Mar 14 2011 | RMPN: Payer Number De-assigned. |
Jul 10 2015 | REM: Maintenance Fee Reminder Mailed. |
Dec 02 2015 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Dec 02 2006 | 4 years fee payment window open |
Jun 02 2007 | 6 months grace period start (w surcharge) |
Dec 02 2007 | patent expiry (for year 4) |
Dec 02 2009 | 2 years to revive unintentionally abandoned end. (for year 4) |
Dec 02 2010 | 8 years fee payment window open |
Jun 02 2011 | 6 months grace period start (w surcharge) |
Dec 02 2011 | patent expiry (for year 8) |
Dec 02 2013 | 2 years to revive unintentionally abandoned end. (for year 8) |
Dec 02 2014 | 12 years fee payment window open |
Jun 02 2015 | 6 months grace period start (w surcharge) |
Dec 02 2015 | patent expiry (for year 12) |
Dec 02 2017 | 2 years to revive unintentionally abandoned end. (for year 12) |