[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

WO1996033499A1 - Inhalts-adressierbarer speicher - Google Patents

Inhalts-adressierbarer speicher Download PDF

Info

Publication number
WO1996033499A1
WO1996033499A1 PCT/EP1995/001460 EP9501460W WO9633499A1 WO 1996033499 A1 WO1996033499 A1 WO 1996033499A1 EP 9501460 W EP9501460 W EP 9501460W WO 9633499 A1 WO9633499 A1 WO 9633499A1
Authority
WO
WIPO (PCT)
Prior art keywords
memory
blocks
line
match
lines
Prior art date
Application number
PCT/EP1995/001460
Other languages
English (en)
French (fr)
Inventor
Klaus Helwig
Christoph Wandel
Original Assignee
International Business Machines Corporation
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by International Business Machines Corporation filed Critical International Business Machines Corporation
Priority to US08/750,765 priority Critical patent/US5870324A/en
Priority to PCT/EP1995/001460 priority patent/WO1996033499A1/de
Priority to JP08531425A priority patent/JP3125884B2/ja
Priority to DE19614443A priority patent/DE19614443A1/de
Publication of WO1996033499A1 publication Critical patent/WO1996033499A1/de

Links

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C8/00Arrangements for selecting an address in a digital store
    • G11C8/12Group selection circuits, e.g. for memory block selection, chip selection, array selection
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C15/00Digital stores in which information comprising one or more characteristic parts is written into the store and in which information is read-out by searching for one or more of these characteristic parts, i.e. associative or content-addressed stores
    • G11C15/04Digital stores in which information comprising one or more characteristic parts is written into the store and in which information is read-out by searching for one or more of these characteristic parts, i.e. associative or content-addressed stores using semiconductor elements

Definitions

  • the invention relates to a content addressable memory (CAM) according to the preamble of claim 1.
  • CAM content addressable memory
  • CAM content-addressable memories
  • the addressing of a memory cell in a CAM does not take place via its address. Rather, a data word is entered into a CAM, which does not represent an address, but a possible content of a memory line in the CAM. If there is a memory line in the CAM in which the entered data word is stored, the CAM emits a corresponding signal. Examples of different embodiments of CAMs and their application can be found in
  • the object of the invention is therefore to create an improved CAM.
  • the invention has for its object to provide a CAM that has a shorter access time.
  • the logical memory arrays of a CAM are not identical to the physical memory arrays of the CAM as they are integrated on the chip surface. Rather, the logical storage arrays are logically divided into blocks. One block each of a logical memory array is integrated with the corresponding blocks of other memory arrays to form a physical memory array. This makes it possible to minimize both the line lengths of the signal connections of the CAM and of the internal signal lines of the CAM and, as a result, to increase the processing speed.
  • FIG. 2 shows a schematic overview representation of a CAM according to the invention
  • Fig. 3 consists of 2 logical blocks
  • Memory array of a CAM according to the invention. 4 shows the circuit of a memory cell and the associated signal lines;
  • FIG. 6 shows a schematic representation of the correspondence between logical memory arrays and physical memory arrays in a CAM according to the invention with three logical memory arrays, each of which is divided into three blocks.
  • the CAM known from the prior art, shown in FIG. 1, is divided into the two memory arrays DO and D1.
  • the memory arrays DO and Dl are essentially identical; the memory arrays DO and Dl each have 128 memory lines, each memory line being able to store a data word with a length of 24 bits.
  • the memory arrays DO and D1 are each electrically connected to the input lines BO - B23.
  • the input lines BO-B23 are used for the transmission of write data of the word length 24 bits.
  • the memory array DO has a signal input WRITE 1 and the memory array D1 has a signal input WRITE 3.
  • the signal inputs WRITE are used 1 and WRITE 3 to determine in which of the storage arrays DO or Dl the data word is to be stored.
  • the memory arrays DO and D1 are each electrically connected to the comparison lines CDO - CD23.
  • a 24-bit data word can be transmitted to the CAM via the comparison lines CDO-CD23.
  • a data word transmitted to the CAM via the comparison lines CDO-CD23 is compared with the data word in the CAM stored data words compared. If all 24 bits of a stored data word match the comparison word, the CAM generates a match signal.
  • the match signal therefore indicates that the comparison word transmitted via the lines CDO-CD23 had already been stored in the CAM as a data word before the comparison process.
  • the match signal is stored in one of the read / write memories EO or E1 belonging to the CAM.
  • the match signal is stored in the read / write memory EO if the data word matching the comparison word is in the memory array DO, otherwise in the read / write memory E1 belonging to the memory array D1.
  • the memory address of the match signal within the read / write memory EO or E1 is representative of the address of that line in the memory array DO or DI whose data word matches the comparison word.
  • the read / write memories EO and E1 can be read out via their outputs OutO and Outl in order to evaluate the results of a comparison.
  • the individual memory lines of the memory arrays DO and D1 are symbolized in FIG. 1 by their corresponding word lines.
  • the CAM shown in Figure 2 consists of the memory arrays DO 'and Dl'.
  • the memory array DO 'contains the two blocks DOO and D10.
  • the block DOO corresponds to the bit positions 0-11 of the memory array DO in FIG. 1.
  • the block D10 corresponds to the bit positions 0-11 in the memory array D1 in FIG. 1.
  • the memory array D1 'contains the blocks D01 and DU, each corresponding to the bit positions 12-23 of the memory arrays DO and Dl of FIG. 1.
  • a 24-bit line for example of the memory array DO in FIG. 1, is therefore divided into two halves in the CAM in FIG. Bit positions 0-11 are realized in block DOO and bit positions 12-23 in block D01, which each belong to different memory arrays DO 'and Dl'.
  • the memory arrays DO 'and Dl' are each electrical via bit line drivers and write heads SO 'and Sl' with the input lines BO - B1 and the comparison lines CDO - CDU or with the input lines B12 - B23 and the comparison lines CD12 - CD23 connected.
  • a write / read memory block El * belongs to the memory array D1 '.
  • the read / write memory blocks EO 'and El' each have enable circuits, which each write to one Allow read / write cell of one of the blocks DO * or El '.
  • Each of the blocks DOO, DOl, DIO and DU is connected to the enable circuits via corresponding match lines MATCHOO, MATCH01, MATCH10 and MATCH11.
  • Each line with 12 bit positions of one of the blocks DOO, DOl, DIO and DU has a separate match line. If a match is found between the corresponding bit positions of a comparison word and the bit positions of one of the blocks, a signal is output on the corresponding match line that indicates the match.
  • the match lines of those blocks which logically form a memory array but are actually arranged in different memory arrays DO 'and Dl' serve as inputs to the same enable circuit in each case of one of the read / write memory blocks.
  • match lines MATCHOO and MATCH01 of the blocks DOO and DO1 are on the corresponding enable circuits of the read / write memory block EO 'and the match lines MATCH10 and MATCH11 of the blocks DIO and DU are on the corresponding enable circuits of the read / write memory block E1 'connected.
  • the match lines MATCHOO and MATCH01, or MATCH10 and MATCH11 are logically AND-linked with each other in the enable circuits.
  • the CAM according to the invention shown in FIG. 2 therefore has 2 logical memory arrays, which consist of the blocks DOO and DO1, or the blocks DIO and DU.
  • the logically related blocks are, however, separated from one another in different memory arrays DO 'and Dl 'arranged on the chip surface. This has the advantage that 24 input and comparison lines do not have to be routed to each of the two memory arrays DO 'and Dl', as is the case with the CAM shown in FIG.
  • match lines MATCH10 and MATCH11 are shortened compared to the prior art, since they only cover 11 bit positions in each case and the required line length up to the read / write memory block El 'is correspondingly shorter.
  • FIG. 3 schematically shows a possible implementation of the memory array DO 'shown in FIG. 2.
  • the memory array DO ' consists of 128 memory rows. Each of the 128 memory rows has 24 memory cells Z.
  • the blocks DOO and DIO, which logically belong to different memory arrays DO and D1, are implemented within the memory array DO '.
  • Line 1 of the memory array DO * is used to store bit positions 0 - 11 of the first line of blocks DOO and DIO. The same applies to the other lines of the memory array DO '.
  • the memory cells of the blocks DOO or DIO are arranged alternately within a row. This means that a memory cell Z for a bit position of the block DOO is spatially followed by the corresponding memory cell Z for the same bit position of the block DIO. This results in the following sequences of memory cells for row 1 of the memory array DO ', the memory cell for bit 0 of the block DOO being designated, for example, by Z (BO, DOO):
  • Each of the columns of the memory array DO ' is connected to one of the associated comparison lines CD.
  • column 1 is electrically connected to the comparison line CDO.
  • Column 2 of the memory array DO ', which is used to store the 1st bit of data words of the block DIO, is also electrically connected to the corresponding comparison line CDO.
  • the memory array DO ' has a write head with a bit line driver, for example SO'1, for every two adjacent columns, for example columns 1 and 2.
  • a write head with bit line driver SO 'always belongs to 2 adjacent columns of the memory array DO', which are used to store the same bit position in different ones of the blocks DOO or DIO.
  • the write heads and bit line drivers SO ' are connected to the signal inputs WRITE1 and WRITE3 of the memory array DO', which correspond to the corresponding signal inputs WRITE1 and WRITE3 in FIG. Furthermore, each write head SO 'is connected to a corresponding input line B.
  • the write head SO'1 is connected to the input line BO, which is used to transmit the 1st bit position, and accordingly the write head SO'2 is connected to the input line B1 for the 2nd bit position.
  • the first 12 bits of the data word are transferred via the input lines BO-B1 to the corresponding write heads SO'l to SO'11 of the memory array DO '.
  • the data on the input lines BO-B1 are then stored either in the block DOO or in the block DIO. This functionality can be achieved, for example, by a three-state transistor in each of the Print heads SO 'can be realized.
  • the memory array D1 ' which is not shown in FIG. 3, is constructed in accordance with the memory array DO', with the difference that the bit positions 12-23 of the blocks DO1 and DU are provided there. This results in a corresponding saving in line length for the comparison lines CD12-CD23 and the input lines B12-B23 for the memory array D1 '.
  • FIG. 4 shows an example of the structure of a memory cell Z according to the invention, for example cells Z (B0, B00) of the memory array DO ', as shown in FIG. 3.
  • the memory cell itself is constructed as a flip-flop consisting of the 4 transistors T1, T2, T3 and T4.
  • the flip-flop is connected to transistors T5 and T6.
  • the bases of transistors T5 and T6 are connected to word line WL.
  • a terminal of transistor T5 is connected to bit line BL, while a terminal of transistor T6 is connected to complementary bit line BLC.
  • the flip-flop consisting of the 4 transistors T1, T2, T3 and T4, can be described by correspondingly controlling the word line WL and the bit line BL and their complement.
  • a comparison line CD for example the comparison line CDO, if the memory cell Z in FIG. 4 is one of the memory cells Z (BO, DOO) is connected to the line end of a transistor T9, while the complement of the comparison line CD - the line CDC - is connected to a line end of a transistor T7.
  • the base of transistor T9 is connected to the common line end of transistors T3 and T4, while the base of transistor T7 is connected to the common line end of transistors Tl and T2 of the flip-flop.
  • Transistors T8 and T10 are connected in parallel with transistors T7 and T9.
  • the base of transistor T8 is connected to the bases of transistors T1 and T2, while the base of transistor T10 is connected to the bases of transistors T3 and T4 of the flip-flop.
  • the transistors T1, T3, T8 and T10 are transistors of the normally-on type, that is to say transistors which are conductive at a potential of 0 volts at the base.
  • the other transistors shown in FIG. 4 are normally-off transistors, which are not conductive at potential 0 at the base.
  • the transistors T7 and T9 are connected to one another via a line 3.
  • the line 3 is in turn connected via a line 2 to the base of a transistor TU.
  • the signal on line 3 is logic 0 if the comparison date on line CD matches the date stored in memory cell Z; on the contrary, if the date on the comparison line CD does not match the date stored in the flip-flop, the signal on line 3 is logical 1.
  • the signal on line 3 is transmitted via line 2 to the base of transistor TU .
  • One end of the transistor TU is connected to GROUND, the other end to a MATCH line.
  • the MATCH line is uploaded to logic 1 before a comparison operation.
  • the signal level is logically 0 of line 2, so that transistor TU remains non-conductive.
  • Another transistor T12, T13,... Is connected to the MATCH line for each of the cells Z of a row of the block DOO.
  • a match circuit 4 to which the transistors TU, T12, T13, ... belong, is thereby realized.
  • the bases of the transistors T12, T13, ... are each connected via lines 2 'or 2'"to lines 3 corresponding to line 3 of their respective memory cells Z.
  • a match line MATCHOO belongs to each line, which may indicate that the first 12 bits of a comparison word match the first 12 bits of a data word in a line of the memory array DO 'stored in block DO'.
  • both the match line MATCHOO and the match line MATCH01 of the corresponding line are on the Potential logic 1.
  • the match line MATCHOO is connected to the base of a transistor T14 and the match line MATCH01 to the base of a transistor T15.
  • the transistors T14 and T15 are connected to one another.
  • the transistor T15 is also connected to a transistor T16 and the transistor T14 to a normally-on transistor T18.
  • the bases of the transistors T16 and T18 are connected to an enable signal ENABLE.
  • the signals MATCHOO and MATCH01 are logically ANDed via the transistors T14 and T15. Only when both match lines MATCHOO and MATCH01 are logic 1 at a potential, both transistors T14 and T15 become conductive, so that the potential at point PX becomes 0. As a result, the potential at point PY, that is to say at the output of inverter I, then becomes logic 1, so that transistor T17 becomes conductive. The corresponding information is thereby written into the flip-flop 18.
  • the flip-flop 18 is a read / write cell of the read / write memory block EO '. The circuit shown in FIG.
  • the read / write memory block EO ' is implemented for each of the 128 lines of the CAM.
  • the read / write memory block EO ' is thereby implemented by the entirety of the read / write cells.
  • the read / write memory block El ' After completion of a comparison operation, the read / write memory blocks EO * and El 'can then be read out in order to determine whether the information that the comparison data match the stored data of the relevant memory line is stored in one of the flip-flops 18 of one of the lines of the CAM.
  • this information is stored in the read / write memory block EO ', this means that the corresponding data word is in the logical memory array DO, that is to say in the block DOO of the memory array DO' and the block DO1 of the memory array.
  • Arrays Dl ' is located.
  • a match line MATCH does not provide transistors TU, T12, T13, ... for each bit of the data word, but - in the exemplary embodiment in FIG. 4 - only 12 transistors due to the division of the logic memory into two Arrays DO and Dl in 2 blocks DOO, DOl, DIO and DU.
  • the associated reduction in the capacity to be reloaded means a further increase in the processing speed of the CAM.
  • the teaching of the invention is not limited to a CAM with 2 logical memory arrays DO and D1, which are each divided into 2 blocks DOO, DOl and DIO, DU. Rather, the teaching of the invention is applicable to a CAM with any number of X logical memory arrays DO, D1, D2, ....
  • each of the logical memory arrays Di is logically divided into a number Y of blocks Dij.
  • the blocks of the various logical memory arrays which contain the same bit positions within a logical memory array correspond to one another.
  • the corresponding blocks are each physically arranged in a memory array Di ', that is DO', Dl ', D2' on the chip surface. Accordingly, this means that each block of a physical memory array Di 'has a separate match line for each memory line.
  • bit positions of the respective blocks of a memory array are preferably arranged alternately in the rows of the memory array.
  • triples of memory cells are formed in the memory array DO 'in FIG. 6, each of which serves to store the same bit position of different blocks.
  • the other lines of the memory array DO ' have the same structure. The same applies to the memory arrays Dl 'and D2'.
  • the individual memory cell is constructed as in the exemplary embodiment in FIG. 4.
  • the match circuit 4 contains only a number of transistors TU, T12, T13,... Which corresponds to one third of the word width of a data word to be stored in the CAM in FIG. This is because, due to the logical division of the memory arrays into three, each block Dij has only a third of the total word width.
  • the match lines of those Blocks belonging to a logical array are ANDed in accordance with FIG. 5; because only if all match lines of the blocks belonging to a common logical array indicate that the comparison word matches the corresponding bit positions of the respective blocks, is there actually a match between the comparison word and the entire data word.
  • a read / write memory block EO ', El', E2 ' is also provided for each of the memory arrays DO', Dl ', D2'.
  • the inventive division of the logical memory arrays into Y 3 blocks, in accordance with the exemplary embodiment in FIG. 2, again has the advantage that the line lengths of the comparison lines, as well as the input lines and the match lines, are minimized. In addition, the capacities of the match lines are also reduced, since a transistor is not provided on the match line for each bit position.
  • a CAM according to the invention can be used as a cache directory.
  • a cache memory can be used, for example, in connection with a mass memory, in particular a hard disk memory. Those sectors, for example of the hard disk memory, which are frequently accessed are stored in corresponding sectors of the cache memory. If the data that is stored in a sector of the memory is to be accessed, it must first be ascertained whether the data of this sector is present in the cache memory or not. For this purpose, the address of the corresponding sector is entered into the CAM via the compare lines. If the corresponding sector number is stored as a data word in the CAM, this means that the data belonging to the sector number is in the cache memory are saved.
  • the line of the CAM in which the sector number was found represents the corresponding sector number in the cache memory. Accordingly, the input lines B are used to write sector numbers of sectors of the hard disk into the CAM as soon as the data of a memory sector of the hard disk are available in the cache memory.

Landscapes

  • Engineering & Computer Science (AREA)
  • Microelectronics & Electronic Packaging (AREA)
  • Dram (AREA)
  • Static Random-Access Memory (AREA)

Abstract

Die Erfindung betrifft einen Inhalts-adressierbaren Speicher (CAM) mit mehreren logischen Speicher-Arrays Di. Die logischen Speicher-Arrays Di sind in mehrere Blöcke Dij logisch aufgeteilt. Die Blöcke Dij sind zu Speicher-Arrays Di' physikalisch angeordnet und auf der Chip-Oberfläche integriert. Jedes Speicher-Array Di' weist dabei je einen Block Dij der logischen Speicher-Arrays Di auf. Dadurch können die parasitären Kapazitäten des CAM minimiert werden.

Description

B E S C H R E I B U N G
INHALTS-ADRESSIERBARER SPEICHER
Die Erfindung betrifft einen Inhalts-adressierbaren Speicher (CAM = content addressable memory) nach dem Oberbegriff von Patentanspruch 1.
Inhalts-adressierbare Speicher - im folgenden CAM abgekürzt - finden nach dem Stand der Technik vielfältige Verwendungen in elektronischen Schaltungen, insbesondere in Computersystemen- Anders als bei einem gewöhnlichen Speicherbaustein geschieht die Adressierung einer Speicherzelle in einem CAM nicht über deren Adresse. Vielmehr wird ein Datenwort in ein CAM eingegeben, welches keine Adresse darstellt, sondern einen möglichen Inhalt einer Speicherzeile in dem CAM. Gibt es eine Speicherzeile in dem CAM, in der das eingegebene Datenwort gespeichert ist, so gibt das CAM ein entsprechendes Signal ab. Beispiele für unterschiedliche Ausführungsformen von CAMs und deren Anwendung finden sich in
TDB Vol. 37, No. 6B, Juni 94, S. 347 - 348
TDB Vol. 37, No. 4B, April 94, S. 125 - 128
TDB No. 1, Januar 1993, S. 200 - 202
TDB No. 4a, September 1991, S. 154 - 157
TDB No. 10B, März 1991, S. 164 - 168
TDB Dezember 1988, S. 254 - 257
TDB März 1984, S. 5364 - 5366
TDB März 1973, S. 3002 - 3004
TDB Dezember 1973, S. 2217 - 2219
TDB August 1974, S. 882 - 883
TDB September 1974, S. 1058 - 1059
TDB Oktober 1981, S. 2601 - 2603
TDB August 1989, S. 478 - 479 TDB März 1989, S. 461 - 466.
Der Erfindung liegt daher die Aufgabe zugrunde, ein verbessertes CAM zu schaffen. Insbesondere liegt der Erfindung die Aufgabe zugrunde ein CAM zur Verfügung zu stellen, daß eine geringere Zugriffszeit aufweist.
Die Aufgabe der Erfindung wird durch die Merkmale des kennzeichnenden Teils von Patentanspruch 1 gelöst. Danach sind die logischen Speicher-Arrays eines CAM nicht identisch mit den physikalischen Speicher-Arrays des CAM, wie sie auf der Chip-Oberfläche integriert sind. Vielmehr sind die logischen Speicher-Arrays in Blöcke logisch aufgeteilt. Je ein Block eines logischen Speicher-Arrays wird mit den entsprechenden Blöcken anderer Speicher- Arrays zu einem physikalischen Speicher-Array integriert. Dadurch ist es möglich, sowohl die Leitungslängen der Signalanschlüsse des CAM als auch der internen Signalleitungen des CAM zu minimieren und infolge dessen die Verarbeitungsgeschwindigkeit zu erhöhen.
Bevorzugte Ausführungsformen des erfindungsgemäßen CAMs finden sich in den Unteransprüchen.
Ein Ausführungsbeispiel der Erfindung ist in der Zeichnung dargestellt und wird im folgenden näher beschrieben.
Es zeigen
Fig. 1 ein CAM nach dem Stand der Technik;
Fig. 2 eine schematische Übersichtsdarstellung eines erfindungsgemäßen CAMs;
Fig. 3 ein aus 2 logischen Blöcken bestehendes
Speicher-Array eines erfindungsgemäßen CAMs; Fig. 4 die Schaltung einer Speicherzelle und der dazugehörigen Signalleitungen;
Fig. 5 die logische Verknüpfung zweier Match- Leitungen;
Fig. 6 in schematischer Darstellung die Entsprechung von logischen Speicher-Arrays und physikalischen Speicher-Arrays bei einem erfindungsgemäßen CAM mit 3 logischen Speicher- Arrays, die jeweils in 3 Blöcke aufgeteilt sind.
Das aus dem Stand der Technik bekannte, in Figur 1 dargestellte CAM, ist in die beiden Speicher-Arrays DO und Dl aufgeteilt. Die Speicher-Arrays DO und Dl sind im wesentlichen identisch; die Speicher-Arrays DO und Dl haben jeweils 128 Speicherzeilen, wobei jede Speicherzeile ein Datenwort der Länge 24 Bit speichern kann. Die Speicher-Arrays DO und Dl sind jeweils mit den Eingangsleitungen BO - B23 elektrisch verbunden. Die Eingangsleitungen BO - B23 dienen zur Übertragung von Schreibdaten der Wortlängen 24 Bit. Ferner hat das Speicher-Array DO einen Signaleingang WRITE 1 und das Speicher-Array Dl einen Signaleingang WRITE 3. Soll ein Datenwort, das über die Eingangsleitungen BO - B23 zu dem CAM übertragen wird, in dem CAM eingeschrieben werden, so dienen die Signaleingänge WRITE 1 und WRITE 3 dazu, festzulegen, in welchen der Speicher-Arrays DO oder Dl das Datenwort gespeichert werden soll.
Die Speicher-Arrays DO und Dl sind jeweils mit den Vergleichsleitungen CDO - CD23 elektrisch verbunden. Über die Vergleichsleitungen CDO - CD23 kann ein 24 bit¬ breites Datenwort zu dem CAM übertragen werden. Ein über die Vergleichsleitungen CDO - CD23 zu dem CAM übertragenes Datenwort wird mit den in das CAM zuvor eingespeicherten Datenworten verglichen. Stimmen alle 24 Bit eines gespeicherten Datenworts mit dem Vergleichswort überein, erzeugt das CAM ein Match-Signal. Das Match- Signal zeigt also an, daß das über die Leitungen CDO - CD23 übertragene Vergleichswort bereits vor dem Vergleichsvorgang in dem CAM als Datenwort abgespeichert worden war. Das Match-Signal wird in einem der zu dem CAM gehörenden Schreib/Lese-Speicher EO oder El abgespeichert. Das Match-Signal wird in dem Schreib/Lese- Speicher EO abgespeichert, falls sich das mit dem Vergleichswort übereinstimmende Datenwort in dem Speicher-Array DO befindet, sonst in dem Schreib/Lese- Speicher El, der zu dem Speicher-Array Dl gehört. Die Speicheradresse des Match-Signals innerhalb des Schreib/Lese-Speichers EO bzw. El ist dabei repräsentativ für die Adresse derjenigen Zeile in dem Speicher-Array DO bzw. Dl, deren Datenwort mit dem Vergleichswort übereinstimmt. Die Schreib/Lese-Speicher EO und El können über deren Ausgänge OutO bzw. Outl ausgelesen werden, um die Ergebnisse eines Vergleichs auszuwerten. Die einzelnen Speicherzeilen der Speicher-Arrays DO und Dl sind in der Figur 1 durch deren entsprechende Wortleitungen symbolisiert.
Bei der in Figur 1 gezeigten, aus dem Stand der Technik bekannten Schaltung, erweist sich als nachteilig, daß zur Verbindung der Speicher-Arrays DO und Dl mit den Eingangsleitungen DO - D23 und den Vergleichsleitungen CDO - CD23 diese jeweils parallel sowohl zu dem Speicher- Array DO als auch zu dem Speicher-Array Dl hingeführt werden müssen. Die entsprechende Verzweigung der jeweils 24 Leitungen macht eine insgesamt große Leitungslänge der Eingangs- und Vergleichsleitungen erforderlich. Aufgrund der dadurch bedingten Leitungskapazitäten ist die Zugriffsgeschwindigkeit auf das CAM beschränkt.
Ferner erweist es sich bei der Schaltung der Figur 1 als nachteilig, daß die Match-Leitungen, die das Speicher- Array DO mit seinem Schreib/Lese-Speicher EO bzw. das Speicher-Array Dl mit seinem Schreib/Lese-Speicher El verbinden jeweils über die gesamte Breite der Speicher- Arrays DO bzw. Dl geführt werden. Die hieraus resultierenden Leitungskapazitäten begrenzen weiter die Verarbeitungsgeschwindigkeit.
Diese Nachteile sind bei den in Figur 2 gezeigten erfindungsgemäßen CAM behoben. Das in Figur 2 gezeigte CAM besteht aus den Speicher-Arrays DO' und Dl' . Das Speicher-Array DO' beinhaltet die beiden Blöcke DOO und D10. Der Block DOO entspricht den Bit-Positionen 0 - 11 des Speicher-Arrays DO der Figur 1. Der Block D10 entspricht dagegen den Bit-Positionen 0 - 11 des Speicher-Arrays Dl der Figur 1. Das Speicher-Array Dl' beinhaltet die Blöcke D01 und DU, die jeweils den Bit- Positionen 12 - 23 der Speicher-Arrays DO bzw. Dl der Figur 1 entsprechen.
Eine 24-Bit-breite Zeile, beispielsweise des Speicher- Arrays DO der Figur 1 ist daher in dem CAM der Figur 2 in 2 Hälften aufgeteilt. Die Bit-Positionen 0 - 11 sind in dem Block DOO und die Bit-Positionen 12 - 23 in dem Block D01 realisiert, die jeweils zu unterschiedlichen Speicher-Arrays DO' und Dl' gehören.
Die Speicher-Arrays DO' und Dl' sind jeweils über Bit- Leitungstreiber und Schreibköpfe SO' bzw. Sl' mit den Eingangsleitungen BO - Bll und den Vergleichsleitungen CDO - CDU bzw. mit den Eingangsleitungen B12 - B23 und den Vergleichsleitungen CD12 - CD23 elektrisch verbunden. Zu dem Speicher-Array DO' gehört ein Schreib/Lese- Speicherblock EO'; zu dem Speicher-Array Dl' gehört ein Schreib/Lese-Speicherblock El*. Die Schreib/Lese- Speicherblöcke EO' und El' weisen jeweils Enable- Schaltkreise auf, die jeweils das Schreiben in eine Schreib/Lese-Zelle eines der Blöcke DO* bzw. El' erlauben. Jeder der Blöcke DOO, DOl, DIO und DU ist über entsprechende Match-Leitungen MATCHOO, MATCH01, MATCH10 und MATCH11 mit den Enable-Schaltkreisen verbunden. Jede Zeile mit 12 Bit-Positionen eines der Blöcke DOO, DOl, DIO und DU hat dabei eine separate Match-Leitung. Wird eine Übereinstimmung zwischen den entsprechenden Bit- Positionen eines Vergleichsworts und den Bit-Positionen einer der Blöcke festgestellt, so wird auf der entsprechenden Match-Leitung ein Signal ausgegeben, das die Übereinstimmung anzeigt. Die Match-Leitungen derjenigen Blöcke, die logisch ein Speicher-Array bilden, aber tatsächlich in verschiedenen Speicher-Arrays DO' und Dl' angeordnet sind, dienen als Eingänge zu jeweils demselben Enable-Schaltkreis eines der Schreib/Lese- Speicherblöcke. Entsprechend sind die Matchleitungen MATCHOO und MATCH01 der Blöcke DOO und DOl an den entsprechenden Enable-Schaltkreisen des Schreib/Lese- Speicherblocks EO' und die Matchleitungen MATCH10 und MATCH11 der Blöcke DIO und DU an die entsprechenden Enable-Schaltkreise des Schreib/Lese-Speicherblocks El' angeschlossen. In den Enable-Schaltkreisen werden die Matchleitungen MATCHOO und MATCH01, bzw. MATCH10 und MATCH11 logisch miteinander UND-verknüpft. Nur wenn jeweils beide der Matchleitungen MATCHOO und MATCH01, bzw. MATCH10 und MATCHll anzeigen, daß die entsprechenden Bit-Positionen der Vergleichsdaten auf der Vergleichsleitung mit denen in den Blöcken abgespeicherten Bits eines Datenworts entspricht, wird der entsprechende Enable-Schaltkreis für diejenige Zeile in den Blöcken, in denen die Übereinstimmung festgestellt wurde, aktiviert. Die Information der Übereinstimmung von Vergleichsdaten und einem gespeicherten Datenwort wird dann in einer entsprechenden Schreib/Lese-Zelle eines der Schreib/Lese-Speicherblöcke EO' , bzw. El* abgespeicchert. Diese Information kann dann über die Ausgangsleitungen OutO und Outl, die über Ausgangstreiber mit den Schreib/Lese-Blöcken EO' , bzw. El' verbunden sind, ausgelesen werden.
Das in der Figur 2 gezeigte erfindungsgemäße CAM hat daher 2 logische Speicher-Arrays, die aus den Blöcken DOO und DOl, bzw. den Blöcken DIO und DU bestehen. Die logischen Speicher-Arrays, die durch die Blöcke DOO und DOl, bzw. DIO und DU gebildet werden, entsprechen den Speicher-Arrays DO und Dl der Figur 1. Die logisch zusammengehörenden Blöcke sind jedoch getrennt voneinander in unterschiedlichen Speicher-Arrays DO' und Dl' auf der Chip-Oberfläche angeordnet. Das hat den Vorteil, daß nicht zu jedem der beiden Speicher-Arrays DO' und Dl' jeweils 24 Eingangs- und Vergleichsleitungen geführt werden müssen, wie das bei dem in Figur 1 gezeigten CAM der Fall ist. Es reicht hier aus, nur die jeweils den Bit-Positionen 0 - 11, bzw. 12 - 23 entsprechenden Eingangsleitungen BO - Bll und CDO - CDU, bzw. B12 - B23 und CD12 - CD23 zu den entsprechenden Speicher-Arrays DO' und Dl' zu führen. Dadurch wird die Leitungslänge der Zuleitungen insgesamt und damit auch die Leitungskapazität minimiert. Infolge dessen steigt die Verarbeitungsgeschwindigkeit des erfindungsgemäßen CAMs.
Ein weiterer Vorteil ergibt sich daraus, daß auch die Match-Leitungen nicht mehr wie bei dem CAM der Figur 1 jeweils über die gesamte Breite der Speicher-Arrays geführt werden müssen. Insbesondere die Match-Leitungen MATCH10 und MATCH11 sind gegenüber dem Stand der Technik verkürzt, da sie lediglich jeweils 11 Bit-Positionen abdecken und entsprechend die erforderliche Leitungslänge bis zum Schreib/Lese-Speicherblock El' geringer ist.
In Figur 3 ist eine Realisierungsmöglichkeit des in Figur 2 gezeigten Speicher-Arrays DO' schematisch dargestellt. Das Speicher-Array DO' besteht aus 128 Speicherzeilen. Jede der 128 Speicherzeilen weist 24 Speicherzellen Z auf. Innerhalb des Speicher-Arrays DO' sind die Blöcke DOO und DIO realisiert, die logisch zu unterschiedlichen Speicher-Arrays DO, bzw. Dl gehören. Die Zeile 1 des Speicher-Arrays DO* dient zur Speicherung der Bit- Positionen 0 - 11 der jeweils 1. Zeile der Blöcke DOO und DIO. Entsprechendes gilt für die weiteren Zeilen des Speicher-Arrays DO'. Innerhalb einer Zeile sind die Speicherzellen der Blöcke DOO, bzw. DIO alternierend angeordnet. Das bedeutet, daß auf eine Speicherzelle Z für eine Bit-Position des Blocks DOO räumlich die entsprechende Speicherzelle Z für dieselbe Bit-Position des Blocks DIO folgt. Daraus ergibt sich für die Zeile 1 des Speicher-Arrays DO' folgende Abfolgen von Speicherzellen, wobei beispielsweise mit Z (BO, DOO) die Speicherzelle für das Bit 0 des Blocks DOO bezeichnet ist:
Z(B0), DOO; Z(B0), DIO; Z(B1), DOO; Z(B1), DIO; Z(B2), DOO; Z(B2), DIO; ...; Z(B11), DOO; Z(B11), DIO.
Jede der Spalten des Speicher-Arrays DO' ist mit einer der dazugehörigen Vergleichsleitungen CD verbunden. Die Spalte 1 beispielsweise des Speicher-Arrays DO' beinhaltet Speicherzellen Z(B0) des Blocks DOO, die zur Speicherung des 1. Bits von Datenworten in dem Block DOO dienen. Entsprechend ist die Spalte 1 mit der Vergleichsleitung CDO elektrisch verbunden. Die Spalte 2 des Speicher-Arrays DO', welche zur Speicherung des jeweils 1. Bits von Datenworten des Blocks DIO dient, ist ebenfalls mit der entsprechenden Vergleichsleitung CDO elektrisch verbunden. Da die Spalten 1 und 2 jeweils zur Speicherung des 1. Bits eines Datenworts dienen und sich diese Spalten unmittelbar nebeneinander in dem Speicher- Array DO' befinden, ist es möglich, die Vergleichsleitung CDO nur einfach auszuführen und an deren Ende mit den beiden Spalten 1 und 2 elektrisch zu verbinden. Diese elektrische Verbindung ist durch den Drahtbügel 1 in Figur 3 symbolisiert. Entsprechend sind auch die weiteren Vergleichsleitungen CD1 bis CDU nur einfach ausgeführt und mit jeweils 2 benachbarten Spalten, die zur Speicherung derselben Bit-Position verschiedener Blöcke DOO, bzw. DIO dienen, verbunden. Die gesamte, dadurch erforderliche Leitungslänge der Vergleichsleitungen CD ist dadurch im Vergleich zum Stand der Technik erheblich reduziert.
Das Speicher-Array DO' hat für je 2 benachbarte Spalten, zum Beispiel Spalten 1 und 2, einen Schreibkopf mit Bit- Leitungstreiber, zum Beispiel SO'l. Ein Schreibkopf mit Bit-Leitungstreiber SO' gehört immer zu 2 benachbarten Spalten des Speicher-Arrays DO' , die zur Speicherung derselben Bit-Position in verschiedenen der Blöcke DOO, bzw. DIO dienen. Die Schreibköpfe und Bit-Leitungstreiber SO' sind mit den Signaleingängen WRITE1 und WRITE3 des Speicher-Arrays DO' verbunden, die den entsprechenden Signaleingängen WRITE1 und WRITE3 der Figur 1 entsprechen. Ferner ist jeder Schreibkopf SO' mit einer entsprechenden Eingangsleitung B verbunden. Zum Beispiel ist der Schreibkopf SO'l mit der Eingangsleitung BO, die zur Übertragung der 1. Bit-Position dient, verbunden und entsprechend der Schreibkopf SO'2 mit der Eingangsleitung Bl für die 2. Bit-Position. Wird über die Eingangsleitungen BO - B23 ein Datenwort in das CAM geschrieben, so werden die ersten 12 Bit des Datenworts über die Eingangsleitungen BO - Bll zu den entsprechenden Schreibköpfen SO'l bis SO'11 des Speicher-Arrays DO' übertragen. Entsprechend den Eingangssignalen WRITE1 und WRITE3, die von dem Computersystem erzeugt werden, werden dann die auf den Eingangsleitungen BO - Bll stehenden Daten entweder in den Block DOO oder in den Block DIO gespeichert. Diese Funktionalität kann beispielsweise durch einen Three-State-Transistor in jedem der Schreibköpfe SO' realisiert werden. Die Aufteilung der logischen Speicher-Arrays DO und Dl in die Blöcke DOO und DIO und deren Anordnung zu einem Speicher-Array DO' macht es möglich, die Eingangsleitungen BO - Bll nur einfach auszuführen und dadurch, wie auch bei den Vergleichsleitungen CDO - CDU, Leitungslänge einzusparen.
Das Speicher-Array Dl', das in Figur 3 nicht gezeigt ist, ist entsprechend dem Speicher-Array DO' aufgebaut, mit dem Unterschied, daß dort die Bit-Positionen 12 - 23 der Blöcke DOl und DU vorgesehen sind. Es ergibt sich für das Speicher-Array Dl' eine entsprechende Ersparnis an Leitungslänge der Vergleichsleitungen CD12 - CD23 und der Eingangsleitungen B12 - B23.
Figur 4 zeigt exemplarisch den Aufbau einer erfindungsgemäßen Speicherzelle Z, zum Beispiel der Zellen Z(B0, B00) des Speicher-Arrays DO', wie in Figur 3 dargestellt. In dem in Figur 4 gezeigten Ausführungsbeispiel ist die Speicherzelle selbst als ein aus den 4 Transistoren Tl, T2, T3 und T4 bestehendes Flip-Flop aufgebaut. Das Flip-Flop ist mit den Transistoren T5 und T6 verbunden. Die Basen der Transistoren T5 und T6 sind mit der Wortleitung WL verbunden. Ein Anschluß des Transistors T5 ist mit der Bit-Leitung BL verbunden, während ein Anschluß des Transistors T6 mit der komplementären Bit-Leitung BLC verbunden ist. Wie an sich aus dem Stand der Technik bekannt, kann das Flip-Flop, bestehend aus den 4 Transistoren Tl, T2, T3 und T4 durch entsprechende Ansteuerung der Wortleitung WL und der Bit-Leitung BL sowie deren Komplement beschrieben werden.
Eine Vergleichsleitung CD, zum Beispiel die Vergleichsleitung CDO, wenn es sich bei der Speicherzelle Z der Figur 4 um eine der Speicherzellen Z (BO, DOO) handelt, ist mit dem Leitungsende eines Transistors T9 verbunden, während das Komplement der Vergleichsleitung CD - die Leitung CDC - mit einem Leitungsende eines Transistors T7 verbunden ist. Die Basis des Transistors T9 ist mit dem gemeinsamen Leitungsende der Transistoren T3 und T4 verbunden, während die Basis des Transistors T7 mit dem gemeinsamen Leitungsende der Transistoren Tl und T2 des Flip-Flops verbunden ist. Parallel zu den Transistoren T7 und T9 sind jeweils die Transistoren T8 und T10 geschaltet. Die Basis des Transistors T8 ist mit den Basen der Transistoren Tl und T2 verbunden, während die Basis des Transistors T10 mit den Basen der Transistoren T3 und T4 des Flip-Flops verbunden ist. Bei den Transistoren Tl, T3, T8 und T10 handelt es sich um Transistoren des Typs Normally-On, das heißt, um Transistoren, die bei einem Potential von 0 Volt an der Basis leitend sind. Die übrigen in der Figur 4 gezeigten Transistoren sind Normally-Off-Transistoren, die bei dem Potential 0 an der Basis nicht leitend sind.
Die Transistoren T7 und T9 sind über eine Leitung 3 miteinander verbunden. Die Leitung 3 ist ihrerseits über eine Leitung 2 mit der Basis eines Transistors TU verbunden. Das Signal auf der Leitung 3 ist logisch 0, wenn das Vergleichsdatum auf der Leitung CD mit dem in der Speicherzelle Z abgespeicherten Datum übereinstimmt; im gegenteiligen Fall, wenn das Datum auf der Vergleichsleitung CD mit dem in dem Flip-Flop gespeicherten Datum nicht übereinstimmt, ist das Signal auf der Leitung 3 logisch 1. Das Signal der Leitung 3 wird über die Leitung 2 zu der Basis des Transistors TU übertragen. Das eine Ende des Transistors TU ist mit GROUND, das andere Ende mit einer MATCH-Leitung verbunden. Vor einer Vergleichsoperation wird die Leitung MATCH auf logisch 1 hochgeladen. Stimmt das Vergleichsdatum mit dem in der Zelle Z gespeicherten Datum überein, so hat das den Signalpegel logisch 0 auf der Leitung 2 zur Folge, so daß der Transistor TU nicht leitend bleibt. Mit der MATCH-Leitung ist je ein weiterer Transistor T12, T13, ... für jede der Zellen Z einer Zeile des Blocks DOO verbunden. Dadurch ist eine Match- Schaltung 4, zu der die Transistoren TU, T12, T13, ... gehören, realisiert. Die Basen der Transistoren T12, T13, ... sind jeweils über Leitungen 2' bzw. 2'" mit der Leitung 3 entsprechenden Leitungen ihrer jeweiligen Speicherzellen Z verbunden. Wenn alle 12 Bit auf den Vergleichsleitungen CDO - CDU eines Vergleichsworts mit den entsprechenden Bit-Positionen 0 - 11 eines gespeicherten Datenworts in einer Speicherzeile eines Block Dj - im Beispiel Block DOO - übereinstimmen, so hat dies zur Folge, daß das Signal auf den Leitungen 2, 2', 2''... der Transistoren der Vergleichsschaltung 4 jeweils logisch 0 ist, so daß keiner der Transistoren der Vergleichsschaltung 4 leitend wird. Wenn es bei einer der Bit-Positionen 0 -11 keine Übereinstimmung von Vergleichsdaten und gespeicherten Daten gibt, so hat dies zur Folge, daß einer der Transistoren der Match-Schaltung 4 leitend wird, so daß die Match-Leitung ebenfalls logisch 0 wird, was anzeigt, daß keine Übereinstimmung zwischen Vergleichswort und Datenwort vorliegt.
Für jede Zeile des Speicher-Arrays DO' gibt es deshalb je 2 Match-Schaltungen 4, und zwar eine Match-Schaltung 4 für jeden der Blöcke DOO und DIO. Die Match-Schaltungen 4 des Blocks DOO haben dementsprechend die Signalleitungs- Eingänge 2, 2', 2'*, ... der Speicherzellen Z (BO, DOO); Z (Bl, DOO); ... Z (Bll, DOO). Zu jeder Zeile gehört dementsprechend eine Match-Leitung MATCHOO, die gegebenenfalls anzeigt, daß die ersten 12-Bit eines Vergleichsworts mit den in dem Block DO' gespeicherten ersten 12 Bits eines Datenworts in einer Zeile des Speicher-Arrays DO' übereinstimmen. Entsprechendes gilt für die Match-Leitungen MATCH10 des Block DIO, sowie für die weiteren Match-Leitungen MATCH01 und MATCH11. Figur 5 zeigt die logische Verknüpfung am Beispiel der Match-Leitungen MATCHOO und MATCH01 der Blöcke DOO und DOl (vergleiche Figur 2). Wenn sowohl die Bit-Positionen 0 - 11 als auch die Bit-Positionen 12 - 23 des Vergleichsworts mit den entsprechenden Bit-Positionen eines gespeicherten Datenworts übereinstimmen, sind sowohl die Match-Leitung MATCHOO als auch die Match- Leitung MATCH01 der entsprechenden Zeile auf dem Potential logisch 1. Die Match-Leitung MATCHOO ist an der Basis eines Transistors T14 und die Match-Leitung MATCH01 an der Basis eines Transistors T15 angeschlossen. Die Transistoren T14 und T15 sind miteinander verbunden. Der Transistor T15 ist ferner mit einem Transistor T16 und der Transistor T14 mit einem Normally-on Transistor T18 verbunden. Die Basen der Transistoren T16 und T18 sind mit einem Enable-Signal ENABLE verbunden. Wenn das Signal ENABLE logisch 1 ist, werden die Signale MATCHOO und MATCH01 über die Transistoren T14 und T15 logisch UND- verknüpft. Nur wenn beide Match-Leitungen MATCHOO und MATCH01 auf einem Potential logisch 1 sind, werden beide Transistoren T14 und T15 leitend, so daß das Potential an dem Punkt PX 0 wird. Infolge dessen wird dann das Potential am Punkt PY, das heißt am Ausgang des Inverters I logisch 1, so daß der Transistor T17 leitend wird. Die entsprechende Information wird dadurch in den Flip-Flop 18 eingeschrieben. Das Flip-Flop 18 ist eine Schreib/Lese-Zelle des Schreib/Lese-Speicherblocks EO'. Die in Figur 5 gezeigte Schaltung, bestehend aus dem Enable-Schaltkreis, der logischen UND-Verknüpfung der Match-Leitungen und der Schreib/Lese-Zelle des Schreib/Lese-Speicherblocks EO' ist für jede der 128 Zeilen des CAM realisiert. Durch die Gesamtheit der Schreib/Lese-Zellen wird dadurch der Schreib/Lese- Speicherblock EO' realisiert. Entsprechendes gilt für den Schreib/Lese-Speicherblock El'. Nach Beendigung einer Vergleichsoperation können dann die Schreib/Lese- Speicherblöcke EO* und El' ausgelesen werden, um festzustellen, ob in einem der Flip-Flops 18 einer der Zeilen des CAMs die Information gespeichert ist, daß die Vergleichsdaten mit den gespeicherten Daten der betreffenden Speicherzeile übereinstimmen. Falls diese Information in dem Schreib/Lese-Speicherblock EO' gespeichert ist, bedeutet dies, daß sich das entsprechende Datenwort in dem logischen Speicher-Array DO, das heißt in dem Block DOO des Speicher-Arrays DO' und dem Block DOl des Speicher-Arrays Dl' befindet.
Durch die erfindungsgemäße Aufteilung der Match-Leitungen in eine Match-Leitung MATCHOO und MATCH01, bzw. MATCH10 und MATCH11, ergibt sich ein weiterer Vorteil. Falls nämlich Vergleichs- und Datenwort nur in einem Bit nicht übereinstimmen, so bedeutet dies, daß einer der Transistoren der Match-Schaltung 4 insgesamt die Match- Leitung MATCH auf das Potential logisch 0 ziehen muß, was die Umladung einer relativ großen Kapazität erforderlich macht. Nach der Lehre der Erfindung sind mit einer Match- Leitung MATCH jedoch nicht für jedes Bit des Datenworts Transistoren TU, T12, T13, ... vorgesehen, sondern - in dem Ausführungsbeispiel der Figur 4 - nur 12 Transistoren aufgrund der Zweiteilung der logischen Speicher-Arrays DO und Dl in jeweils 2 Blöcke DOO, DOl, DIO und DU. Die damit verbundene Verringerung der umzuladenden Kapazität bedeutet eine weitere Erhöhung der Verarbeitungsgeschwindigkeit des CAM.
Die Lehre der Erfindung ist jedoch nicht auf ein CAM mit 2 logischen Speicher-Arrays DO und Dl, die jeweils in 2 Blöcke DOO, DOl und DIO, DU aufgeteilt sind, beschränkt. Vielmehr ist die Lehre der Erfindung auf ein CAM mit einer beliebigen Anzahl X logischer Speicher-Arrays DO, Dl, D2, ... anwendbar. Jedes der logischen Speicher- Arrays Di wird dazu in eine Anzahl Y von Blöcken Dij logisch aufgeteilt. Jeweils einander entsprechende Blöcke Dij verschiedener logischer Speicher-Arrays Di sind nach der Lehre der Erfindung zu Speicher-Arrays Di' angeordnet. Das zeigt Figur 6 exemplarisch für den Fall dreier logischer Speicher-Arrays DO, Dl, D2, die in je Y = 3 Blöcke aufgeteilt sind. Dabei entsprechen diejenigen Blöcke, der verschiedenen logischen Speicher-Arrays einander, die dieselben Bit-Positionen innerhalb eines logischen Speicher-Arrays beinhalten. Die einander entsprechenden Blöcke sind jeweils in einem Speicher- Array Di', das heißt DO', Dl', D2' physikalisch auf der Chip-Oberfläche angeordnet. Entsprechend bedeutet dies, daß jeder Block eines physikalischen Speicher-Arrays Di' eine separate Match-Leitung für jede Speicher-Zeile aufweist.
Vorzugsweise sind auch bei dem allgemeineren Beispiel der Figur 6 die Bit-Positionen der jeweiligen Blöcke eines Speicher-Arrays, zum Beispiel die Blöcke DOO, DIO, D20 des Speicher-Arrays DO' , alternierend in den Zeilen des Speicher-Arrays angeordnet. Die ersten 3 Speicherzellen des Speicher-Arrays DO' etwa beinhalten jeweils die erste Bit-Position der Blöcke BOO, BIO und B20. Dies entspricht der Darstellung in Figur 3 für den Fall zweier Blöcke pro Speicher-Array. Es werden also in dem Speicher-Array DO' der Figur 6 jeweils Tripel von Speicherzellen gebildet, die jeweils zur Speicherung der selben Bit-Position verschiedener Blöcke dienen. Die weiteren Zeilen des Speicher-Arrays DO' sind gleich aufgebaut. Entsprechendes gilt für die Speicher-Arrays Dl' und D2' . Die einzelne Speicherzelle ist wie in dem Ausführungsbeispiel der Figur 4 aufgebaut. Im Unterschied zum Ausführungsbeispiel der Figur 4, beinhaltet die Match-Schaltung 4 nur eine Anzahl von Transistoren TU, T12, T13, ..., die einem Drittel der Wortbreite eines in dem CAM der Figur 6 abzuspeichernden Datenworts entspricht. Das liegt daran, daß aufgrund der logischen Dreiteilung der Speicher- Arrays jeder Block Dij nur ein Drittel der gesamten Wortbreiten aufweist. Die Match-Leitungen derjenigen Blöcke, die zu einem logischen Array gehören, werden entsprechend der Figur 5 UND-verknüpft; denn nur wenn alle Match-Leitungen der Blöcke, die zu einem gemeinsamen logischen Array gehören, anzeigen, daß das Vergleichswort mit den entsprechenden Bit-Positionen der jeweiligen Blöcke übereinstimmt, liegt tatsächlich eine Übereinstimmung des Vergleichsworts mit dem gesamten Datenwort vor. Entsprechend ist auch für jedes der Speicher-Arrays DO', Dl', D2 ' ein Schreib/Lese- Speicherblock EO', El', E2' vorgesehen.
Durch die erfindungsgemäße Aufteilung der logischen Speicher-Arrays in Y = 3 Blöcke ist entsprechend dem Ausführungsbeispiel der Figur 2 wiederum der Vorteil erreicht, daß die Leitungslängen sowohl der Vergleichsleitungen, als auch der Eingangsleitungen und der Match-Leitungen minimiert werden. Außerdem sind auch wiederum die Kapazitäten der Match-Leitungen reduziert, da nicht für jeweils jede Bit-Position ein Transistor an der Match-Leitung vorgesehen ist.
Beispielsweise kann ein erfindungsgemäßes CAM als Cache- Directory verwendet werden. Ein Cache-Speicher kann beispielsweise im Zusammenhang mit einem Massenspeicher, insbesondere einem Festplatten-Speicher, Verwendung finden. Diejenigen Sektoren, beispielsweise des Festplatten-Speichers, auf die oft zugegriffen werden muß, sind in entsprechenden Sektoren des Cache-Speichers abgespeichert. Soll auf die Daten, die in einem Sektor des Speichers abgespeichert sind, zugegriffen werden, so muß zunächst festgestellt werden, ob die Daten dieses Sektors in dem Cache-Speicher vorhanden sind oder nicht. Dazu wird die Adresse des entsprechenden Sektors über die Compare-Leitungen in das CAM eingegeben. Wenn die entsprechende Sektornummer als Datenwort in dem CAM gespeichert ist, so bedeutet dies, daß die zu der Sektornummer gehörenden Daten in dem Cache-Speicher gespeichert sind. Diejenige Zeile des CAM, in der die Sektornummer aufgefunden wurde, repräsentiert die entsprechende Sektornummer in dem Cache-Speicher. Entsprechend werden die Eingangsleitungen B dazu benutzt, Sektornummern von Sektoren der Festplatte in das CAM zu schreiben, sobald die Daten eines Speichersektors der Festplatte in dem Cache-Speicher zur Verfügung stehen.

Claims

P A T E N T A N S P R Ü C H E
CAM mit X logischen Speicherarrays Di dadurch gekennzeichnet, daß die logischen Speicherarrays Di in je Y Blöcke Dij logisch aufgeteilt sind und die Blöcke Din der Speicherarrays Di jeweils zu einem Speicherarray Di' angeordnet sind.
CAM nach Anspruch 1, dadurch gekennzeichnet, daß zu jedem der Blöcke Dij eine Matchleitung gehört und die Matchleitungen derjenigen Blöcke Dij, die logisch zu dem Speicherarray Di gehören, logisch miteinander verknüpft sind.
CAM nach Anspruch 2, dadurch gekennzeichnet, daß die logische Verknüpfung der Match-Leitungen eine logische UND-Verknüpfung ist.
CAM nach einem oder mehreren der vorhergehenden Ansprüche, dadurch gekennzeichnet, daß die Speicherzellen Z der Blöcke Dij eines Speichers- Arrays Di' in dem Speicher-Array Di' alternierend angeordnet sind.
CAM nach einem oder mehreren der vorhergehenden Ansprüche, dadurch gekennzeichnet, daß die Zahl X der logischen Speicher-Arrays Di gleich 2 ist und die Anzahl Y der Blöcke Dij gleich 2 ist.
Computersystem mit wenigstens einem CAM nach einem oder mehreren der vorhergehenden Ansprüche.
Verwendung eines CAM nach einem oder mehreren der vorhergehenden Ansprüche als Cache-Verzeichnis.
PCT/EP1995/001460 1995-04-18 1995-04-18 Inhalts-adressierbarer speicher WO1996033499A1 (de)

Priority Applications (4)

Application Number Priority Date Filing Date Title
US08/750,765 US5870324A (en) 1995-04-18 1995-04-18 Contents-addressable memory
PCT/EP1995/001460 WO1996033499A1 (de) 1995-04-18 1995-04-18 Inhalts-adressierbarer speicher
JP08531425A JP3125884B2 (ja) 1995-04-18 1995-04-18 内容アドレス記憶装置
DE19614443A DE19614443A1 (de) 1995-04-18 1996-04-12 Inhalts-adressierbarer Speicher

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/EP1995/001460 WO1996033499A1 (de) 1995-04-18 1995-04-18 Inhalts-adressierbarer speicher

Publications (1)

Publication Number Publication Date
WO1996033499A1 true WO1996033499A1 (de) 1996-10-24

Family

ID=8166001

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/EP1995/001460 WO1996033499A1 (de) 1995-04-18 1995-04-18 Inhalts-adressierbarer speicher

Country Status (4)

Country Link
US (1) US5870324A (de)
JP (1) JP3125884B2 (de)
DE (1) DE19614443A1 (de)
WO (1) WO1996033499A1 (de)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0858077A2 (de) * 1997-02-06 1998-08-12 Nortel Networks Corporation Inhaltaddressierter Speicher

Families Citing this family (49)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6199140B1 (en) * 1997-10-30 2001-03-06 Netlogic Microsystems, Inc. Multiport content addressable memory device and timing signals
US6892272B1 (en) 1999-02-23 2005-05-10 Netlogic Microsystems, Inc. Method and apparatus for determining a longest prefix match in a content addressable memory device
US6460112B1 (en) 1999-02-23 2002-10-01 Netlogic Microsystems, Llc Method and apparatus for determining a longest prefix match in a content addressable memory device
US6539455B1 (en) 1999-02-23 2003-03-25 Netlogic Microsystems, Inc. Method and apparatus for determining an exact match in a ternary content addressable memory device
US6499081B1 (en) 1999-02-23 2002-12-24 Netlogic Microsystems, Inc. Method and apparatus for determining a longest prefix match in a segmented content addressable memory device
US6574702B2 (en) 1999-02-23 2003-06-03 Netlogic Microsystems, Inc. Method and apparatus for determining an exact match in a content addressable memory device
US6137707A (en) * 1999-03-26 2000-10-24 Netlogic Microsystems Method and apparatus for simultaneously performing a plurality of compare operations in content addressable memory device
US6240000B1 (en) * 1999-08-18 2001-05-29 Lara Technology, Inc. Content addressable memory with reduced transient current
US6542391B2 (en) * 2000-06-08 2003-04-01 Netlogic Microsystems, Inc. Content addressable memory with configurable class-based storage partition
US6567340B1 (en) 1999-09-23 2003-05-20 Netlogic Microsystems, Inc. Memory storage cell based array of counters
US7110407B1 (en) 1999-09-23 2006-09-19 Netlogic Microsystems, Inc. Method and apparatus for performing priority encoding in a segmented classification system using enable signals
US6751701B1 (en) 2000-06-14 2004-06-15 Netlogic Microsystems, Inc. Method and apparatus for detecting a multiple match in an intra-row configurable CAM system
US6763425B1 (en) 2000-06-08 2004-07-13 Netlogic Microsystems, Inc. Method and apparatus for address translation in a partitioned content addressable memory device
US6799243B1 (en) 2000-06-14 2004-09-28 Netlogic Microsystems, Inc. Method and apparatus for detecting a match in an intra-row configurable cam system
US6944709B2 (en) * 1999-09-23 2005-09-13 Netlogic Microsystems, Inc. Content addressable memory with block-programmable mask write mode, word width and priority
US6934795B2 (en) * 1999-09-23 2005-08-23 Netlogic Microsystems, Inc. Content addressable memory with programmable word width and programmable priority
US6324087B1 (en) 2000-06-08 2001-11-27 Netlogic Microsystems, Inc. Method and apparatus for partitioning a content addressable memory device
US7487200B1 (en) * 1999-09-23 2009-02-03 Netlogic Microsystems, Inc. Method and apparatus for performing priority encoding in a segmented classification system
US6687785B1 (en) 2000-06-08 2004-02-03 Netlogic Microsystems, Inc. Method and apparatus for re-assigning priority in a partitioned content addressable memory device
US6757779B1 (en) 1999-09-23 2004-06-29 Netlogic Microsystems, Inc. Content addressable memory with selectable mask write mode
US6795892B1 (en) 2000-06-14 2004-09-21 Netlogic Microsystems, Inc. Method and apparatus for determining a match address in an intra-row configurable cam device
US7143231B1 (en) 1999-09-23 2006-11-28 Netlogic Microsystems, Inc. Method and apparatus for performing packet classification for policy-based packet routing
US7272027B2 (en) * 1999-09-23 2007-09-18 Netlogic Microsystems, Inc. Priority circuit for content addressable memory
US6154384A (en) * 1999-11-12 2000-11-28 Netlogic Microsystems, Inc. Ternary content addressable memory cell
US6671771B2 (en) * 1999-12-21 2003-12-30 Intel Corporation Hash CAM having a reduced width comparison circuitry and its application
US6252790B1 (en) * 2000-10-16 2001-06-26 Nicholas Shectman Large-capacity content addressable memory with sorted insertion
US6496398B2 (en) 2000-12-15 2002-12-17 International Business Machines Corporation Content addressable memory
US6910097B1 (en) 2001-04-09 2005-06-21 Netlogic Microsystems, Inc. Classless interdomain routing using binary content addressable memory
US6744652B2 (en) * 2001-08-22 2004-06-01 Netlogic Microsystems, Inc. Concurrent searching of different tables within a content addressable memory
US7210003B2 (en) 2001-10-31 2007-04-24 Netlogic Microsystems, Inc. Comparand generation in a content addressable memory
US7301961B1 (en) 2001-12-27 2007-11-27 Cypress Semiconductor Corportion Method and apparatus for configuring signal lines according to idle codes
US7237058B2 (en) 2002-01-14 2007-06-26 Netlogic Microsystems, Inc. Input data selection for content addressable memory
US7382637B1 (en) 2002-02-01 2008-06-03 Netlogic Microsystems, Inc. Block-writable content addressable memory device
US6697276B1 (en) 2002-02-01 2004-02-24 Netlogic Microsystems, Inc. Content addressable memory device
US6876559B1 (en) 2002-02-01 2005-04-05 Netlogic Microsystems, Inc. Block-writable content addressable memory device
US6934796B1 (en) 2002-02-01 2005-08-23 Netlogic Microsystems, Inc. Content addressable memory with hashing function
US7114026B1 (en) 2002-06-17 2006-09-26 Sandeep Khanna CAM device having multiple index generators
US6842358B2 (en) * 2002-08-01 2005-01-11 Netlogic Microsystems, Inc. Content addressable memory with cascaded array
US6933757B1 (en) 2002-10-31 2005-08-23 Cypress Semiconductor Corporation Timing method and apparatus for integrated circuit device
US20060018142A1 (en) * 2003-08-11 2006-01-26 Varadarajan Srinivasan Concurrent searching of different tables within a content addressable memory
US6958925B1 (en) 2003-12-24 2005-10-25 Cypress Semiconductor Corporation Staggered compare architecture for content addressable memory (CAM) device
US7486531B2 (en) * 2004-11-09 2009-02-03 Integrated Device Technology, Inc. Low power content addressable memory array (CAM) and method of operating same
US7149101B1 (en) 2004-12-15 2006-12-12 Netlogic Microsystems, Inc. Method and apparatus for smoothing current transients in a content addressable memory (CAM) device with dummy searches
US7814266B1 (en) 2005-09-01 2010-10-12 Netlogic Microsystems, Inc. Partial row expansion by logically combining range representation values in content addressable memory
US7366830B1 (en) 2005-09-01 2008-04-29 Netlogic Microsystems, Inc. Row expansion reduction by inversion for range representation in ternary content addressable memories
US7848129B1 (en) 2008-11-20 2010-12-07 Netlogic Microsystems, Inc. Dynamically partitioned CAM array
US7920399B1 (en) 2010-10-21 2011-04-05 Netlogic Microsystems, Inc. Low power content addressable memory device having selectable cascaded array segments
CN102122270B (zh) * 2011-02-23 2013-08-07 华为技术有限公司 在存储器中查找数据的方法和装置以及存储器
US8467213B1 (en) 2011-03-22 2013-06-18 Netlogic Microsystems, Inc. Power limiting in a content search system

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5280447A (en) * 1992-06-19 1994-01-18 Intel Corporation Floating gate nonvolatile memory with configurable erasure blocks

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS60117495A (ja) * 1983-11-29 1985-06-24 Nec Corp 半導体メモリ
JPS60138798A (ja) * 1983-12-27 1985-07-23 Toshiba Corp 連想記憶集積回路
JP2585227B2 (ja) * 1986-07-25 1997-02-26 株式会社日立製作所 半導体メモリ装置
US5564052A (en) * 1991-06-27 1996-10-08 Integrated Device Technology, Inc. Logically disconnectable virtual-to-physical address translation unit and method for such disconnection

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5280447A (en) * 1992-06-19 1994-01-18 Intel Corporation Floating gate nonvolatile memory with configurable erasure blocks

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0858077A2 (de) * 1997-02-06 1998-08-12 Nortel Networks Corporation Inhaltaddressierter Speicher
EP0858077A3 (de) * 1997-02-06 1999-12-15 Nortel Networks Corporation Inhaltaddressierter Speicher
KR100562805B1 (ko) * 1997-02-06 2006-05-25 노오텔 네트웍스 리미티드 내용번지화기억장치

Also Published As

Publication number Publication date
JPH09507949A (ja) 1997-08-12
JP3125884B2 (ja) 2001-01-22
DE19614443A1 (de) 1996-10-24
US5870324A (en) 1999-02-09

Similar Documents

Publication Publication Date Title
WO1996033499A1 (de) Inhalts-adressierbarer speicher
DE4110173C2 (de) Adressenansteuereinrichtung für einen SRAM und Verfahren zum Betreiben derselben
DE19530100C2 (de) Integrierte Dram-Schaltung mit Reihenkopierschaltung und Verfahren
DE2803989C2 (de) Digitaldatenspeicher mit wahlfreiem Zugriff
EP0908893B1 (de) Speicherarchitektur mit Mehrebenenhierarchie
DE3618163C2 (de) Speichermanagementanordnung für ein Mikroprozessorsystem
DE69218941T2 (de) Neuronale netzwerk architektur
DE4207945C2 (de) Multiport-Speicher und Verfahren zum Entscheiden eines Zugriffskonflikts darin
DE2310631C3 (de) Speicherhierarchie für ein Datenverarbeitungssystem
DE2324731A1 (de) Festzustandsspeicher fuer mehrdimensionalen zugriff
DE2445617A1 (de) Hierarchische speicheranordnung
EP0046976A2 (de) Halbleiterspeicher aus Speicherbausteinen mit redundanten Speicherbereichen
DE3618136C2 (de)
DE2261786A1 (de) Nur-lese-speicher hoher dichte
DE69525527T2 (de) Multiport mehrfachregisterspeicher zum empfang von daten unterschiedlicher länge
DE69322436T2 (de) Halbleiterspeicheranordnung
DE4312086A1 (de) Halbleiterspeichereinrichtung und Betriebsverfahren dafür
EP0224887A1 (de) Gate Array Anordnung in CMOS-Technik
DE69025782T2 (de) Registerbankschaltung
DE69227144T2 (de) Programmierbare logische Einheit
DE1524856A1 (de) Wortadressierbare Datenspeicher mit mehreren defekten Speicherelementen
DE1295656B (de) Assoziativer Speicher
DE2101180B2 (de)
EP0771463B1 (de) Verfahren und vorrichtung zum speichern und drehen von bitmustern
DE2332555A1 (de) Schadhafte speicherzellen enthaltendes monolithisches halbleiterchip geringer verlustleistung

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): JP US

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH DE DK ES FR GB GR IE IT LU MC NL PT SE

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 08750765

Country of ref document: US

122 Ep: pct application non-entry in european phase