DE69716112T2 - Taktanpassung mit feinregelung - Google Patents
Taktanpassung mit feinregelungInfo
- Publication number
- DE69716112T2 DE69716112T2 DE69716112T DE69716112T DE69716112T2 DE 69716112 T2 DE69716112 T2 DE 69716112T2 DE 69716112 T DE69716112 T DE 69716112T DE 69716112 T DE69716112 T DE 69716112T DE 69716112 T2 DE69716112 T2 DE 69716112T2
- Authority
- DE
- Germany
- Prior art keywords
- clock signal
- leading edge
- trailing edge
- memory
- data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Lifetime
Links
- 230000015654 memory Effects 0.000 claims abstract description 203
- 230000003111 delayed effect Effects 0.000 claims abstract description 31
- 230000001960 triggered effect Effects 0.000 claims abstract description 6
- 230000001934 delay Effects 0.000 claims description 19
- 238000000034 method Methods 0.000 claims description 11
- 239000000872 buffer Substances 0.000 description 40
- 101000885321 Homo sapiens Serine/threonine-protein kinase DCLK1 Proteins 0.000 description 23
- 102100039758 Serine/threonine-protein kinase DCLK1 Human genes 0.000 description 23
- 238000010586 diagram Methods 0.000 description 16
- 230000002457 bidirectional effect Effects 0.000 description 7
- 230000000694 effects Effects 0.000 description 6
- 238000012546 transfer Methods 0.000 description 6
- 230000010355 oscillation Effects 0.000 description 5
- 230000007704 transition Effects 0.000 description 5
- 230000003139 buffering effect Effects 0.000 description 4
- 238000004891 communication Methods 0.000 description 3
- 230000032258 transport Effects 0.000 description 3
- 230000005540 biological transmission Effects 0.000 description 2
- 230000000295 complement effect Effects 0.000 description 2
- 230000002411 adverse Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000001914 calming effect Effects 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 230000000116 mitigating effect Effects 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 238000005070 sampling Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000009966 trimming Methods 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03K—PULSE TECHNIQUE
- H03K5/00—Manipulating of pulses not covered by one of the other main groups of this subclass
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/22—Read-write [R-W] timing or clocking circuits; Read-write [R-W] control signal generators or management
- G11C7/225—Clock input buffers
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/10—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
- G11C7/1051—Data output circuits, e.g. read-out amplifiers, data output buffers, data output registers, data output level conversion circuits
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/10—Input/output [I/O] data interface arrangements, e.g. I/O data control circuits, I/O data buffers
- G11C7/1078—Data input circuits, e.g. write amplifiers, data input buffers, data input registers, data input level conversion circuits
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C7/00—Arrangements for writing information into, or reading information out from, a digital store
- G11C7/22—Read-write [R-W] timing or clocking circuits; Read-write [R-W] control signal generators or management
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C8/00—Arrangements for selecting an address in a digital store
- G11C8/06—Address interface arrangements, e.g. address buffers
Landscapes
- Engineering & Computer Science (AREA)
- Microelectronics & Electronic Packaging (AREA)
- Physics & Mathematics (AREA)
- Nonlinear Science (AREA)
- Dram (AREA)
- Electric Clocks (AREA)
- Synchronisation In Digital Transmission Systems (AREA)
- Information Transfer Systems (AREA)
- Pulse Circuits (AREA)
Description
- Die Erfindung betrifft allgemein integrierte Schaltungen, spezieller Takteinstellungen in Speichersystemen wie z. B. Speichersystemen, die dynamische Schreib-/Lese-Speicher (DRAMs) enthalten.
- Integrierte Schaltungen enthalten typischerweise eine Anzahl von Eingangs-/Ausgangs--Pins, die zur Kommunikation mit zusätzlichen Schaltungsteilen dienen. Beispielsweise enthält ein integriertes Speicherbauelement, beispielsweise ein dynamischer Schreib-/Lese-Speicher (DRAM), sowohl Steuereingänge zum Empfangen von Speicherbetriebs-Steuersignalen, als auch Datenpins für die bidirektionale Datenkommunikation mit einem externen System oder einem Prozessor.
- Die Datenübertragungsgeschwindigkeit moderner integrierter Schaltungen wird hauptsächlich beschränkt durch interne Schaltungs-Arbeitsgeschwindigkeiten. Das heißt: Es wurden Kommunikationsnetzwerke entwickelt, die Signale zwischen einer Schaltung mit einer Geschwindigkeit übertragen, die höher ist als die Leistungsfähigkeit zahlreicher integrierter Schaltungen, Um dem Bedarf an schnelleren Schaltungen Rechnung zu tragen, läßt sich eine Gruppe integrierter Schaltungen an einem gemeinsamen Bus kombinieren, gesteuert von einer gemeinsamen Steuerung. Bei einer solchen Konfiguration arbeitet jede integrierte Schaltung in koordinierter Weise mit den übrigen integrierten Schaltungen, um gemeinsam Daten zu verwenden, die mit hoher Geschwindigkeit übertragen werden. So z. B. kann eine Gruppe von Speicherbauelementen, beispielsweise in Form von DRAMs, statischen RAMs oder Festspeichern (ROM) an einen gemeinsamen Datenbus angeschlossen werden und kann von einer Speichersteuerung gesteuert werden, wodurch ein Speichersystem gebildet wird. Die Datenrate auf dem Bus kann wesentlich höher liegen als die mögliche Arbeitsgeschwindigkeit der einzelnen Speicher. Deshalb wird jeder Speicher derart betrieben, dass, während ein Speicher empfangene Daten verarbeitet, ein anderer Speicher neue Daten empfängt. Ein solches Speichersystem mit einer beträchtlichen Anzahl von Speicherbauelementen und einer effizienten Speichersteuerung kann Datenübertragungen mit sehr hoher Geschwindigkeit erreichen.
- Wenn die Übertragungsgeschwindigkeit von Datenkommunikationssignalen in solchen Speichersystemen zunehmend anwächst, werden neue Schaltungen und Verfahren benötigt, um Befehlsdaten, Schreibdaten und Lesedaten, die zwischen der Speichersteuerung und den Speicherbauelementen übertragen werden, exakt zu Takten. Der Anteil eines Taktzyklus, der dem Takten zulässiger Daten gewidmet wird, wird sehr klein, und es kann zu Fehlern beim Takten von Daten bei diesen erhöhten Übertragungsgeschwindigkeiten kommen aufgrund bekannter Effekte wie z. B. Tastverhältnis-Schwankungen, der Busposition eines gegebenen Speicherbauelements, zeitlicher Drift, Ladeschwankungen, Takt-Jitter, Taktdrift, Rauschen, Überschwinger und Schwingungen.
- Aus den oben angegebenen Gründen und aus anderen Gründen, die weiter unten im Zuge der Beschreibung der bevorzugten Ausführungsformen der vorliegenden Patentbeschreibung in größerer Einzelheit angegeben werden, besteht Bedarf im Stand der Technik an einem Speichersystem, welches genauer und exakter derartige Effekte wie z. B. Tastverhältnis-Schwankungen, die Busposition eines gegebenen Speicherbauelements, zeitliche Drifts, Ladeschwankungen, Takt-Jitter, Takt-Drift, Rauschen, Überschwinger und Schwingungen kompensiert, damit Daten in den Speicherbauelementen exakter getaktet werden können.
- ANONYMUS: "Pulse Combining Network", IBM Technical Disclosure Bulletin, Vol. 32, Nr. 12, Mai 1990, Seiten 149-151 zeigt eine Schaltung zur Bereitstellung von Komplementär-Signalen, deren jeweilige Flanken miteinander ausgerichtet sind. Zwei Verzögerungsschaltungen sind mit ihren Eingängen an eine Taktsignalleitung angeschlossen, so dass an den Ausgängen der beiden Verzögerungsschaltungen die komplementären Signale erhalten werden.
- Die vorliegende Erfindung schafft ein Verfahren und eine integrierte Schaltung, die die Merkmale der unabhängige Ansprüche aufweisen.
- Bei einer Ausführungsform der integrierten Schaltung gemäß der Erfindung sind die Vorderflanken- und die Rückflanken-Verzögerungen programmierbare Verzögerungen.
- Bei einer Ausführungsform der integrierten Schaltung gemäß der Erfindung (Anspruch 1) empfängt eine Vorderflanken-Verzögerungsschaltung das Eingangstaktsignal und liefert das Vorderflanken-Taktsignal, und eine Rückflanken-Verzögerungsschaltung empfängt das Vorderflanken-Taktsignal und liefert das Rückflanken-Taktsignal. Bei einer anderen Ausführungsform der integrierten Schaltung (Anspruch 4) empfängt eine Rückflanken-Verzögerungsschaltung das Eingangssignal und liefert ein Rückflanken-Taktsignal, und eine Vorderflanken-Verzögerungsschaltung empfängt das Rückflanken-Taktsignal und liefert das Vorderflanken-Taktsignal.
- Eine Form der vorliegenden Erfindung ist ein Speichersystem mit einer Speichersteuerung und Speichermodulen zum Speichern von Daten. Ein Datenbus überträgt Schreibdaten von der Speichersteuerung zu den Speichermodulen und überträgt Lesedaten aus den Speichermodulen zu der Speichersteuerung. Ein Befehlsbus transportiert Befehle von der Speichersteuerung zu den Speichermodulen. Eine Taktleitung führt ein Eingangstaktsignal von der Speichersteuerung zu den Speichermodulen. Jedes Speichermodul enthält mindestens eine Nonius-(oder Fein-)Takteinstellschaltung, die das Eingangstaktsignal empfingt und ein Vorderflanken-Taktsignal liefert, welches das um eine Vorderflankenverzögerung verzögerte Eingangstaktsignal repräsentiert, und liefert ein Flückflanken-Taktsignal, welches das um eine Rückflankenverzögerung verzögerte Eingangstaktsignal repräsentiert. jedes Speichermodul enthält außerdem mindestens eine flankengetriggerte Schaltung, welche Lese- oder Schreibdaten empfängt, und welche außerdem die Vorderflanken- und Rückflanken-Taktsignale empfängt, um bei der Vorderflanke des Vorderflanken- Taktsignals und bei der Rückflanke des Rückflanken-Taktsignals Lese- oder Schreibdaten zu speichern. Eine solche Nonius-Einstellschaltung läßt sich verwenden zum Eintakten von Befehlen in die Speichermodule. Die Speichermodule können eine oder mehrere integrierte Speicherschaltungen aufweisen, so z. B. dynamische Schreib-/Lese-Speicher (DRAMs).
- Die Nonius-Takteinstellschaltung und das Verfahren gemäß der Erfindung kompensieren genau und exakter Effekte der Tastverhältnis-Schwankung, der Busposition eines gegebenen Speicherbauelements, der zeitlichen Drifts, von Ladeschwankungen, Takt-Jitter und Takt-Drift, Rauschen, Überschwingern und Schwingungen, indem individuell sowohl die Vorder- als auch Rückflanken-Zeitpunkte eingestellt werden, und zwar unabhängig voneinander. Im Ergebnis werden Daten exakt in die Speicherbauelemente auch bei höheren Datenübertragungsraten getaktet.
- Fig. 1 ist ein Blockdiagramm einer Ausführungsform eines Speichersystems.
- Fig. 2 ist ein Impulsdiagramm, das den zeitlichen Ablauf auf dem Bus für das in Fig. 1 gezeigte Speichersystem veranschaulicht.
- Fig. 3 ist ein Blockdiagramm einer weiteren Ausführungsform eines Speichersystems.
- Fig. 4 ist ein Impulsdiagramm, das den zeitlichen Ablauf auf dem Bus für das in Fig. 3 gezeigte Speichersystem veranschaulicht.
- Fig. 5 ist ein Blockdiagramm einer weiteren Ausführungsform eines Speichersystems.
- Fig. 6 ist ein Impulsdiagramm, welches den zeitlichen Ablauf auf dem Bus für das in Fig. 5 gezeigte Speichersystem veranschaulicht.
- Fig. 7 ist ein Blockdiagramm eines Speichersystems mit einer Nonius- Takteinstellschaltung.
- Fig. 8A ist ein Impulsdiagramm, welches eine ideale Signalwellenform veranschaulicht.
- Fig. 8E3 ist ein Impulsdiagramm, welches eine nicht ideale Signalwellenform veranschaulicht.
- Fig. 9 ist ein Blockdiagramm eines unabhängigen Vorder- und Rückflanken-Nonius-Takteinstellsystems.
- Fig. 10 ist ein Blockdiagramm eines unabhängigen, kaskadierten Vorderflanken- und Rückflanken-Nonius-Takteinstellsystems.
- Bei der folgenden detaillierten Beschreibung bevorzugter Ausführungsformen wird auf die begleitenden Zeichnungen Bezug genommen, die ein Teil der Erfindungsbeschreibung sind, und in denen beispielhaft spezifische Ausführungsbeispiele dargestellt sind, die eine Umsetzung der Erfindung in die Praxis darstellen. Es versteht sich, dass weitere Ausführungsformen verwendet werden können, und dass bauliche oder logische Änderungen vorgenommen werden können, ohne vom Schutzumfang der vorliegenden Erfindung abzuweichen. Die nachfolgende detaillierte Beschreibung ist daher nicht in beschränkendem Sinn zu verstehen, der Schutzumfang der Erfindung ist durch die beigefügten Ansprüche definiert.
- Die im folgenden beschriebenen Ausführungsformen der Erfindung werden für die Anwendung auf einen dynamischen Schreib-/Lese-Speicher (DRAM) und Speichersysteme beschrieben, die DRAMs enthalten. Allerdings kann die Erfindung in jeder integrierten Schaltung und in anderen Speichersystemen mit anderen Arten von integrierten Speicherschaltungen implementiert werden. Der DRAM gemäß der Erfindung ähnelt in zahlreichen Gesichtspunkten konventionellen DRAMs, wie sie z. B. im Handel erhältlich sind von der Firma Micron Technology, Inc. in Boise, Idaho. Aus Gründen der Klarheit wird nur ein Teil der bekannten Schaltung des DRAM hier beschrieben, während die neue Schaltung des DRAM gemäß der Erfindung im einzelnen beschrieben wird.
- Ein Speichersystem ist in Fig. 1 allgemein bei 20 dargestellt. Das Speichersystem 20 enthält eine Speichersteuerung 22 und N DRAM-Module, beispielsweise wie bei 24 und 26 angedeutet. Die DRAM-Module, so z. B. das Modul 24 und das Modul 26, enthalten jeweils mindestens ein DRAM-Bauelement. Ein Befehlsbus 28 ist ein unidirektionaler Bus zum Führen von Adressen- und Steuerinformation von der Speichersteuerung 22 zu den DRAM-Modulen. Adressen- und Steuerinformation wird typischerweise von der Speichersteuerung 22 über den Befehlsbus 28 in gleichförmigen Paketen transferiert. Wenn z. B. ein Paket dem Vierfachen der Breite des Befehlsbusses 28 entspricht, so wird ein Befehlspaket in vier Zyklen bei jeder Flanke eines freilaufenden Takts (CCLK) übertragen, der von der Speichersteuerung 22 auf eine Taktleitung 30 gelegt wird. Ein Datenbus 32 ist ein bidirektionaler Bus, der Schreibdaten von der Speichersteuerung 22 zu den DRAM-Modulen führt und außerdem Lesedaten von den DRAM-Modulen zu der Speichersteuerung 22 transportiert. Zwei bidirektionale Datentakte DCLK0 und DCLK1 werden auf die Taktleitung 34 bzw. die Taktleitung 36 gelegt.
- Datentakte DCLK0 und DCLK1 dienen zum präzisen Transfer von Lesedaten- Zeiteinteilung von den DRAM-Modulen zu der Speichersteuerung 22 und weiterhin den präzisen Transfer von Schreibdaten-Zeiteinteilungen von der Speichersteuerung 22 zu den DRAM-Modulen. Sowohl Vorderflanken- als auch Rückflanken-Übergänge des ausgewählten DCLK dienen zum Takten der Eingangs-Zwischenspeicher der DRAM-Module und der Speichersteuerung, welche Daten empfangen. Die Datentakte DCLK0 und DCLK1 folgen demselben Weg wie Daten auf dem Datenbus 32, um die Auswirkungen von Takt-Jitter, Tastverhältnis-Schwankungen, Busposition, zeitlicher Drift und Ladeschwankungen zu reduzieren.
- Wenn die Steuerung des Datenbusses 32 von einem Bauelement im Speichersystem 20 zu einem anderen Bauelement im Speichersystem 20 übergeht, so z. B. von der Speichersteuerung 22 zu dem DRAM-Modul 24, vom DRAM- Modul 24 zu der Speichersteuerung 22 oder vom DRAM-Modul 24 zum DRAM-Modul 26, wird ein DCLK deaktiviert, und der DCLK wird aktiviert. Die Speichersteuerung 22 bestimmt, welcher DCLK für eine gegebene Lese- oder Schreiboperation zu verwenden ist, und sie liefert die Information, die angibt, welche DCLK in dem auf dem Befehlsbus 28 vorhandenen Befehlspaket zu verwenden ist.
- Das Speichersystem 20 sorgt für minimale und maximale Verzögerungen von dem Befehl an der Speichersteuerung 22 bis zum Lesen von Daten an der Speichersteuerung 22 seitens der verschiedenen DRAM-Module, indem es in jedem DRAM-Modul Nonius-Takteinstellschaltungen programmiert. Vorzugsweise liefern die Nonius- oder Fein-Einstellungen in jedem DRAM-Modul einerseits grobe Schritte, die in Bit-Perioden definiert und feine Schritte für Fein-Einstellungen innerhalb einer einzelnen Bit-Periode.
- Fig. 2 ist ein Impulsdiagramm, welches den Bus-Zeitsteuerablauf für das Speichersystem 20 veranschaulicht. Wie in Fig. 2 gezeigt ist, besitzt CCLK alle T Nanosekunden (Ns) eine Übergangsflanke, die abfällt (Rückflanke) oder ansteigt (Vorderflanke). Beispielsweise hat bei einer Ausführungsform des Speichersystems 20 T den Wert von 2,5 Ns. Fig. 2 zeigt eine Folge von vier T Lese- und Schreib-Erstoperationen. Die Bus-Ausbreitungsverzögerung vom Befehlsbus 28 bei der Speichersteuerung 22 zu dem Befehlsbus 28 am DRAM-Modul hat gemäß Darstellung ein Maximum eines Taktübergangs von CCLK (1 T).
- Wie in Fig. 2 gezeigt ist, führt das DRAM-Modul eine interne Leseoperation "Read0" zum Zeitpunkt 17 T aus. Die DRAM-Modul-Nonius-Takteinstellung ist so programmiert, dass sie Lesedaten beginnend beim Zeitpunkt 29 T liefert, so dass Lesedaten bei der Speichersteuerung (MC = Memory Controller) 22 im Zeitpunkt 30 T ankommen. Mit der programmierten Nonius-Takteinstellung in jedem DRAM-Modul wird die Schleifenverzögerung vom Befehl zu dem Datenburst an der Speichersteuerung 22 sowohl für Lese- als auch für Schreiboperationen auf 30 T gehalten. Das DRAM-Modul liefert an die Speichersteuerung 22 mit dem DCLK0 auf der Taktleitung 34 einen Lesedatentakt.
- Zwischen dem Befehlsburst "Read0" und einem Befehlsburst "Write1" gibt es eine zeitliche Lücke von 2 T, damit die Steuerung des Datenbusses 32 von der Speichersteuerung 22 übergehen kann auf das DRAM-Modul. Damit werden Schreibdaten im Zeitpunkt 36 T an der Speichersteuerung 22 geliefert, die dementsprechend im Zeitpunkt 37 T an dem DRAM-Modul ankommen. Ein internen Schreibvorgang wird unmittelbar bei Empfang der Schreibdaten am DRAM-Modul im Zeitpunkt 41 T ausgeführt. Die Speichersteuerung 22 liefert einen Schreibdatentakt mit DCLK1 auf der Taktleitung 34 an das DRAM-Modul.
- Eine Folge von lückenlosen Lese-Burstbefehlen (d. h. Read2, Read3 und Read3) schließen sich an den Befehl "Write1" an. Die Burstbefehle Read2-4 werden an ein einzelnes DRAM-Modul übertragen. Damit sind keine Zeitsteuerlücken in der Folge von Lese-Burstbefehlen erforderlich, da dasselbe Bauelement den Datenbus 32 während sämtlicher dieser Leseoperationen treibt. Eine Lücke von 6 T befindet sich zwischen dem Befehl Write1 und dem ersten Lesebefehl der Folge von Lesebefehlen (das ist der Befehl Read2), um eine Busberuhigung zu ermöglichen.
- Das Speichersystem 20 kann möglicherweise pro DRAM-Modul nur ein DRAM-Bauelement enthalten. Ein Speichersystem, welches pro DRAM-Module mehrere DRAM-Bauelemente enthält, ist in Fig. 3 allgemein bei 120 dargestellt Das Speichersystem 120 enthält eine Speichersteuerung 122 und N DRAM-Module, wie sie bei 124 und 126 angedeutet sind. Die DRAM-Module, wie z. B. die Module 124 und 126, enthalten jeweils M DRAM-Bauelemente. Ein Befehlsbus 128 ist ein unidirektionaler Bus zum transportieren Adressen- und Steuerinformation von der Speichersteuerung 122 zu den DRAM-Modulen. Adressen- und Steuerinformation wird typischerweise von der Speichersteuerung 122 auf dem Befehlsbus 128 in gleichförmigen Paketen bei sowohl den Vorder- als auch den Rückflanken eines freilaufenden Takts (CCLK) auf einer von der Speichersteuerung 122 kommenden Taktleitung 130 übertragen. Datenbusse 132a-m sind bidirektionale Busse, welche Schreibdaten von Speichersteuerung 122 zu den DRAM-Modulen übertragen und außerdem Lesedaten von den DRAM-Modulen zu der Speichersteuerung 122 transportieren. Zwei bidirektionale Datentakte DCLK0 und DCLK1 liegen auf Taktleitungen 34am sowie 36a-m.
- Das DRAM-Modul 124 enthält einen Befehlspuffer 140 zum Puffern von Befehlen vom Befehlsbus 128, die an M DRAM-Bauelemente gegeben werden sollen, wie bei 142a und 142m angedeutet sind. In ähnlicher Weise enthält das N-te DRAM-Modul, angedeutet bei 126, einen Befehlspuffer 144, der Befehle vom Befehlsbus 128 für M DRAM-Bauelemente, wie sie bei 146a und 146m angedeutet sind, puffert.
- Wie in Fig. 3 gezeigt ist, enthält das Speichersystem 120 keine Datenpuffer in den DRAM-Modulen. Daher enthält das Speichersystem 120 M parallele Datenbusse bei 132a und 132m. Entsprechende Datentakte werden über zwei M Taktleitungen, die bei 134a und 134m angedeutet sind, geliefert, um DCLK0 zu transportieren, während bei 136a und 136m angedeutete Taktleitungen das Signal DCLK1 transportieren. Das Speichersystem 120 ist nützlich für solche Speicheranwendungen, die breitere Datenbusse für größere Bandbreiten erfordern, dabei aber keine Verdoppelung des Befehlsbusses 128 für jeden Datenbus erforderlich machen.
- Fig. 4 ist ein Impulsdiagramm, welches den zeitlichen Ablauf für das Speichersystem 120 veranschaulicht. Wie in Fig. 2 ist auch in Fig. 3 ein Folge von vier T Lese- und Schreib-Burstoperationen dargestellt. Die Befehlspuffer, wie sie bei 140 und 144 angegeben sind, fügen eine zusätzliche 2 T betragende Verzögerung hinzu, bis der Befehl zu den DRAM-Bauelementen in den DRAM-Modulen gelangt. Damit beginnt eine interne Leseoperation bei 19 T. Dennoch wird die Nonius-Takteinstellung in dem DRAM-Modul derart einjustiert, dass die Ausgabe von Daten "Read0" bei 29 T an den entsprechenden Datenbus erfolgt und die Ausgangsdaten "Read0" dementsprechend zur Zeit 30 T an der Speichersteuerung 122 ankommen.
- Was den Schreibvorgang angeht, so werden im Zeitpunkt 36 T Schreibdaten bereitgestellt, die im Zeitpunkt 37 T am DRAM-Modul ankommen, damit der interne Schreibvorgang bei 41 T möglich ist, ähnlich wie der Schreib-Zeitab- lauf des Speichersystems 20.
- Ein weiteres Speichersystem, welches mehrere DRAM-Bauelemente pro DRAM-Modul enthält, ist allgemein mit 220 in Fig. 5 bezeichnet. Das Speichersystem 220 enthält eine Speichersteuerung 222 und N DRAM-Module, angedeutet bei 224 und 226. Die DRAM-Module, beispielsweise die Module 224 und 226, enthalten jeweils M DRAM-Bauelemente. Ein Befehlsbus 228 ist ein unidirektionaler Bus zum Transportieren von Adressen- und Steuerinformation aus der Speichersteuerung 222 zu den DRAM-Modulen. Adressen- und Steuerinformation wird typischerweise von der Speichersteuerung 222 über den Befehlsbus 228 in gleichförmigen Paketen bei den Vorder- und den Rückflanken eines von der Speichersteuerung 222 auf eine Taktleitung 230 gelegten, freilaufenden Takts (CCLK) übertragen. Ein Datenbus 232 ist ein bidirektionaler Bus, welcher Schreibdaten von der Speichersteuerung 222 zu den DRAM-Modulen transportiert und außerdem Lesedaten von den DRAM-Modulen zu der Speichersteuerung 222 transportiert. Zwei bidirektionale Datentakte DCLK0 und DCLK1 liegen auf den Taktleitung 234 bzw. 236.
- Das erste DRAM-Modul 224 enthält einen Befehlspuffer 240, der Befehle für M DRAM-Bauelemente puffert, wie sie bei 242a und 242m angedeutet sind. Darüber hinaus enthält das DRAM-Modul 224 einen Datenpuffer 250 zum Puffern von Lese- und Schreibdaten von und zu den N DRAM-Bauelementen 242a- m. In ähnlicher Weise enthält das N-te DRAM-Modul 226 einen Befehlspuffer 224 zum Puffern von Befehlen für M DRAM-Bauelemente, angedeutet beispielsweise bei 246a und 246m. Zusätzlich enthält das DRAM-Modul 226 einen Datenpuffer 252 zum Puffern von Lese- und Schreibdaten von den und für die M DRAM-Bauelemente 246a-m. Bei der Konfiguration des Speichersystems 220 mit den Datenpuffern sind nur ein Datenbus 232 und ein Satz von DCLK- Taktleitungen erforderlich. Damit senden und empfangen Datenpuffer wie z. B. der Datenpuffer 250 und der Datenpuffer 252, Daten vom Datenbus 232 und senden und empfangen das DCLK0-Taktsignal von der Taktleitung 234 und das DCLK1-Taktsignal von der Taktleitung 236.
- Der Aufbau des Speichersystems 220 ist dann nützlich, wenn eine sehr große Speicherkonfiguration erforderlich ist. Bei einer Ausführungsform des Speichersystems 220, das die Parameter N = 4 und M = 8 hat, sind in einem einzelnen DRAM-Modul acht DRAM-Bauelemente enthalten, und in dem Speichersystem 220 befinden sich vier DRAM-Module, was insgesamt 32 DRAM- Bauelemente für das Speichersystem ausmacht.
- Aufgrund der zeitlichen Flexibilität, die durch die Nonius-Takteinstellschaltung in den individuellen DRAM-Bauelementen ermöglicht wird, können andere Ausführungsformen der erfindungsgemäßen Speichersysteme, so z. B. das Speichersystem 20, 120 und 220, sowohl gepufferte als auch ungepufferte Module aufweisen. Beispielsweise kann ein Speichersystem gemäß der Erfindung tatsächlich enthalten: Ein oder mehrere DRAM-Module, die keine Befehlspuffer und keine Datenpuffer enthalten; ein oder mehrere DRAM-Module, die Befehlspuffer aber keine Datenpuffer enthalten; und ein oder mehrere DRAM- Module, die sowohl Befehlspuffer als auch Datenpuffer enthalten. Ob ein spezielles DRAM-Modul Puffer oder Teilpuffer enthält, ist für die Speichersteuerung des Speichersystems gemäß der Erfindung vollständig transparent.
- Fig. 6 zeigt in Form eines Impulsdiagramms die zeitliche Bussteuerung für das Speichersystem 220. Wie in Fig. 6 gezeigt ist, fügen Datenpuffer wie die Datenpuffer 250 und 252 zusätzliche 2 T Verzögerung zu den Lesedaten hinzu. Damit beginnt die interne Leseoperation immer nach im Zeitpunkt 19 T, genau so wie beim Speichersystem 120. Allerdings ist die Nonius-Takteinstellschaltung in dem DRAM-Modul so einjustiert, dass sie Ausgangsdaten auf den Datenbus 232 am DRAM-Modul im Zeitpunkt 27 T gibt, um die Ankunft dieser Ausgangsdaten an der Speichersteuerung 222 im Zeitpunkt 30 T zu garantieren (d. h.: 27 T + 2 T Verzögerung vom Datenpuffer plus 1 T Ausbreitungsverzögerung auf dem Datenbus 232). Damit kommen die Lesedaten "Read0" an der Speichersteuerung bei 30 T an, unabhängig davon, ob es Befehlspuffer gibt, Lind unabhängig davon, ob in dem Speichersystem Datenpuffer verwendet werden.
- In dem Speichersystem 220 liefert der Schreibvorgang "Write1" Daten im Zeitpunkt 36 T an der Speichersteuerung 222, ähnlich wie die Schreiboperationen "Write1" die in den Fig. 2 und 4 für die Speichersysteme 20 bzw. 120 dargestellt sind. Weil allerdings die 2 T betragende Verzögerung aus den Datenpuffern vorhanden ist, kommen die Daten "Write1" anstatt im Zeitpunkt 37 T erst im Zeitpunkt 39 T an dem DRAM-Modul an. Dementsprechend wird der interne Schreibvorgang "Write1" beginnend im Zeitpunkt 23 T im Speichersystem 220 ausgeführt, und nicht im Zeitpunkt 41 T.
- Die Nonius-Takteinstellschaltung sowie weitere dazugehörige Schaltungselemente des Speichersystems 20 (oder der Speichersysteme 120 und 220) sind in Fig. 7 in Farm eines Blockdiagramms dargestellt. Wie aus Fig. 7 hervorgeht, enthält die Speichersteuerung 22 ein Befehlsregister 50 zum Liefern von Befehlen an den Befehlsbus 28, und ein CCLK-Register 52 zum Liefern des Takt CCLK auf die Taktleitung 30. Ein Mastertakt geht über eine Leitung 54 an die Register 50 und 52. Ein Schreibdatenregister 56 wird ebenfalls von dem Mastertakt auf der Leitung 54 getaktet und sorgt für ein Schreiben von Daten auf den Datenbus 32. Ein Lesedatenregister 58 empfängt Lesedaten von dem Datenbus 32 und empfängt seinen Takt von einer optionalen Nonius-Takteinstellschaltung 60. Diese Nonius-Takteinstellschaltung 60 empfängt den Mastertakt von der Leitung 54 und den aktiven Datentakt von den Datentakten DCLK0 oder DCLK1 über einen Register-Multiplexer 62, der DCLK0 und DCLK1 von den Taktleitungen 34 und 36 empfängt.
- Das DRAM-Modul 24 enthält einen Befehlszwischenspeicher 64, der Befehle vom Befehlsbus 28 empfängt. Der Befehlszwischenspeicher 64 empfängt einen verzögerten CCLK-Takt von der Befehls-Nonius-Takteinstellschaltung 66. Diese empfängt das CCLK-Taktsignal von der Taktleitung 30. Ein FIFO-Puffer (38 empfängt von den Leitungen 34 und 36 die Taktsignale DCLK0 und DCLK1 und empfängt die Schreibdaten vom Datenbus 32, um Daten an einen DRAM- Kern 76 zu geben. Ein Schreib-FIFO-Puffer 68 empfängt einen verzögerten CCLK-Takt von der Schreib-Nonius-Takteinstellschaltung 70. Diese empfängt außerdem das CCLK-Taktsignal von der Taktleitung 30. Ein Lese-FIFO-Puffer 72 empfängt Lesedaten von dem DRAM-Kern 76 und liefert die Lesedaten zusammen mit den Taktsignalen DCLK0 und DCLK1 auf den Leitungen 34 und 36 an den Datenbus 32. Der Lese-FIFO-Puffer 72 empfängt von einer Lese-Nonius-Takteinstellschaltung 74 einen verzögerten CCLK-Takt. Die Lese-Nonius-Takteinstellschaltung 74 empfängt außerdem von der Taktleitung 30 das CCLK-Taktsignal.
- Wenn die Speichersysteme 20/120/220 eingeschaltet werden, wird die Befehls-Zeiteinteilung, die Lese-Zeiteinteilung ebenso wie die Schreib-Zeiteinteilung jedes individuellen DRAMs von der Speichersteuerung 22/122/222 derart eingestellt, dass Datenbursts auf dem Datenbus, die ihren Ursprung in verschiedenen Bauelementen haben, passen beabstandet sind. DRAM-Bauelemente von verschiedenen Lieferanten, hergestellt an verschiedenen Stellen eines verstreuten Prozesses und bei unterschiedlichen Temperaturen und Versorgungsspannungen arbeitend sowie verschiedene Positionen an dem Befehls- und dem Datenbus belegend und außerdem mit und ohne Befehlspuffer und/oder Datenpuffer arbeitend, enthalten notwendigerweise einen Bereich von Schleifenverzögerungen zwischen dem Lesebefehl auf dem Befehlsbus 28 bei der Speichersteuerung 22 bis hin zur Eingabe von Lesedaten in die Speichersteuerung 22 an deren Position am Datenbus 32. Ähnliche Schwankungen treten auf bei Schreibdaten, die einen Bereich von Schleifenverzögerungen zwischen dem Schreibbefehl an der Speichersteuerung 22 bis zu den Schreibdaten am ausgewählten DRAM-Bauelement seitens des Datenbusses 32 aufweisen.
- Wie in Fig. 7 gezeigt ist, enthält jeder DRAM eine Vielfalt von Nonius-Einstellschaltungen, die für eine Kompensation all dieser Variablen sorgen, damit Lesedaten von sämtlichen DRAMs innerhalb eines fixen, deterministischen Zeitrahmens an der Speichersteuerung 22 ankommen, und um in ähnlicher Weise zu ermöglichen, dass Schreibdaten mit einem fixen, deterministischen Zeitrahmen an den ausgewählten DRAM-Bauelementen ankommen.
- Bei einer Ausführungsform des Speichersystems 20/120/220 erfolgen die Einstellungen der Nonius-Takteinstellschaltung 66, 70 bzw. 74 in jedem DRAM- Bauelement durch Schreiben eines Verzögerungswerts in ein Register, welches sich in jedem DRAM-Bauelement befindet. Beispielsweise beinhaltet die Verzögerung typischerweise eine Grobeinstellung, durch die eine Anzahl von Bitperioden der Verzögerungseinstellung festgelegt wird, und eine Feineinstellung, die eine feine Abstufung beinhaltet, um eine Einstellung innerhalb eines einzelnen Bits abzudecken.
- Nonius-Einstellschaltung 66, 70, 74 und 60 werden typischerweise mit angezapften Verzögerungsleitungen implementiert. In einer bevorzugten Ausführungsform der Erfindung werden Negatoren kaskadiert, und verschiedene Anzapfpunkte entlang den angezapften Verzögerungsleitungen liefern die geforderten Variationen der Nonius-Einstellverzögerungen. Die Nonius-Verzögerungen sind optional mit einer Phasenregelschleife (PPL-Schaltung) oder einer Verzögerungsregelschleife (DLL-Schaltung) ausgestattet, wo verschiedene Phasen von verschiedenen Stellen ausgewählt werden, um die geforderten Schwankungen der Nonius-Einstellverzögerungen zu erhalten. Die Nonius- Takteinstellschaltungen können mit beliebigen, geeigneten und programmierbaren Verzögerungselementen implementiert werden.
- Während der Initialisierung gibt es eine Vielfalt von Möglichkeiten für die Einstellung der Nonius-Takteinstellschaltungen. Beispielsweise läuft eine Ausführungsform des Speichersystems 20 durch sämtliche Verzögerungsstufen der Nonius-Schaltung und ermittelt, wann Daten bei niedrigen Einstellungen und bei hohen Einstellungen fehlen, um die Nonius-Einstellung bei einer aproximierten optimalen Mitteleinstellung festzulegen. Eine weitere Ausführungsform des Speichersystems 20 enthält eine Regelung zum Einrichtungen der Nonius- Einstellungen, indem zunächst eine abgeschätzte optimale Einstellung ausgewählt wird, und dann der Steuerung und der Regelschaltung zu ermöglichen, bei der optimalen Verzögerungseinstellung für die Nonius-Takteinstellschaltung anzukommen.
- Was folgt ist ein Beispiel für Nonius-Zeiteinstellungen während der Initialisierung einer Ausführungsform des Speichersystems 20 ohne optionale Nonius- Einstellschaltung 60 innerhalb der Speichersteuerung 22. Bei dieser Ausführungsform sendet die Speichersteuerung 22 Befehle an das erste DRAM-Modul 24, und die Befehls-Takteinstellschaltung 66 im DRAM-Modul 24 wird so eingestellt, dass der Befehl optimal von dem Befehlsbus 28 im Befehlszwischenspeicher 64 empfangen wird. Dann startet die Speichersteuerung 22 eine Schreibbefehlssequenz, und die Schreib-Nonius-Einstellschaltung 70 im DRAM-Modul 24 wird so eingestellt, dass ein optimaler Empfang der Schreibdaten am Schreib-FIFO-Puffer 68 von dem Datenbus 32 möglich ist. Als nächstes wird eine Lesebefehlssequenz von der Speichersteuerung 22 gestartet, und die Lese-Nonius-Takteinstellschaltung 74 wird so eingestellt, dass ein optimaler Empfang von Lesedaten am Lesedatenregister 58 seitens des Datenbusses 32 möglich ist.
- Die Befehls-, Schreib- und Lese-Nonius-Takteinstellschaltungen werden mit der obigen Sequenz von Schritten für jedes der DRAM-Module bis hin zu dem N-ten DRAM-Modul 26 entsprechend eingestellt. Bei Abschluss dieser Sequenzen sind die Einstellungen von Takten, Befehlen, Schreibdaten-Bursts und Lesedaten-Bursts aus sämtlichen Quellen optimal eingestellt.
- Was nun folgt, ist ein alternatives Beispiel für die Lese-Zeitsteuereinstellung für eine alternative Ausführungsform des Speichersystems 20, welches die Nonius-Einstellschaltung 60 in der Speichersteuerung 22 enthält. Bei dieser Ausführungsform wird beim Initialisieren die Lese-Nonius-Verzögerung auf einen Minimumwert in jedem DRAM-Bauelement eingestellt. Dann sendet die Speichersteuerung 22 Schreibdaten auf den Datenbus 32 und versucht, die Schreibdaten am Lesedatenregister 58 zu empfangen. Bei dieser Ausführungsform stellt die Speichersteuerung 22 die Speichersteuerungs-Nonius- Takteinstellschaltung 60 auf den optimalen Abtastzeitpunkt ein. Diese Einstellung legt einen Lesedaten-Zeitreferenzpunkt fest, um eine zeitliche Ausrichtung zwischen Schreibdaten-Bursts und Lesedaten-Bursts auf dem Datenbus 32 zu garantieren.
- Die Speichersteuerung 22 sendet die Lesedatenbefehle an das erste DRAM- Modul 24 und beobachtet das entsprechende DCLK-Muster, welches über die Datentaktleitung 34 oder 36 zurückkehrt. Die Speichersteuerung 22 schreibt dann in das Nonius-Verzögerungssteuerregister der Lese-Nonius-Takteinstellschaltung 74 ein oder stellt in anderer Weise die Verzögerung dieser Takteinstellschaltung ein, um die Verzögerung so weit zu erhöhen, bis Leseverzögerungsdaten optimal mit dergleichen internen Speichersteuerungs- Taktsteuerung abgetastet werden können, wie sie zum Lesen und Schreiben von Daten im vorausgehenden Schritt verwendet wurde.
- Die Speichersteuerung 22 stellt dementsprechend die Lese-Nonius-Takteinstellschaltungen jedes der DRAM-Module bis hin zu dem N-ten DRAM-Modul 26 ein. Nach Abschluss dieser Sequenz sind die Lesedatenburst-Einstellungen von sämtlichen Quellen optimal einjustiert.
- Mit einer ähnlichen Einleitungssequenz, die für Schreiboperationen und Leseoperationen durchgeführt wird, wird eine konstante Verzögerung zwischen der Bereitstellung eines Befehlspakets an dem Befehlsbus 28 an der Speichersteuerung 22 bis zu Lesedaten- oder Schreibdaten-Bursts an den E/A-Pins des Datenbusses der Speichersteuerung eingerichtet. Beim normalen Betrieb wird einer von den Takten DCLK0 oder DCLK1 in der Nonius-Takteinstellschaltung 60 ausgewählt, um die Lesedaten in dem Lesedatenregister 58 zwischenzuspeichern, anstelle des Mastertakts von der Leitung 54. Allerdings kann die Nonius-Schaltung 60 der Speichersteuerung 22 periodisch dazu eingesetzt werden, den zeitlichen Ablauf von Daten aus sämtlichen Quellen zu überwachen, um nötigenfalls zur Kompensation einer zeitlichen Drift des Systems die DRAM-Nonius-Steuerregister zu aktualisieren.
- An jedem DRAM-Bauelement-Eingang fallen die Flanken des CCLK-Takts und der DCLK-Takte zusammen mit Datenübergängen auf dem Befehlsbus 28 bzw. dem Datenbus 32. Um dies zu kompensieren, werden der CCLK-Takt und die DCLK-Takte typischerweise um eine halbe Bitperiode mit Hilfe der Nonius-Takteinstellschaltungen verzögert, um ankommende Daten optimal abzutasten. Wie oben erwähnt und in Verbindung mit Fig. 7 dargestellt, dient der freilaufenden CCLK zum Treiben sämtlicher interner DRAM-Zeitsteuerabläufe. Eine verzögerte Version des CCLK dient zum Zwischenspeichern der Befehlspakete mit Hilfe der Nonius-Takteinstellschaltung 66. In ähnlicher Weise liefern Nonius-Einstellschaltungen 70 und 74 verzögerte Versionen des freilaufenden CCLK-Takts, um den Schreib-FIFO-Puffer 68 bzw. den Lese-FIFO- Puffer 72 zu takten.
- In einem Speichersystem treten verschiedene Probleme auf, so z. B. in den Speichersystemen 20, 120 und 220, wenn höhere Taktgeschwindigkeiten für das CCLK-Taktsignal verwendet werden. Derartige Speichersysteme leisten beispielsweise 400 Mbps pro Pin, was einen CCLK-Takt von 200 MHz erfordert. Tatsächlich können derartige Systeme sogar noch höhere Datenraten pro Pin aufweisen, so z. B. gibt es Systeme mit 600 Mbps, 800 Mbps, 1 Gbps und 1, 2 Gbps pro Pin. Mit diesen noch höheren Datenübergängen führen Effekte von Jitter, Drift, Rauschen, Überschwingern und Schwingungen (ringing) zu immer kleiner werdenden Abschnitten einer gesamten Taktperiode, in denen gültige Daten in ein DRAM-Bauelement getaktet werden können.
- Das folgende Zeiteinteilungs-Budget für ein Speichersystem mit 400 Mbps pro Pin veranschaulicht dieses Problem. Bei dem Speichersystem mit 400 Mbps pro Pin beträgt das CCLK-Signal 200 MHz oder 2,5 Ns zwischen jeder Flanke des Takts, der folgendermaßen zugeteilt wird:
- 1) 250 ps für den Zeitversatz aufgrund der VREF-Drift und Rauschen;
- 2) 500 ps für die Vorbereitung und das Halten des Fensters;
- 3) 400 ps für den Treiberversatz in Querrichtung des Busses;
- 4) 200 ps für die Lastschwankungen in Querrichtung des Busses;
- 5) 100 ps für die Weganpassung in Querrichtung des Busses (die Schaltungsplatinen-Leitungsbahnen);
- 6) 500 ps für den Impulsbreiten abhängigen zeitlichen Versatz (Datenabhängigkeit);
- 7) 200 ps für Takt- und Daten-Jitter (durch Rauschen hervorgerufen); und
- 8) 250 ps für eine gesamte Daten-Leseschwankung von Modul zu Modul nach dem Trimmen. Datenfehler vornehmlich aufgrund der als ungünstigsten Fall anzunehmenden Trim-Auflösung. Ausgeschaltete Zeitsteuerfehler beinhalten Busweglängen-Differenzen von Modulen an dem Bus und verschiedene DRAM-Zugriffszeiten durch den Takt.
- Dieses Problem wird anhand der Fig. 8A und 8B mittels Impulsdiagramm näher erläutert. In Fig. 8A ist eine ideale Signalwellenform bei 80 dargestellt, sie bedeutet zulässige Daten zwischen den Zeitpunkten zwischen den Pfeilen 82. Wie in Fig. 8A dargestellt ist, bildet die ideale Signalwellenform 80 ein großes Augenmuster. Im Gegensatz dazu zeigt Fig. 8B eine nicht ideale Wellenform bei 84, die eine deutliche verminderte Zeitspanne für zulässige Daten aufweist, angedeutet durch Pfeile 86. Die nicht ideale Wellenform 84 entsteht als Ergebnis von Jitter, zeitlichen Versatz, Rauschen, Überschwinger und gedämpfte Schwingungen und andere derartige bekannte Probleme.
- Um diese Probleme zu kompensieren und in geeigneter Weise ankommende Daten in jedes DRAM zwischenzuspeichern, ist eine zweite Stufe einer Nonius- Einstellung oder Feineinstellung gemäß der Erfindung jeder Nonius-Einstellschaltung in jedem DRAM-Modul hinzugefügt, um von einem Takt die zeitliche Lage seiner Rückflanke unabhängig von oder gegenseitig abhängig mit der Takt-Vorderflanke einzustellen.
- Eine nicht beanspruchte Ausführungsform eines Nonius-Takteinstellsystems ist allgemein mit 300 in Fig. 9 bezeichnet. Dieses Nonius-Takteinstellsystem 300 enthält eine Vorderflanken-Nonius-Einstellschaltung 302 und eine Rückflanken-Nonius-Einstellschaltung 304. Ein Taktsignal (CLK) wird über eine Taktleitung 306 den Nonius-Einstellschaltungen 302 und 304 zugeführt. Die Nonius-Einstellschaltung 302 verzögert unabhängig das von der Taktleitung 306 kommende CLK-Signal, um eine verzögerte Version des CLK-Signals auf einer Taktleitung 308 zu liefern. Der verzögerte Takt auf der Taktleitung 308 dient zur Vorderflanken-Takterzeugung. Eine Rückflanken-Nonius-Takteinstellschaltung 304 verzögert unabhängig das von der Taktleitung 306 kommende CLK-Signal, um eine verzögerte Version des CLK-Signals auf eine Taktleitung 310 zu geben. Das verzögerte Taktsignal auf der Leitung 310 dient für die Rückflanken-Takterzeugung. Damit beinhaltet das Nonius-Takteinstellsystem 300 zwei vollständig separate Nonius-Schaltungen, jeweils eine zur unabhängigen Verzögerung jeder Taktflanke.
- Eine weitere Ausführungsform eines erfindungsgemäßen Nonius-Takteinstell- Systems ist in Fig. 10 allgemein mit 400 bezeichnet. Das Nonius-Takteinstellsystem 400 enthält kaskadierte Nonius-Takteinstellschaltungen 402 und 404. Ein CLK-Signal wird über eine Leitung 406 der Nonius-Taktschaltung 402 zugeführt. Die Nonius-Taktschaltung 402 gibt auf eine Taktleitung 408 eine verzögerte Version des CLK-Signals. Der verzögerte Takt auf der Leitung 408 wird für Vorderflanken-Taktungen verwendet. Die Nonius-Takteinstellschaltung 402 liefert außerdem die gleiche verzögerte Version des CLK-Signals über eine Leitung 409 an die zweite Nonius-Takteinstellschaltung 404. Diese verzögert das Taktsignal zusätzlich, um auf eine Taktleitung 410 ein verzögertes Taktsignal zu gehen. Dieses verzögerte Taktsignal auf der Leitung 410 dient für Rückflanken-Taktungen. In dem kaskadierten Nonius-Einstellsystem 400 basiert die zeitliche Lage der Rückflanke auf der zeitlichen Lage der Vorderflanke. Eine (nicht gezeigte) alternative Ausführungsform des Nonius-Takteinstellsystems 400 ist derart konfiguriert, dass die zeitliche Lage der Vorderflanke auf der zeitlichen Lage der Rückflanke basiert.
- Nonius-Takteinstellsysteme 300 und 400 werden vorzugsweise in der Befehls--Nonius-Takteinstellschaltung 66, der Schreib-Nonius-Takteinstellschaltung 70 und der Lese-Nonius-Takteinstellschaltung 74 des DRAM-Moduls 24 und der anderen DRAM-Module der Speichersysteme 20/120/220 eingesetzt, wie dies in Fig. 7 gezeigt ist. Optional enthält die Nonius-Einstellschaltung 60 der Speichersteuerung 22 ebenfalls eine solche individuelle Flankeneinstellung, wie sie durch das Nonius-Taktsystem 300 oder 400 bereitgestellt wird.
- Bei einer Ausführungsform des Speichersystems 20/120/220 werden bei der Initialislierung des Systems die Vorderflanken-Taktdaten zuerst einjustiert, gefolgt von den Rückflanken-Taktdaten. Die Vorderflanken-Taktdaten werden dadurch einjustiert, dass die Verzögerung eingestellt wird, die durch die Vorderflanken-Nonius-Einstellschaltung 302 des Systems 300 oder die Schaltung 402 des Systems 400 gebildet wird. Die Rückflanken-Taktdaten werden anschließend dadurch eingestellt, dass man die Verzögerung der Rückflanken- Nonius-Einstellschaltung 304 des Systems 300 oder der Schaltung 404 des Systems 400 einjustiert. Alternative Ausführungsformen für das Speichersystem 20/120/220 stellen als erstes die Rückflankenzeit ein, anschließend die Vorderflankenzeit, wenn das System initialisiert wird.
- Die Rückflanken- und Vorderflanken-Einstellungen, die durch das Nonius- Takteinstellsystem 400 erfolgen, sind besonders günstig, wenn es darum geht, Speichersystemanforderungen bezüglich des Takt-Tastverhältnisses zu mildern. Insbesondere ist das zur Erzeugung der Signale DCLK0 und DCLK1 in den Speichersystemen 20, 120 und 220 eingesetzte Echotaktschema besonders anfällig für Tastverhältnisprobleme, da jedes DRAM-Bauelement einen Takt empfangen und den Takt mit den Lesedaten zurücksenden muss. Jedesmal, wenn der Takt auf den Datenbus und von dem Datenbus umgesetzt wird, wird das Tastverhältnis abträglich beeinflusst. Das erfindungsgemäße Speichersystem kompensiert diese Tastverhältnisprobleme unter Verwendung der Takt- Nonien, um individuell sowohl die Vorderflanken als auch die Rückflanken des Takts einzujustieren.
- Darüber hinaus arbeitet ein Speichersystem wie z. B. das Speichersystem 20, 120 oder 220, typischerweise gemäß einem Industrie-Normprotokoll, wonach die DRAM-Bauelemente, seien sie nun von demselben oder von unterschiedlichen Lieferanten gefertigt, für die Speichersteuerung identisch aussehen. Aus der Sichtweise der Speichersteuerung können darüber hinaus die DRAM- Bauelemente sich an verschiedenen Punkten in dem verstreuten Prozess befinden, so z. B. bei 400 Mbps im Vergleich zu 800 Mbps. Darüber hinaus können DRAM-Bauelemente bei verschiedenen Temperaturen und Versorgungsspannungen arbeiten und unterschiedliche Positionen an dem Befehlsbus und dem Datenbus belegen, und gleichzeitig können die DRAM-Bauelemente mit oder auch ohne Befehlspuffer und Datenpuffer arbeiten. Die exaktere Einjustierung beim Einstellen sowohl Rückflanken als auch Vorderflanken der Takte kompensieren diese Probleme besser.
- Durch Einsatz der Nonius-Takteinstellschaltung und des entsprechenden Verfahrens gemäß der Erfindung bei Speichersystemen wie z. B. den Speichersystemen 20/120/220 werden die Auswirkungen von Tastverhältnisschwankungen, Busposition eines gegebenen Speicherbauelements, zeitlicher Drift, Ladeschwankungen, Takt-Jitter, zeitlichen Taktversatz, Rauschen, Überschwinger und abklingende Schwingungen genauer und präziser durch individuelles Einstellen der zeitlichen Lage sowohl der Vorderflanken als auch der Rückflanken unabhängig voneinander kompensiert. Auf diese Weise können Daten exakter in die Speicherbauelemente eingetaktet werden, selbst dann, wenn mit höheren Datenübertragungsgeschwindigkeiten gearbeitet wird.
Claims (16)
1. Integrierte Schaltung (20; 120; 220), umfassend:
eine Nonius-Takteinstellschaltung (66, 70, 74), die ein Eingangstaktsignal
(CLK) empfängt, eine Vorderflanken-Verzögerungsschaltung enthält, die
das Eingangstaktsignal (CLK) empfängt und ein Vorderflanken-Taktsignal
liefert, welches das um eine Vorderflankenverzögerung verzögerte
Eingangstaktsignal (CLK) darstellt, wobei die Nonius-Takteinstellschaltung
(66, 70, 74) außerdem eine Rückflanken-Verzögerungsschaltung (404)
enthält, die das Vorderflanken-Taktsignal empfängt und ein Rückflanken-
Taktsignal liefert, welches das um eine Rückflankenverzögerung verzögerte
Eingangstaktsignal (CLK) repräsentiert; und
eine flankengetriggerte Schaltung (64, 68, 72), welche Daten und die
Vorderflanken- und Rückflanken-Taktsignale empfängt und bei der
Vorderflanke des Vorderflanken-Taktsignals und bei der Rückflanke des
Rückflanken-Taktsignals Daten speichert.
2. Integrierte Schaltung nach Anspruch 1, bei der die Vorderflanken- und die
Rückflankenverzögerungen programmierbare Verzögerungen aufweisen.
3. Integrierte Schaltung nach Anspruch 1, umfassend eine integrierte
Speicherschaltung (20; 120; 220).
4. Integrierte Schaltung, umfassend:
eine Nonius-Takteinstellschaltung (66, 70, 74), die ein Eingangstaktsignal
empfängt und eine Rückflanken-Verzögerungsschaltung enthält, die das
Eingangstaktsignal empfängt und ein Rückflanken-Taktsignal liefert,
welches das um eine Rückflankenverzögerung verzögerte Eingangstaktsignal
(DLK) repräsentiert, wobei die Nonius-Takteinstellschaltung (66, 70, 74)
außerdem eine Vorderflanken-Verzögerungsschaltung enthält, die das
Rückflanken-Taktsignal empfängt und ein Vorderflanken-Taktsignal
liefert, welches das um eine Vorderflankenverzögerung verzögerte
Eingangstaktsignal repräsentiert; und
eine flankengetriggerte Schaltung (64, 68, 72), die Daten und die
Vorderflanken- und Rückflanken-Taktsignale empfängt und bei der Vorderflanke
des Vorderflanken-Taktsignals und bei der Rückflanke des Rückflanken-
Taktsignals Daten speichert.
5. Integrierte Schaltung (20; 120; 220) nach Anspruch 4, bei der die
Vorderflanken- und Rückflankenverzögerungen programmierbare Verzögerungen
aufweisen.
6. Integrierte Schaltung nach Anspruch 4, umfassend eine integrierte
Speicherschaltung (20; 120; 220).
7. Verfahren zum Betreiben einer integrierten Schaltung, umfassend folgende
Schritte:
Empfangen eines Eingangstaktsignals (CLK);
Verzögern des Eingangstaktsignals, um ein Vorderflanken-Taktsignal zu
liefern, welches das um eine Vorderflankenverzögerung verzögerte
Eingangstaktsignal (CLK) repräsentiert;
Verzögern des Vorderflanken-Taktsignals, um ein Rückflanken-Taktsignal
zu liefern, welches das um eine Rückflankenverzögerung verzögerte
Eingangstaktsignal repräsentiert; und
Speichern von Daten bei der Vorderflanke des Vorderflanken-Taktsignals
und bei der Rückflanke des Rückflanken-Taktsignals.
8. Verfahren nach Anspruch 7, weiterhin umfassend das Programmieren der
Vorderflanken- und der Rückflankenverzögerungen.
9. Verfahren zum Betreiben einer integrierten Schaltung, umfassend die
Schritte:
Empfangen eines Eingangstaktsignals (CLK);
Verzögern des Eingangstaktsignals (CLK), um ein Rückflanken-Taktsignal
zu liefern, das das um eine Rückflankenverzögerung verzögerte
Eingangstaktsignal repräsentiert;
Verzögern des Rückflanken-Taktsignals, um ein Vorderflanken-Taktsignal
zu liefern, welches das um eine Vorderflankenverzögerung verzögerte
Eingangstaktsignal darstellt; und
Speichern von Daten bei der Vorderflanke des Vorderflanken-Taktsignals
und bei der Rückflanke des Rückflanken-Taktsignals.
10. Verfahren nach Anspruch 9, weiterhin umfassend das Programmieren der
Vorderflanken- und der Rückflankenverzögerungen.
11. Speichersystem (20; 120; 220), umfassend:
eine Speichersteuerung (22; 122; 222);
mehrere Speichermodule (24, 26; 124, 126; 224, 226) zum Speichern von
Daten;
einen Datenbus (32; 132; 232) zum Übertragen von Schreibdaten von der
Speichersteuerung (22; 122; 222) zu den mehreren Speichermodulen und
zum Übertragen von Lesedaten von den mehreren Speichermodulen (24,
26; 124, 126; 224, 226) zu der Speichersteuerung (22; 122; 222);
einen Befehlsbus (28; 128; 22ß), der Befehle von der Speichersteuerung
(22; 122; 222) zu den mehreren Speichermodulen (24, 26; 124, 126; 224,
226) überträgt;
eine Taktleitung (30; 130; 230) zum Übertragen eines Eingangstaktsignals
von der Speichersteuerung (22; 122; 222) zu den mehreren
Speichermodulen (24, 26; 124, 126; 224, 226); und
wobei jedes Speichermodul beinhaltet:
eine Nonius-Takteinstellschaltung, die eine
Vorderflanken-Verzögerungsschaltung (402) enthält, die ein Eingangstaktsignal empfängt und ein
Vorderflanken-Taktsignal liefert, das das um eine
Vorderflankenverzögerung verzögerte Eingangstaktsignal repräsentiert, wobei die Nonius-
Takteinstellschaltung außerdem eine Rückflanken-Verzögerungsschaltung
(4104) enthält, die das Vorderflanken-Taktsignal empfängt und ein Rückflanken-Taktsignal
liefert, welches das um eine Rückflankenverzögerung
verzögerte Eingangstaktsignal repräsentiert; und
eine flankengetriggerte Schaltung (64, 68, 72), die Daten und die
Vorderflanken- und Rückflanken-Taktsignale empfängt und bei der Vorderflanke
des Vorderflanken-Taktsignals und bei der Rückflanke des Rückflanken-
Taktsignals Daten speichert.
12. Speichersystem nach Anspruch 11, bei dem die Speichersteuerung (22;
122; 222) die Vorderflanken- und Rückflankenverzögerung dadurch
programmiert, dass sie Befehle an die mehreren Speichermodule (24, 26; 124,
126; 224, 226) sendet.
13. Speichersystem nach Anspruch 11, bei dem die mehreren Speichermodule
(24, 26; 124, 126; 224, 226) jeweils mindestens einen dynamischen
Schreib-/Lesespeicher (142a ... m; 146a ... m; 76) enthalten.
14. Speichersystem (20; 120; 220), umfassend:
eine Speichersteuerung (22; 122; 222);
mehrere Speichermodule (24, 26; 124; 126; 224, 226) zum Speichern von
Daten;
einen Datenbus (32; 132; 232) zum Übertragen von Schreibdaten von der
Speichersteuerung (22; 122; 222) zu den mehreren Speichermodulen und
zum Übertragen von Lesedaten von den mehreren Speichermodulen zu
der Speichersteuerung (22; 122; 222);
einen Befehlsbus (28; 128; 228), der Befehle von der Speichersteuerung zu
den mehreren Speichermodulen (24, 26; 124, 126; 224; 226) überträgt;
eine Taktleitung (30; 130; 230) zum Übertragen eines Eingangstaktsignals
von der Speichersteuerung (22; 122; 222) zu den mehreren
Speichermodulen; und
wobei jedes Speichermodul enthält:
eine Nonius-Takteinstellschaltung (66, 70, 74) mit einer Rückflanken-
Verzögerungsschaltung, die das Eingangstaktsignal empfängt und ein
Rückflanken-Taktsignal liefert, welches das um eine
Rückflankenverzögerung verzögerte Eingangstaktsignal repräsentiert, wobei die Nonius-
Takteinstellschaltung außerdem eine
Vorderflanken-Verzögerungsschaltung enthält, die das Rückflanken-Taktsignal empfängt und ein
Vorderflanken-Taktsignal liefert, welches das um eine Vorderflankenverzögerung
verzögerte Eingangstaktsignal repräsentiert; und
eine flankengetriggerte Schaltung (64, 68, 72), die Daten und die
Vorderflanken- und Rückflanken-Taktsignale empfängt und bei der Vorderflanke
des Vorderflanken-Taktsignals und bei der Rückflanke des Rückflanken-
Taktsignals Daten speichert.
15. Speichersystem nach Anspruch 14, bei dem die Speichersteuerung die
Vorderflanken- und die Rückflankenverzögerung dadurch programmiert,
dass sie Befehle an die mehreren Speichermodule sendet.
16. Speichersystem nach Anspruch 14, bei dem die mehreren Speichermodule
(24, 26; 124, 126; 224, 226) jeweils mindestens einen dynamischen
Schreib-/Lesespeicher (142a ... m; 146a ... m; 76) enthalten.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/759,351 US6115318A (en) | 1996-12-03 | 1996-12-03 | Clock vernier adjustment |
PCT/US1997/022001 WO1998025345A1 (en) | 1996-12-03 | 1997-12-03 | Clock vernier adjustment |
Publications (2)
Publication Number | Publication Date |
---|---|
DE69716112D1 DE69716112D1 (de) | 2002-11-07 |
DE69716112T2 true DE69716112T2 (de) | 2003-05-28 |
Family
ID=25055332
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
DE69716112T Expired - Lifetime DE69716112T2 (de) | 1996-12-03 | 1997-12-03 | Taktanpassung mit feinregelung |
Country Status (8)
Country | Link |
---|---|
US (1) | US6115318A (de) |
EP (1) | EP0943177B1 (de) |
JP (1) | JP2001505693A (de) |
KR (1) | KR100435612B1 (de) |
AT (1) | ATE225581T1 (de) |
AU (1) | AU5513998A (de) |
DE (1) | DE69716112T2 (de) |
WO (1) | WO1998025345A1 (de) |
Families Citing this family (51)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6088774A (en) * | 1996-09-20 | 2000-07-11 | Advanced Memory International, Inc. | Read/write timing for maximum utilization of bidirectional read/write bus |
US6173432B1 (en) | 1997-06-20 | 2001-01-09 | Micron Technology, Inc. | Method and apparatus for generating a sequence of clock signals |
US6101197A (en) * | 1997-09-18 | 2000-08-08 | Micron Technology, Inc. | Method and apparatus for adjusting the timing of signals over fine and coarse ranges |
US6067594A (en) * | 1997-09-26 | 2000-05-23 | Rambus, Inc. | High frequency bus system |
US6401167B1 (en) | 1997-10-10 | 2002-06-04 | Rambus Incorporated | High performance cost optimized memory |
JP3259764B2 (ja) * | 1997-11-28 | 2002-02-25 | 日本電気株式会社 | 半導体記憶装置 |
US6330627B1 (en) | 1998-01-20 | 2001-12-11 | Kabushiki Kaisha Toshiba | System for fast data transfer between memory modules and controller using two clock lines each having a go line portion and a return line portion |
JPH11328961A (ja) * | 1998-05-21 | 1999-11-30 | Fujitsu Ltd | 電子回路装置及びインタフェース回路 |
US6349399B1 (en) | 1998-09-03 | 2002-02-19 | Micron Technology, Inc. | Method and apparatus for generating expect data from a captured bit pattern, and memory device using same |
US6470060B1 (en) | 1999-03-01 | 2002-10-22 | Micron Technology, Inc. | Method and apparatus for generating a phase dependent control signal |
KR100301054B1 (ko) * | 1999-04-07 | 2001-10-29 | 윤종용 | 데이터 입출력 버스의 전송 데이터율을 향상시키는 반도체 메모리장치 및 이를 구비하는 메모리 모듈 |
KR100318264B1 (ko) * | 1999-06-28 | 2001-12-24 | 박종섭 | 패킷명령어 구동형 메모리소자의 로드신호 발생회로 |
US6446180B2 (en) * | 1999-07-19 | 2002-09-03 | Micron Technology, Inc. | Memory device with synchronized output path |
US6643787B1 (en) | 1999-10-19 | 2003-11-04 | Rambus Inc. | Bus system optimization |
US6646953B1 (en) | 2000-07-06 | 2003-11-11 | Rambus Inc. | Single-clock, strobeless signaling system |
US6681272B1 (en) * | 1999-10-20 | 2004-01-20 | Applied Micro Circuits Corporation | Elastic store circuit with static phase offset |
US6629251B1 (en) * | 1999-10-20 | 2003-09-30 | Applied Micro Circuits Corporation | Elastic store circuit with vernier clock delay |
JP4675442B2 (ja) * | 1999-11-02 | 2011-04-20 | 富士通セミコンダクター株式会社 | メモリデバイス |
US6647507B1 (en) * | 1999-12-31 | 2003-11-11 | Intel Corporation | Method for improving a timing margin in an integrated circuit by setting a relative phase of receive/transmit and distributed clock signals |
US6910146B2 (en) * | 1999-12-31 | 2005-06-21 | Intel Corporation | Method and apparatus for improving timing margin in an integrated circuit as determined from recorded pass/fail indications for relative phase settings |
DE10004108C1 (de) * | 2000-01-31 | 2001-08-09 | Infineon Technologies Ag | Schaltungsanordnung zur Generierung eines Ausgangs-Taktsignals mit optimierter Signalgenerierungszeit |
JP2002082830A (ja) * | 2000-02-14 | 2002-03-22 | Mitsubishi Electric Corp | インターフェイス回路 |
JP3757757B2 (ja) * | 2000-05-18 | 2006-03-22 | 株式会社日立製作所 | リード優先メモリシステム |
US6807613B1 (en) * | 2000-08-21 | 2004-10-19 | Mircon Technology, Inc. | Synchronized write data on a high speed memory bus |
JP4652562B2 (ja) * | 2000-12-26 | 2011-03-16 | キヤノン株式会社 | メモリ制御装置 |
US7313715B2 (en) * | 2001-02-09 | 2007-12-25 | Samsung Electronics Co., Ltd. | Memory system having stub bus configuration |
US6747474B2 (en) * | 2001-02-28 | 2004-06-08 | Intel Corporation | Integrated circuit stubs in a point-to-point system |
US6434082B1 (en) * | 2001-03-13 | 2002-08-13 | International Business Machines Corporation | Clocked memory device that includes a programming mechanism for setting write recovery time as a function of the input clock |
US6675272B2 (en) | 2001-04-24 | 2004-01-06 | Rambus Inc. | Method and apparatus for coordinating memory operations among diversely-located memory components |
US8391039B2 (en) | 2001-04-24 | 2013-03-05 | Rambus Inc. | Memory module with termination component |
US6570813B2 (en) | 2001-05-25 | 2003-05-27 | Micron Technology, Inc. | Synchronous mirror delay with reduced delay line taps |
JP4812976B2 (ja) * | 2001-07-30 | 2011-11-09 | エルピーダメモリ株式会社 | レジスタ、メモリモジュール及びメモリシステム |
JP2003044349A (ja) * | 2001-07-30 | 2003-02-14 | Elpida Memory Inc | レジスタ及び信号生成方法 |
DE10149031A1 (de) * | 2001-10-05 | 2003-04-24 | Infineon Technologies Ag | Speichervorrichtung |
DE10154505B4 (de) * | 2001-11-07 | 2006-11-16 | Infineon Technologies Ag | Speichervorrichtung und Verfahren zum Zugriff auf ein Speichermodul |
US7071749B2 (en) * | 2002-03-25 | 2006-07-04 | Aeroflex Colorado Springs Inc. | Error correcting latch |
JP4159415B2 (ja) | 2002-08-23 | 2008-10-01 | エルピーダメモリ株式会社 | メモリモジュール及びメモリシステム |
US6920187B2 (en) | 2002-10-02 | 2005-07-19 | Micron Technology, Inc. | Constant delay zero standby differential logic receiver and method |
US7234099B2 (en) * | 2003-04-14 | 2007-06-19 | International Business Machines Corporation | High reliability memory module with a fault tolerant address and command bus |
US7168027B2 (en) | 2003-06-12 | 2007-01-23 | Micron Technology, Inc. | Dynamic synchronization of data capture on an optical or other high speed communications link |
US7233185B2 (en) * | 2003-10-10 | 2007-06-19 | Atmel Corporation | Vernier circuit for fine control of sample time |
JP2005267713A (ja) * | 2004-03-17 | 2005-09-29 | Toshiba Corp | ダイナミック型半導体記憶装置 |
US7301831B2 (en) | 2004-09-15 | 2007-11-27 | Rambus Inc. | Memory systems with variable delays for write data signals |
US7542322B2 (en) * | 2004-09-30 | 2009-06-02 | Intel Corporation | Buffered continuous multi-drop clock ring |
KR100892647B1 (ko) * | 2007-08-13 | 2009-04-09 | 주식회사 하이닉스반도체 | 반도체 메모리 장치의 클럭 생성 회로 |
JP5305543B2 (ja) * | 2007-12-21 | 2013-10-02 | ラムバス・インコーポレーテッド | メモリシステムの書き込みタイミングを較正する方法および装置 |
JP5268392B2 (ja) * | 2008-03-07 | 2013-08-21 | パナソニック株式会社 | メモリデバイス及びメモリシステム並びにメモリシステムにおけるアクセスタイミング調整方法 |
JP2009237678A (ja) * | 2008-03-26 | 2009-10-15 | Fujitsu Microelectronics Ltd | メモリコントローラデバイス、メモリコントローラデバイスの制御方法およびデータ受信デバイス |
DE102012222357A1 (de) * | 2012-12-05 | 2014-06-05 | Robert Bosch Gmbh | Inter-Integrated-Circuit-Slave-Schnittstelle und Verfahren zum Betrieb einerInter-Integrated-Circuit-Slave-Schnittstelle |
US11962306B2 (en) | 2021-06-29 | 2024-04-16 | Nvidia Corporation | Clock anomaly detection |
US12079028B2 (en) * | 2022-01-31 | 2024-09-03 | Nvidia Corporation | Fast clock detection |
Family Cites Families (116)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3633174A (en) * | 1970-04-14 | 1972-01-04 | Us Navy | Memory system having self-adjusting strobe timing |
US4096402A (en) * | 1975-12-29 | 1978-06-20 | Mostek Corporation | MOSFET buffer for TTL logic input and method of operation |
US4077016A (en) * | 1977-02-22 | 1978-02-28 | Ncr Corporation | Apparatus and method for inhibiting false locking of a phase-locked loop |
US4404474A (en) * | 1981-02-06 | 1983-09-13 | Rca Corporation | Active load pulse generating circuit |
US4481625A (en) * | 1981-10-21 | 1984-11-06 | Elxsi | High speed data bus system |
US4511846A (en) * | 1982-05-24 | 1985-04-16 | Fairchild Camera And Instrument Corporation | Deskewing time-critical signals in automatic test equipment |
US4514647A (en) * | 1983-08-01 | 1985-04-30 | At&T Bell Laboratories | Chipset synchronization arrangement |
US4687951A (en) * | 1984-10-29 | 1987-08-18 | Texas Instruments Incorporated | Fuse link for varying chip operating parameters |
US4600895A (en) * | 1985-04-26 | 1986-07-15 | Minnesota Mining And Manufacturing Company | Precision phase synchronization of free-running oscillator output signal to reference signal |
US4638187A (en) * | 1985-10-01 | 1987-01-20 | Vtc Incorporated | CMOS output buffer providing high drive current with minimum output signal distortion |
GB2184622B (en) * | 1985-12-23 | 1989-10-18 | Philips Nv | Outputbuffer and control circuit providing limited current rate at the output |
US4773085A (en) * | 1987-06-12 | 1988-09-20 | Bell Communications Research, Inc. | Phase and frequency detector circuits |
US5086500A (en) * | 1987-08-07 | 1992-02-04 | Tektronix, Inc. | Synchronized system by adjusting independently clock signals arriving at a plurality of integrated circuits |
DE3855492T2 (de) * | 1987-08-07 | 1997-01-09 | Tektronix Inc | Hochgeschwindigkeitsrechner mit beschränktem Befehlssatz, der in mehrere Schaltungen aufgeteilt ist |
US4893087A (en) * | 1988-01-07 | 1990-01-09 | Motorola, Inc. | Low voltage and low power frequency synthesizer |
KR0141494B1 (ko) * | 1988-01-28 | 1998-07-15 | 미다 가쓰시게 | 레벨시프트회로를 사용한 고속센스 방식의 반도체장치 |
US4902986B1 (en) * | 1989-01-30 | 1998-09-01 | Credence Systems Corp | Phased locked loop to provide precise frequency and phase tracking of two signals |
US5020023A (en) * | 1989-02-23 | 1991-05-28 | International Business Machines Corporation | Automatic vernier synchronization of skewed data streams |
US4958088A (en) * | 1989-06-19 | 1990-09-18 | Micron Technology, Inc. | Low power three-stage CMOS input buffer with controlled switching |
IT1236578B (it) | 1989-07-04 | 1993-03-16 | Ind Face Standard S P A Milano | Dispositivo per la trasformazione di un flip flop di tipo d in un flip flop denominato di tipo b in grado di campionare i dati sui fronti di salita e sui fronti di discesa del segnale di clock. |
US5165046A (en) * | 1989-11-06 | 1992-11-17 | Micron Technology, Inc. | High speed CMOS driver circuit |
JP2671538B2 (ja) * | 1990-01-17 | 1997-10-29 | 松下電器産業株式会社 | 入力バッファ回路 |
JP2787725B2 (ja) * | 1990-02-14 | 1998-08-20 | 第一電子工業株式会社 | データ・クロックのタイミング合わせ回路 |
US5408640A (en) * | 1990-02-21 | 1995-04-18 | Digital Equipment Corporation | Phase delay compensator using gating signal generated by a synchronizer for loading and shifting of bit pattern to produce clock phases corresponding to frequency changes |
US5239206A (en) * | 1990-03-06 | 1993-08-24 | Advanced Micro Devices, Inc. | Synchronous circuit with clock skew compensating function and circuits utilizing same |
US5023488A (en) | 1990-03-30 | 1991-06-11 | Xerox Corporation | Drivers and receivers for interfacing VLSI CMOS circuits to transmission lines |
US5243703A (en) * | 1990-04-18 | 1993-09-07 | Rambus, Inc. | Apparatus for synchronously generating clock signals in a data processing system |
IL96808A (en) * | 1990-04-18 | 1996-03-31 | Rambus Inc | Introductory / Origin Circuit Agreed Using High-Performance Brokerage |
US5038115A (en) * | 1990-05-29 | 1991-08-06 | Myers Glen A | Method and apparatus for frequency independent phase tracking of input signals in receiving systems and the like |
US5134311A (en) * | 1990-06-07 | 1992-07-28 | International Business Machines Corporation | Self-adjusting impedance matching driver |
US5122690A (en) * | 1990-10-16 | 1992-06-16 | General Electric Company | Interface circuits including driver circuits with switching noise reduction |
US5257294A (en) * | 1990-11-13 | 1993-10-26 | National Semiconductor Corporation | Phase-locked loop circuit and method |
TW198135B (de) * | 1990-11-20 | 1993-01-11 | Oki Electric Ind Co Ltd | |
US5128563A (en) * | 1990-11-28 | 1992-07-07 | Micron Technology, Inc. | CMOS bootstrapped output driver method and circuit |
US5281865A (en) * | 1990-11-28 | 1994-01-25 | Hitachi, Ltd. | Flip-flop circuit |
US5150186A (en) * | 1991-03-06 | 1992-09-22 | Micron Technology, Inc. | CMOS output pull-up driver |
US5128560A (en) * | 1991-03-22 | 1992-07-07 | Micron Technology, Inc. | Boosted supply output driver circuit for driving an all N-channel output stage |
US5220208A (en) * | 1991-04-29 | 1993-06-15 | Texas Instruments Incorporated | Circuitry and method for controlling current in an electronic circuit |
US5256989A (en) * | 1991-05-03 | 1993-10-26 | Motorola, Inc. | Lock detection for a phase lock loop |
US5212601A (en) * | 1991-05-03 | 1993-05-18 | Western Digital Corporation | Disk drive data synchronizer with window shift synthesis |
US5194765A (en) * | 1991-06-28 | 1993-03-16 | At&T Bell Laboratories | Digitally controlled element sizing |
US5276642A (en) * | 1991-07-15 | 1994-01-04 | Micron Technology, Inc. | Method for performing a split read/write operation in a dynamic random access memory |
KR970005124B1 (ko) * | 1991-08-14 | 1997-04-12 | 가부시끼가이샤 아드반테스트 | 가변지연회로 |
US5465076A (en) * | 1991-10-04 | 1995-11-07 | Nippondenso Co., Ltd. | Programmable delay line programmable delay circuit and digital controlled oscillator |
US5283631A (en) * | 1991-11-01 | 1994-02-01 | Hewlett-Packard Co. | Programmable capacitance delay element having inverters controlled by adjustable voltage to offset temperature and voltage supply variations |
US5498990A (en) * | 1991-11-05 | 1996-03-12 | Monolithic System Technology, Inc. | Reduced CMOS-swing clamping circuit for bus lines |
US5295164A (en) * | 1991-12-23 | 1994-03-15 | Apple Computer, Inc. | Apparatus for providing a system clock locked to an external clock over a wide range of frequencies |
DE4206082C1 (de) * | 1992-02-27 | 1993-04-08 | Siemens Ag, 8000 Muenchen, De | |
US5355391A (en) * | 1992-03-06 | 1994-10-11 | Rambus, Inc. | High speed bus system |
DE4390991T1 (de) * | 1992-03-06 | 1995-02-23 | Rambus Inc | Verfahren und Schaltungsanordnung zum Minimieren der Takt-Daten-Schieflage in einem Bussystem |
US5278460A (en) * | 1992-04-07 | 1994-01-11 | Micron Technology, Inc. | Voltage compensating CMOS input buffer |
US5390308A (en) * | 1992-04-15 | 1995-02-14 | Rambus, Inc. | Method and apparatus for address mapping of dynamic random access memory |
US5254883A (en) * | 1992-04-22 | 1993-10-19 | Rambus, Inc. | Electrical current source circuitry for a bus |
US5265218A (en) * | 1992-05-19 | 1993-11-23 | Sun Microsystems, Inc. | Bus architecture for integrated data and video memory |
US5317202A (en) * | 1992-05-28 | 1994-05-31 | Intel Corporation | Delay line loop for 1X on-chip clock generation with zero skew and 50% duty cycle |
US5485490A (en) * | 1992-05-28 | 1996-01-16 | Rambus, Inc. | Method and circuitry for clock synchronization |
US5268639A (en) * | 1992-06-05 | 1993-12-07 | Rambus, Inc. | Testing timing parameters of high speed integrated circuit devices |
US5274276A (en) * | 1992-06-26 | 1993-12-28 | Micron Technology, Inc. | Output driver circuit comprising a programmable circuit for determining the potential at the output node and the method of implementing the circuit |
US5473274A (en) * | 1992-09-14 | 1995-12-05 | Nec America, Inc. | Local clock generator |
FR2696061B1 (fr) * | 1992-09-22 | 1994-12-02 | Rainard Jean Luc | Procédé pour retarder temporellement un signal et circuit à retard correspondant. |
EP0596657A3 (de) * | 1992-11-05 | 1994-12-07 | American Telephone & Telegraph | Normalisierung der sichtbaren Fortpflanzungsverzögerung. |
US5311481A (en) * | 1992-12-17 | 1994-05-10 | Micron Technology, Inc. | Wordline driver circuit having a directly gated pull-down device |
JP2792801B2 (ja) * | 1992-12-28 | 1998-09-03 | 三菱電機株式会社 | 半導体集積回路並びにその設計方法及び製造方法 |
US5339408A (en) * | 1992-12-30 | 1994-08-16 | Digital Equipment Corporation | Method and apparatus for reducing checking costs in fault tolerant processors |
US5347177A (en) * | 1993-01-14 | 1994-09-13 | Lipp Robert J | System for interconnecting VLSI circuits with transmission line characteristics |
US5544203A (en) * | 1993-02-17 | 1996-08-06 | Texas Instruments Incorporated | Fine resolution digital delay line with coarse and fine adjustment stages |
JPH06273423A (ja) | 1993-03-18 | 1994-09-30 | Daikin Ind Ltd | 測定装置の測定時間短縮方法 |
US5488321A (en) * | 1993-04-07 | 1996-01-30 | Rambus, Inc. | Static high speed comparator |
US5347179A (en) * | 1993-04-15 | 1994-09-13 | Micron Semiconductor, Inc. | Inverting output driver circuit for reducing electron injection into the substrate |
US5337285A (en) * | 1993-05-21 | 1994-08-09 | Rambus, Inc. | Method and apparatus for power control in devices |
AU6988494A (en) * | 1993-05-28 | 1994-12-20 | Rambus Inc. | Method and apparatus for implementing refresh in a synchronous dram system |
US5506814A (en) * | 1993-05-28 | 1996-04-09 | Micron Technology, Inc. | Video random access memory device and method implementing independent two WE nibble control |
JP2636677B2 (ja) * | 1993-06-02 | 1997-07-30 | 日本電気株式会社 | 半導体集積回路 |
US5430676A (en) * | 1993-06-02 | 1995-07-04 | Rambus, Inc. | Dynamic random access memory system |
US5428311A (en) * | 1993-06-30 | 1995-06-27 | Sgs-Thomson Microelectronics, Inc. | Fuse circuitry to control the propagation delay of an IC |
US5473639A (en) * | 1993-07-26 | 1995-12-05 | Hewlett-Packard Company | Clock recovery apparatus with means for sensing an out of lock condition |
JP3232351B2 (ja) * | 1993-10-06 | 2001-11-26 | 三菱電機株式会社 | デジタル回路装置 |
US5451898A (en) * | 1993-11-12 | 1995-09-19 | Rambus, Inc. | Bias circuit and differential amplifier having stabilized output swing |
JP3547466B2 (ja) | 1993-11-29 | 2004-07-28 | 株式会社東芝 | メモリ装置、シリアル‐パラレルデータ変換回路、メモリ装置にデータを書き込む方法、およびシリアル‐パラレルデータ変換方法 |
JPH07153286A (ja) * | 1993-11-30 | 1995-06-16 | Sony Corp | 半導体不揮発性記憶装置 |
US5400283A (en) * | 1993-12-13 | 1995-03-21 | Micron Semiconductor, Inc. | RAM row decode circuitry that utilizes a precharge circuit that is deactivated by a feedback from an activated word line driver |
KR0132504B1 (ko) * | 1993-12-21 | 1998-10-01 | 문정환 | 데이타 출력버퍼 |
US5579326A (en) * | 1994-01-31 | 1996-11-26 | Sgs-Thomson Microelectronics, Inc. | Method and apparatus for programming signal timing |
AU1841895A (en) * | 1994-02-15 | 1995-08-29 | Rambus Inc. | Delay-locked loop |
US5424672A (en) * | 1994-02-24 | 1995-06-13 | Micron Semiconductor, Inc. | Low current redundancy fuse assembly |
US5440514A (en) * | 1994-03-08 | 1995-08-08 | Motorola Inc. | Write control for a memory using a delay locked loop |
US5554946A (en) * | 1994-04-08 | 1996-09-10 | International Business Machines Corporation | Timing signal generator |
US5497115A (en) | 1994-04-29 | 1996-03-05 | Mosaid Technologies Incorporated | Flip-flop circuit having low standby power for driving synchronous dynamic random access memory |
JP3553639B2 (ja) * | 1994-05-12 | 2004-08-11 | アジレント・テクノロジーズ・インク | タイミング調整回路 |
US5457407A (en) * | 1994-07-06 | 1995-10-10 | Sony Electronics Inc. | Binary weighted reference circuit for a variable impedance output buffer |
JP3537500B2 (ja) | 1994-08-16 | 2004-06-14 | バー−ブラウン・コーポレーション | インバータ装置 |
JP3176228B2 (ja) * | 1994-08-23 | 2001-06-11 | シャープ株式会社 | 半導体記憶装置 |
GB9417266D0 (en) * | 1994-08-26 | 1994-10-19 | Inmos Ltd | Testing a non-volatile memory |
JPH08139572A (ja) * | 1994-11-07 | 1996-05-31 | Mitsubishi Electric Corp | ラッチ回路 |
US5497127A (en) * | 1994-12-14 | 1996-03-05 | David Sarnoff Research Center, Inc. | Wide frequency range CMOS relaxation oscillator with variable hysteresis |
US5577236A (en) * | 1994-12-30 | 1996-11-19 | International Business Machines Corporation | Memory controller for reading data from synchronous RAM |
US5489864A (en) * | 1995-02-24 | 1996-02-06 | Intel Corporation | Delay interpolation circuitry |
US5578940A (en) * | 1995-04-04 | 1996-11-26 | Rambus, Inc. | Modular bus with single or double parallel termination |
US5621690A (en) * | 1995-04-28 | 1997-04-15 | Intel Corporation | Nonvolatile memory blocking architecture and redundancy |
JP3386924B2 (ja) | 1995-05-22 | 2003-03-17 | 株式会社日立製作所 | 半導体装置 |
US5581197A (en) * | 1995-05-31 | 1996-12-03 | Hewlett-Packard Co. | Method of programming a desired source resistance for a driver stage |
US5576645A (en) * | 1995-06-05 | 1996-11-19 | Hughes Aircraft Company | Sample and hold flip-flop for CMOS logic |
US5636173A (en) | 1995-06-07 | 1997-06-03 | Micron Technology, Inc. | Auto-precharge during bank selection |
JP3403551B2 (ja) | 1995-07-14 | 2003-05-06 | 沖電気工業株式会社 | クロック分配回路 |
US5621340A (en) * | 1995-08-02 | 1997-04-15 | Rambus Inc. | Differential comparator for amplifying small swing signals to a full swing output |
JP3252666B2 (ja) | 1995-08-14 | 2002-02-04 | 日本電気株式会社 | 半導体記憶装置 |
US5578941A (en) * | 1995-08-23 | 1996-11-26 | Micron Technology, Inc. | Voltage compensating CMOS input buffer circuit |
US5692165A (en) | 1995-09-12 | 1997-11-25 | Micron Electronics Inc. | Memory controller with low skew control signal |
JP3408030B2 (ja) | 1995-09-21 | 2003-05-19 | 日本プレシジョン・サーキッツ株式会社 | 位相比較器 |
US5594690A (en) * | 1995-12-15 | 1997-01-14 | Unisys Corporation | Integrated circuit memory having high speed and low power by selectively coupling compensation components to a pulse generator |
US5636174A (en) | 1996-01-11 | 1997-06-03 | Cirrus Logic, Inc. | Fast cycle time-low latency dynamic random access memories and systems and methods using the same |
US5719508A (en) | 1996-02-01 | 1998-02-17 | Northern Telecom, Ltd. | Loss of lock detector for master timing generator |
US5712580A (en) | 1996-02-14 | 1998-01-27 | International Business Machines Corporation | Linear phase detector for half-speed quadrature clocking architecture |
US5627791A (en) | 1996-02-16 | 1997-05-06 | Micron Technology, Inc. | Multiple bank memory with auto refresh to specified bank |
US5668763A (en) | 1996-02-26 | 1997-09-16 | Fujitsu Limited | Semiconductor memory for increasing the number of half good memories by selecting and using good memory blocks |
US5621739A (en) * | 1996-05-07 | 1997-04-15 | Intel Corporation | Method and apparatus for buffer self-test and characterization |
-
1996
- 1996-12-03 US US08/759,351 patent/US6115318A/en not_active Expired - Lifetime
-
1997
- 1997-12-03 AT AT97951512T patent/ATE225581T1/de not_active IP Right Cessation
- 1997-12-03 WO PCT/US1997/022001 patent/WO1998025345A1/en active IP Right Grant
- 1997-12-03 EP EP97951512A patent/EP0943177B1/de not_active Expired - Lifetime
- 1997-12-03 DE DE69716112T patent/DE69716112T2/de not_active Expired - Lifetime
- 1997-12-03 JP JP52574298A patent/JP2001505693A/ja active Pending
- 1997-12-03 KR KR10-1999-7004924A patent/KR100435612B1/ko not_active IP Right Cessation
- 1997-12-03 AU AU55139/98A patent/AU5513998A/en not_active Abandoned
Also Published As
Publication number | Publication date |
---|---|
JP2001505693A (ja) | 2001-04-24 |
ATE225581T1 (de) | 2002-10-15 |
WO1998025345A1 (en) | 1998-06-11 |
EP0943177A1 (de) | 1999-09-22 |
DE69716112D1 (de) | 2002-11-07 |
KR100435612B1 (ko) | 2004-06-12 |
AU5513998A (en) | 1998-06-29 |
US6115318A (en) | 2000-09-05 |
EP0943177B1 (de) | 2002-10-02 |
KR20000069287A (ko) | 2000-11-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
DE69716112T2 (de) | Taktanpassung mit feinregelung | |
DE19882418B4 (de) | System einer quellensynchronen Schnittstelle zwischen Master- und Slave-Einrichtungen und zugehöriges Verfahren | |
DE102005051206B4 (de) | Speichersystem, Halbleiterspeicherbauelement und Abtastsignalerzeugungsverfahren | |
DE69838852T2 (de) | Verfahren und vorrichtung zur kopplung von signalen zwischen zwei schaltungen, in verschiedenen taktbereichen arbeitend | |
DE102006045254B4 (de) | Verzögerungsregelschleife für Hochgeschwindigkeits-Halbleiterspeichervorrichtung | |
DE69805628T2 (de) | Synchroner taktgenerator mit verzögerungsregelschleife | |
DE69120586T2 (de) | Rechnersystem mit synchronem Bus | |
DE60205877T2 (de) | Verfahren zur synchronisation der auslesezeit eines hochgeschwindigkeitsspeichers | |
DE10235739B4 (de) | Register, das auf einem Speichermodul montiert ist sowie Verwendung eines Registers in einem Speichermodul | |
DE69910674T2 (de) | Verzögerungsregelschleife | |
DE19652310C2 (de) | Halbleiterspeichervorrichtung, die ein asynchrones Signal verwendet | |
DE602004007674T3 (de) | Integrierte Schaltung mit bimodalem Daten-Strobe | |
DE69033309T2 (de) | Takterzeugungsschaltung | |
DE69619505T2 (de) | Optimierschaltung und steuerung für eine synchrone speicheranordnung vorzugsweise mit programmierbarer latenzzeit | |
DE10144247B4 (de) | Halbleiterspeicherbauelement und zugehöriges Halbleiterspeichersystem | |
DE69305049T2 (de) | Hochfrequenz- cmos-schaltung mit geringen verbrauch | |
DE60002571T2 (de) | Elastische schnittstelleanornung und verfahren dafür | |
DE10330796B4 (de) | Registergesteuerter Delay Locked Loop mit Beschleunigungsmodus | |
DE19860650B4 (de) | Synchrone Halbleiter-Speichervorrichtung mit einer Chip-Satz-Speichersteuervorrichtung mit Datenausblend-Maskenfunktion | |
DE69325119T2 (de) | Taktsynchronisierter Halbleiterspeicheranordnung und Zugriffsverfahren | |
DE19507562A1 (de) | Synchrone Halbleiterspeichervorrichtung mit einer Schreiblatenzsteuerfunktion | |
DE102004025900A1 (de) | Leselatenz-Steuerschaltung | |
DE69304632T2 (de) | Parallel-Seriell-Umsetzer | |
DE68922984T2 (de) | Programmierbare Zeitsteuerung der Datenübertragung. | |
DE19914986A1 (de) | Vorrichtung zum Verzögern eines Taktsignals |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
8364 | No opposition during term of opposition |