The present invention relates to integrated circuit memory devices and methods of operating same, and more particularly to buffer memory devices and methods of operating buffer memory devices.
Semiconductor memory devices can typically be classified on the basis of memory functionality, data access patterns and the nature of the data storage mechanism. For example, distinctions are typically made between read-only memory (ROM) devices and read-write memory (RWM) devices. The RWM devices typically have the advantage of offering both read and write functionality with comparable data access times. Typically, in RWM devices, data is stored either in flip-flops for “static” memory devices or as preset levels of charge on a capacitor in “dynamic” memory devices. As will be understood by those skilled in the art, static memory devices retain their data as long as a supply of power is maintained, however, dynamic memory devices require periodic data refreshing to compensate for potential charge leakage. Because RWM devices use active circuitry to store data, they belong to a class of memory devices known as “volatile” memory devices because data stored therein will be lost upon termination of the power supply. ROM devices, on the other hand, may encode data into circuit topology (e.g., by blowing fuses, removing diodes, etc.). Since this latter type of data storage may be hardwired, the data cannot be modified, but can only be read. ROM devices also typically belong to a class of memory devices known as “nonvolatile” memory devices because data stored therein will typically not be lost upon termination of the power supply. Other types of memory devices that have been more recently developed are typically referred to as nonvolatile read-write (NVRWM) memory devices. These types of memory devices include EPROM (erasable programmable read-only memory), E2PROM (electrically erasable programmable read-only memory), and flash memories, for example.
An additional memory classification is typically based on the order in which data can be accessed. Here, most memory devices belong to the random-access class, which means that memory locations can be read from or written to in random order. Notwithstanding the fact that most memory devices provide random-access, typically only random-access RWM memories use the acronym RAM. Alternatively, memory devices may restrict the order of data access to achieve shorter data access times, reduce layout area and/or provide specialized functionality. Examples of such specialized memory devices include buffer memory devices such as first-in first-out (FIFO) memory devices, last-in first-out (LIFO or “stack”) memory devices, shift registers and content-addressable memory (CAM) devices.
A final classification of semiconductor memories is based on the number of data input and data output ports associated with the memory cells therein. For example, although most memory devices have unit cells therein that provide only a single port which is shared to provide an input and output path for transfer of data, memory devices with higher bandwidth requirements often have cells therein with multiple input and output ports. However, the addition of ports to unit memory cells typically increases the complexity and layout area requirements for these higher bandwidth memory devices.
Single-port memory devices are typically made using static RAM cells if fast data access times are a requirement, and dynamic RAM cells if low cost is a primary requirement. Many FIFO memory devices use dual-port RAM based designs with self-incrementing internal read and write pointers to achieve fast fall-through capability. As will be understood by those skilled in the art, fall-through capability is typically measured as the time elapsing between the end of a write cycle into a previously empty FIFO and the time an operation to read that data may begin. Exemplary FIFO memory devices are more fully described and illustrated at section 2.2.7 of a textbook by A.K. Sharma entitled “Semiconductor Memories: Technology, Testing and Reliability”, IEEE Press (1997).
In particular, dual-port SRAM-based FIFOs typically utilize separate read and write pointers to advantageously allow read and write operations to occur independently of each other and achieve fast fall-through capability since data written into a dual-port SRAM FIFO can be immediately accessed for reading. Since these read and write operations may occur independently, independent read and write clocks having different frequencies may be provided to enable the FIFO to act as a buffer between peripheral devices operating at different rates. Unfortunately, a major disadvantage of typical dual-port SRAM-based FIFOs is the relatively large unit cell size for each dual-port SRAM cell therein. Thus, for a given semiconductor chip size, dual-port buffer memory devices typically provide less memory capacity relative to single-port buffer memory devices. For example, using a standard DRAM cell as a reference unit cell consuming one (1) unit of area, a single-port SRAM unit cell typically may consume four (4) units of area and a dual-port SRAM unit cell typically may consume sixteen (16) units of area. Moreover, the relatively large unit cells of a dual-port SRAM FIFO limit the degree to which the number of write operations can exceed the number of read operations, that is, limit the capacity of the FIFO.
To address these limitations of dual-port buffer memory devices, single-port buffer memory devices have been developed to, among other things, achieve higher data capacities for a given semiconductor chip size. For example, U.S. Pat. No. 5,546,347 to Ko et al. entitled “Interleaving Architecture And Method For A High Density FIFO”, assigned to the present assignee, discloses a memory device which has high capacity and uses relatively small single-port memory cells. However, the use of only single port memory cells typically precludes simultaneous read and write access to data in the same memory cell, which means that single-port buffer memory devices typically have slower fall-through time than comparable dual-port memory devices. Moreover, single-port buffer memory devices may use complicated arbitration hardware to control sequencing and queuing of reading and writing operations.
U.S. Pat. No. 5,371,708 to Kobayashi also discloses a FIFO memory device containing a single-port memory array, a read data register for holding read data from the memory array and a write data register for holding write data to the memory array. A bypass switch is also provided for transferring data from the write data register to the read data register so that the memory array can be bypassed during testing of the FIFO to detect the presence of defects therein. However, like the above-described single-port buffer memory devices, simultaneous read and write access to data is not feasible.
Commonly assigned U.S. Pat. Nos. 5,978,307, 5,982,700 and 5,999,478 disclose memory buffers having fast fall-through capability. These memory buffers contain a tri-port memory array of moderate capacity having nonlinear columns of tri-port cells therein which collectively form four separate registers, and a substantially larger capacity supplemental memory array (e.g., DRAM array) having cells therein with reduced unit cell size. The tri-port memory array has a read port, a write port and a bidirectional input/output port. The tri-port memory array communicates internally with the supplemental memory array via the bidirectional input/output port and communicates with external devices (e.g., peripheral devices) via the read and write data ports. Efficient steering circuitry is also provided by a bidirectional crosspoint switch that electrically couples terminals (lines IO and IOB) of the bidirectional input/output port in parallel to bit lines (BL and BLB) in the supplemental memory array during a write-to-memory time interval and vice versa during a read-from-memory time interval.
Notwithstanding the above described buffer memory devices, there still exists a need to develop high speed buffer memory devices having expanded functionality, increased data capacity and reduced unit cell size.
An integrated circuit memory device according to an embodiment of the present invention includes a quad-port cache memory device and an embedded memory device therein. These devices operate collectively as high speed buffer memory devices having fast fall through capability and extended data capacity, for example. These devices also do not require complex arbitration circuitry to oversee reading and writing operations.
The quad-port cache memory device may comprise a data input register having an input electrically coupled to a first port of the cache memory device and an output electrically coupled to a second port of the cache memory device. A multiplexer is also provided. This multiplexer is responsive to at least one select signal and has a first input electrically coupled to the output of the data input register and a second input electrically coupled to a third port of the cache memory device. The quad-port cache memory device also preferably includes an output register having an input electrically coupled to an output of the multiplexer and an output electrically coupled to a fourth port of the cache memory device. Retransmit capability may also be provided by including a retransmit register within the quad-port cache. This retransmit register preferably has an input electrically coupled to the first port and an output electrically coupled to a third input of the multiplexer. The at least one select signal may include three (3) select signals, for example. These select signals may be a retransmit path select signal, a memory path select signal and a direct path select signal. The data input register, the output register and the retransmit register are also preferably responsive to write address, a read address and a retransmit address, respectively. The embedded memory device may comprise a SRAM memory array, for example, and the array may have a write port electrically coupled to the second port of the cache memory device and a read port electrically coupled to the third port of the cache memory device.
Another embodiment of the present invention includes tri-port or other multi-port cache memory devices. Such devices may comprise a data input register having an input electrically coupled to a first port of the cache memory device and a multiplexer that is responsive to a direct path select signal and a memory path select signal. The multiplexer may also have a first input electrically coupled to an output of the data input register and a second input electrically coupled to a second port of the cache memory device. An output register is also provided. This output register has an input electrically coupled to an output of the multiplexer and an output electrically coupled to a third port of the cache memory device. Here, the second port of the cache memory device may by a bidirectional port and the first input of the multiplexer may be electrically coupled by a pass gate device (e.g., CMOS transmission gate) to the bidirectional port. The pass gate device may be responsive to a read/write control signal. An embedded DRAM memory array may also be electrically coupled to the bidirectional port.
A still further embodiment of the present invention includes a multi-port memory device bit cell. This bit cell may comprise an input register and a first retransmit register having an input electrically coupled to an input of the input register. This first retransmit register may comprise a retransmit from zero register. A multiplexer may also be provided. This multiplexer may have a first input electrically coupled to an output of the input register and a second input electrically coupled to an output of the first retransmit register. An output register may also be provided along with a second retransmit register. In particular, the output register may have an input electrically coupled to an output of the multiplexer and the second retransmit register may have an input electrically coupled to an output of the output register and an output electrically coupled to a third input of the multiplexer. The second retransmit register may constitute a retransmit from mark (RTM) register. The multiplexer may also be responsive to a retransmit from zero path select signal, a direct path select signal and a retransmit from mark path select signal.
Additional embodiments of the present invention include methods of operating a FIFO buffer memory device having an embedded memory device and a plurality of multi-port cache memory devices therein. These methods include the operations of reading a first page of data from a first multi-port cache memory device during a first read time interval and reading a second page of data from a second multi-port cache memory device during a second read time interval that follows that first time interval. Arbitration operations are also performed during these reading operations in order to make additional pages of data available for reading without interruption. In particular, prior to termination of the second read time interval, an arbitration operation is performed to determine whether a page of next-to-read data relative to the second page of data is available in the embedded memory device. Then, if the page of next-to-read data is available, an operation is performed to transfer the page of next-to-read data from the embedded memory device to the first multi-port cache memory device during the second read time interval. Operations may also be performed to write data into the second multi-port cache memory during the first and/or second read time interval and then transfer this page of data from the second multi-port cache memory device to the embedded memory device during the second read time interval.
The present invention will now be described more fully hereinafter with reference to the accompanying drawings, in which preferred embodiments of the invention are shown. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Like numbers refer to like elements throughout.
Referring now to
The buffer memory device 10 of
As illustrated by
As illustrated by the detailed electrical schematic of
Referring again to the multi-bank memory device 10a of
As more fully described hereinbelow with respect to
Referring now to
As illustrated by
As illustrated by Blocks 54 and 56, a read data path is provided through the data multiplexer and the data output register within QPCACHE0 until all 144 bits of data (i.e., four 36-bit words) have been read from the retransmit register within QPCACHE0. However, once all initial 144 bits of data have been read from QPCACHE0, a check is made to determine whether a “less than three” flag is active, Block 58. This flag is active whenever a difference between the value of the write pointer (not shown) and a read pointer (not shown) in the embedded memory is less than three (3). Stated alternatively, an operation is performed at Block 58 to determine whether an additional page of data relative to the cache data (i.e., the data available for reading within QPCACHE0 and QPCACHE1) is available in the embedded memory array SRAM ARRAY #0. If the <3 flag is active, then the additional page of data is not available and the direct path signal DIRECTPATH0 is set to a logic 1 level and the signal RTPATH0 is made inactive, as illustrated by Block 60. This operation enables data written into the data input register within QPCACHE0 to be available for reading after the data within QPCACHE1 has been read. However, if an additional page of data is available in the embedded memory SRAM ARRAY #0, then a fetch (i.e., read) operation is performed from SRAM ARRAY #0 and signal SRAMPATH0 is set to a logic 1 level, Block 62. Signal RTPATH0 is also made inactive since the initial data within the retransmit register within QPCACHE0 has been completely read out.
Read control is then passed to QPCACHE1 and, as illustrated by Blocks 64 and 66, a continuous check is then made to determine whether all 144 bits of read data within the retransmit register in QPCACHE1 have been read. If all 144 bits have been read, then the <3 flag is checked again to determine whether an additional page of data relative to the current data in QPCACHE0 and QPCACHE1 is available in the embedded memory SRAM ARRAY #1, Block 68. If the <3 flag is active, which means an additional page of data is not available, the signal DIRECTPATH1 is set to an active level and signal RTPATH1 is made inactive, Block 70. However, if the <3 flag is not active, signal SRAMPATH1 is set to a logic 1 level, a fetch operation is performed from SRAM ARRAY #1 and signal RTPATH1 is made inactive, Block 72. Read control is then passed back to QPCACHE0 and operations commence to read data from either the data input register or from SRAM ARRAY #0. As illustrated by
The operations 80 of
Referring now to Block 82 of
In the drawings and specification, there have been disclosed typical preferred embodiments of the invention and, although specific terms are employed, they are used in a generic and descriptive sense only and not for purposes of limitation, the scope of the invention being set forth in the following claims.
This application is a continuation of U.S. application Ser. No. 10/307,638, filed Dec. 2, 2002, now U.S. Pat. No. 6,754,777, which is a divisional of U.S. application Ser. No. 09/721,478, filed Nov. 22, 2000, now U.S. Pat. No. 6,546,461, the disclosures of which are hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4195340 | Joyce | Mar 1980 | A |
4402067 | Moss et al. | Aug 1983 | A |
4577293 | Matick et al. | Mar 1986 | A |
4731758 | Lam et al. | Mar 1988 | A |
4758987 | Sakui | Jul 1988 | A |
4823321 | Aoyama | Apr 1989 | A |
4829471 | Banerjee et al. | May 1989 | A |
4837746 | Banerjee et al. | Jun 1989 | A |
4849935 | Miyazawa | Jul 1989 | A |
4888741 | Malinowski | Dec 1989 | A |
4894770 | Ward et al. | Jan 1990 | A |
4926385 | Fujishima et al. | May 1990 | A |
5025421 | Cho | Jun 1991 | A |
5046000 | Hsu | Sep 1991 | A |
5226009 | Arimoto | Jul 1993 | A |
5226147 | Fujishima et al. | Jul 1993 | A |
5228002 | Huang | Jul 1993 | A |
5249282 | Segers | Sep 1993 | A |
5269009 | Herzl et al. | Dec 1993 | A |
5276842 | Sugita | Jan 1994 | A |
5280441 | Wada et al. | Jan 1994 | A |
5365485 | Ward et al. | Nov 1994 | A |
5371877 | Drako et al. | Dec 1994 | A |
5434818 | Byers et al. | Jul 1995 | A |
5442747 | Chan et al. | Aug 1995 | A |
5546347 | Ko et al. | Aug 1996 | A |
5557733 | Hicok et al. | Sep 1996 | A |
5561781 | Braceras et al. | Oct 1996 | A |
5586299 | Wakerly | Dec 1996 | A |
5603009 | Konishi et al. | Feb 1997 | A |
5642318 | Knaack et al. | Jun 1997 | A |
5663910 | Ko et al. | Sep 1997 | A |
5671393 | Yamaki et al. | Sep 1997 | A |
5682356 | Knaack | Oct 1997 | A |
5712820 | Knaack | Jan 1998 | A |
5715197 | Nance et al. | Feb 1998 | A |
5732041 | Joffe | Mar 1998 | A |
5751638 | Mick et al. | May 1998 | A |
5764967 | Knaack | Jun 1998 | A |
5777944 | Knaack et al. | Jul 1998 | A |
5784382 | Byers et al. | Jul 1998 | A |
5829015 | Macno | Oct 1998 | A |
5852608 | Csoppenszky et al. | Dec 1998 | A |
5867672 | Wang et al. | Feb 1999 | A |
5946261 | Artieri | Aug 1999 | A |
5956748 | New | Sep 1999 | A |
5978307 | Proebsting et al. | Nov 1999 | A |
5982700 | Proebsting | Nov 1999 | A |
5999478 | Proebsting | Dec 1999 | A |
6044416 | Hasan | Mar 2000 | A |
6075931 | Panwar | Jun 2000 | A |
6088744 | Hill | Jul 2000 | A |
6091260 | Shamarao | Jul 2000 | A |
6114840 | Farrell et al. | Sep 2000 | A |
6147926 | Park | Nov 2000 | A |
6151273 | Iwamoto et al. | Nov 2000 | A |
6154418 | Li | Nov 2000 | A |
6154419 | Shakkarwar | Nov 2000 | A |
6172927 | Taylor | Jan 2001 | B1 |
6202139 | Witt et al. | Mar 2001 | B1 |
6216205 | Chin et al. | Apr 2001 | B1 |
6259648 | Kragick | Jul 2001 | B1 |
6259652 | Heyne et al. | Jul 2001 | B1 |
6263410 | Kao et al. | Jul 2001 | B1 |
6269413 | Sherlock | Jul 2001 | B1 |
6327642 | Lee et al. | Dec 2001 | B1 |
6330636 | Bondurant et al. | Dec 2001 | B1 |
6337809 | Kim et al. | Jan 2002 | B1 |
6337830 | Faue | Jan 2002 | B1 |
6339558 | Ioki | Jan 2002 | B1 |
6366529 | Williams et al. | Apr 2002 | B1 |
6381194 | Li | Apr 2002 | B2 |
6381684 | Hronik et al. | Apr 2002 | B1 |
6532185 | Calvignac | Mar 2003 | B2 |
6557053 | Bass | Apr 2003 | B1 |
Number | Date | Country | |
---|---|---|---|
20040193805 A1 | Sep 2004 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09721478 | Nov 2000 | US |
Child | 10307638 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10307638 | Dec 2002 | US |
Child | 10818018 | US |