A static random access memory device includes a plurality of local latch circuits coupled between a data communication line and a common memory array block. The local latch circuits allow a series of data signals to be received on the data communication line and latched for writing to the memory array block in one memory write operation. The local latch circuits provide for a burst of data to be written in a single memory array block in a single write operation.

Patent
   6219283
Priority
Sep 03 1998
Filed
Sep 03 1998
Issued
Apr 17 2001
Expiry
Sep 03 2018
Assg.orig
Entity
Large
15
10
all paid
13. A method of operating a memory device, the method comprising:
receiving a series of data input signals;
receiving an externally provided memory array start address;
generating a plurality of additional memory array addresses in response to the memory array start address;
sequentially activating a plurality of local latch circuits to latch a portion of the series of data input signals including a burst line of at least two addresses; and
writing the latched portions of the data input signals to a single memory array block in one write operation.
1. A static random access memory device comprising:
a memory array block having rows and columns of memory cells;
a data communication line for receiving input data; and
a plurality of local latch circuits coupled between the data communication line and the memory array block, such that a series of data signals received on the data communication line is latched in the plurality of local latch circuits for writing to the memory array block in one memory write operation; and
wherein a burst line of at least two addresses can be provided on a single data communication line to a single memory array block.
17. A static random access memory device comprising:
a memory array block having rows and columns of memory cells;
a data communication line for receiving input data; and
a plurality of local latch circuits coupled between a single data communication line and a single memory array block, such that a series of data signals having at least two addresses received on the single data communication line is latched in the plurality of local latch circuits for writing to the single memory array block in one memory write operation, wherein each of the plurality of local latch circuits comprise an inverter, and a logic gate couple to the inverter for providing a feedback path and resetting an output of the local latch circuit to a predetermined logic level.
6. A static random access memory device comprising:
a memory array block having rows and columns of memory cells;
address circuitry for receiving an externally provided memory array address and generating a series of additional memory array addresses, wherein the externally provided memory array address and the series of additional memory array addresses form a burst address sequence having at least two addresses;
a data communication input for receiving a series of input data including a burst address sequence having at least two addresses;
a plurality of local latch circuits coupled between the data communication input and the memory array block, such that the series of data signals received on the data communication input is latched in the plurality of local latch circuits for writing to the memory array block defined by the burst address sequence; and
coupling circuitry for coupling the series of input data to a single memory array block in one memory write operation after the series of input data is latched in the plurality of local latch circuits.
16. A data processing system comprising:
a memory controller; and
a static random access memory device comprising:
a memory array block having rows and columns of memory cells;
a data communication line for receiving input data;
a plurality of local latch circuits coupled between the data communication line and the memory array block, the plurality of local latch circuits each comprise an inverter, and a logic gate coupled to the inverter for providing a feedback path and resetting an output of the local latch circuit to a predetermined logic level, wherein a series of data signals including a burst line of at least two addresses received on the data communication line is latched in the plurality of local latch circuits such that the burst line can be written to a single memory array block in one memory write operation;
pass transistors coupled between the data communication line and the plurality of local latch circuits for selectively coupling the data communication line to the plurality of local latch circuits; and
write transistors coupled between the plurality of local latch circuits and the memory array block for selectively coupling the plurality of local latch circuits to the memory array block.
19. A static random access memory device comprising:
a memory array block having rows and columns of memory cells;
address circuitry for receiving an externally provided memory array address and generating a series of additional memory array addresses, wherein the externally provided memory array address and the series of additional memory array addresses form a burst address sequence;
a data communication input for receiving a series of input data;
a plurality of local latch circuits coupled between a single data communication input and a single memory array block, such that the series of data signals having at least two addresses received on the single data communication input is latched in the plurality of local latch circuits for writing to the single memory array block defined by the burst address sequence; and
coupling circuitry for coupling the series of input data to the memory array block in one memory write operation after the series of input data is latched in the plurality of local latch circuits, the coupling circuitry comprises a plurality of write pass transistors coupled between the plurality of local latch circuits and the memory array block for selectively coupling the plurality of local latch circuits to the memory array block.
2. The static random access memory device of claim 1 wherein each of the plurality of local latch circuits comprise:
an inverter; and
a logic gate coupled to the inverter for providing a feedback path and resetting an output of the local latch circuit to a predetermined logic level.
3. The static random access memory device of claim 1 further comprising pass transistors coupled between the data communication line and the plurality of local latch circuits for selectively coupling the data communication line to the plurality of local latch circuits.
4. The static random access memory device of claim 1 further comprising write transistors coupled between the plurality of local latch circuits and the memory array block for selectively coupling the plurality of local latch circuits to the memory array block.
5. The static random access memory device of claim 1 further comprising column pass transistors coupled between the plurality of local latch circuits and the memory array block for selectively coupling the plurality of local latch circuits to a column of the memory array block.
7. The static random access memory device of claim 6 wherein the coupling circuitry comprises a plurality of write pass transistors coupled between the plurality of local latch circuits and the memory array block for selectively coupling the plurality of local latch circuits to the memory array block.
8. The static random access memory device of claim 6 wherein each of the plurality of local latch circuits comprise:
an inverter; and
a NAND gate coupled to the inverter for providing a feedback path and resetting an output of the local latch circuit to a predetermined logic level.
9. The static random access memory device of claim 6 further comprising pass transistors coupled between the data communication input and the plurality of local latch circuits for selectively coupling the data communication input to the plurality of local latch circuits.
10. The static random access memory device of claim 6 wherein the data communication input is a pair of complementary data communication lines.
11. The static random access memory device of claim 6 wherein the burst address sequence is four addresses long, and the static random access memory device comprises four local latch circuits wherein the four local latch circuits respectively latch data for the four memory array block addresses.
12. The static random access memory device of claim 6 wherein the burst address sequence is N addresses long, and the static random access memory device comprises N local latch circuits wherein the N local latch circuits respectively latch data for the N memory array block addresses.
14. The method of claim 13 wherein the plurality of local latch circuits are activated by turning off a reset signal and selectively activating a pass transistor coupled between the local plurality of local latch circuits and a data input.
15. The method of claim 13 wherein the latched portions of the data input signals are written to the common memory array block by activating a plurality of write transistors located between the plurality of local latch circuits and the common memory array block.
18. The static random access memory device of claim 17 further comprising pass transistors coupled between the data communication line and the plurality of local latch circuits for selectively coupling the data communication line to the plurality of local latch circuits.
20. The static random access memory device of claim 19 wherein each of the plurality of local latch circuits comprise:
an inverter; and
a NAND gate coupled to the inverter for providing a feedback path and resetting an output of the local latch circuit to a predetermined logic level.

The present invention relates generally to memory devices and in particular the present invention relates to a static memory device which includes latch circuitry to minimize memory array blocks.

The performance of computer systems, especially personal computers, has improved dramatically due to the rapid growth in computer architecture design, and in particular, to the performance of computer memory. The speed with which a processor can access data is critical to its performance, while providing uniformly fast memory access can be cost prohibitive. To get around this problem, computer architectures have relied on a mix of fast, less dense, memory and slower bulk memory. In fact, many computer architectures have a multilevel memory architecture in which an attempt is made to find information in the fastest memory. If the information is not in that memory, a check is made at the next fastest memory. This process continues down through the memory hierarchy until the information sought is found. One critical component in such a memory hierarchy is a cache memory.

Cache memories rely on the principle of locality to attempt to increase the likelihood that a processor will find the information it is looking for in the cache memory. To do this, cache memories typically store contiguous blocks of data. In addition, the cache memory stores a tag which is compared to an address to determine whether the information the processor is seeking is present in the cache memory. Cache memories are usually constructed from higher speed memory devices such as static random access memory (SRAM). The typical cache memory transfers a cache line as a contiguous block of data, starting at the first word in the cache line and proceeding through to the last. Each of the bits of a cache line is typically stored in a different memory array block using one write operation. As such, numerous blocks of memory must be accessed for writing a line of data.

For the reasons stated above, and for other reasons stated below which will become apparent to those skilled in the art upon reading and understanding the present specification, there is a need in the art for an SRAM which can store a line of data in a single memory array block while maintaining a minimum number of input data lines.

The above mentioned problems with high speed memory devices and other problems are addressed by the present invention and will be understood by reading and studying the following specification. A memory is described which includes local data latches coupled to columns of a memory array.

In one embodiment, the present invention describes a static random access memory device comprising a memory array block having rows and columns of memory cells, a data communication line for receiving input data, and a plurality of local latch circuits coupled between the data communication line and the memory array block. A series of data signals received on the data communication line can be latched in the plurality of local latch circuits for writing to the memory array block in one memory write operation.

In another embodiment, static random access memory device is described which comprises a memory array block having rows and columns of memory cells, and address circuitry for receiving an externally provided memory array address and generating a series of additional memory array addresses. The externally provided memory array address and the series of additional memory array addresses form a burst address sequence. The static random access memory device further comprises a data communication input for receiving a series of input data, a plurality of local latch circuits coupled between the data communication input and the memory array block, and coupling circuitry for coupling the series of input data to the memory array block in one memory write operation after the series of input data is latched in the plurality of local latch circuits.

In another embodiment a method of operating a memory device is described. The method comprises receiving a series of data input signals, receiving an externally provided memory array start address, generating a plurality of additional memory array addresses in response to the memory array start address, sequentially activating a plurality of local latch circuits to latch a portion of the data input signals, and writing the latched portions of the data input signals to a common memory array block in one write operation.

FIG. 1 is a block diagram of a static memory device;

FIG. 2 is a block diagram of a data processing system;

FIG. 3 is a memory device which has a plurality of memory array blocks;

FIG. 4 is a memory device which has a plurality of memory array blocks and a plurality of data communication line pairs;

FIG. 5 is a block diagram of one embodiment of a memory incorporating the present invention;

FIG. 6 is a schematic diagram of one embodiment of a latch circuit; and

FIG. 7 is a timing diagram of the operation of the memory of FIG. 5.

In the following detailed description of the preferred embodiments, reference is made to the accompanying drawings which form a part hereof, and in which is shown by way of illustration specific preferred embodiments in which the inventions may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that logical, mechanical and electrical changes may be made without departing from the spirit and scope of the present inventions. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present invention is defined only by the appended claims.

A local data latch architecture is provided to allow write data to be queued for writing to memory. This architecture is particularly useful in SRAM memories which are being operated as a cache memory, but can be implemented in any memory device which operates in a burst fashion. Some cache operation specifications require that an entire line of memory be read or written before a new memory address can be presented to the memory. Further, it is desirable to have large memory cell blocks to decrease die size.

Referring to FIG. 1, a static memory 100 includes a memory array 102 constructed of rows and columns of static memory cells. Row decode circuit 104 and column 106 decode circuitry is provided to access the memory array in response to an address provided by an external controller, such as a microprocessor. Control circuitry 108 is provided to control either synchronous or asynchronous data communication between the memory 100 and external devices. I/O data buffers 110 are coupled to the data communication lines (DQ's) for bi-directional data communication with the memory array 102. The SRAM can be operated in a burst mode using address generator circuit 109 to provide a series of address in response to an externally provided start address. It will be appreciated that the description of SRAM 100 has been simplified to focus on specific features of the present invention and is not intended to be a detailed description of all the circuitry of a basic SRAM.

Memory array 102 is arranged in rows and columns of memory cells. The columns are defined by a pair of bit lines which communicate data stored in the memory cells to the sense amplifier circuits. The bit lines are complements of each other such that in an active state one bit line will be at a low signal level and the other bit line will be at a high signal level.

FIG. 2 is a schematic representation of a data processing apparatus designed in accordance with the present invention. In FIG. 2, microprocessor 200 is connected via address lines and control lines to a memory control circuit 202. The memory control circuit provides address and control signals to a memory device 100. The memory device sends and receives data over a data bus. Optional data bus buffer 210 between the memory data bus and the microprocessor data bus allows for amplification of the data signals, and/or synchronization with the microprocessor and memory control signals. A fast static random access memory (SRAM) cache circuit 100 provides higher speed access to data stored in the cache from the memory control circuit or the microprocessor. It will be appreciated that the memory control circuit 202 may be incorporated within the microprocessor.

Referring to FIG. 3, a memory device is illustrated which has a plurality of memory array blocks 210, 212 and 214 and 216. Each array block is coupled to a complementary data bus 220 through column pass circuitry 222 and write pass circuitry 224. If the memory is operated in a burst mode, a separate memory array block is required for each address in the burst address sequence. This is assuming that the sequence of data is to be written in one operation. As known to those skilled in the art, a burst mode uses an externally provided starting address and advances the starting address using internally generated addresses to either "burst" read or write data to a series of addresses. Thus, a burst line of two addresses can be written using the single complementary data bus, but at least two arrays are required. The data can be written in a common memory array block, however, if the data bits in a burst sequence is written after the receipt of each data bit. This option requires substantial power, and is not an attractive option.

Alternately, the array blocks could be reduced if the number of data buses were increased, as illustrated in FIG. 4. The memory includes two array blocks 230 and 232, column pass circuitry 233 and write pass circuitry 234. Note that two pairs of complementary data buses are provided, 236 and 238. Thus, a burst line having a length of two addresses can be provided in one array, but two data buses would be required. It will be appreciated that for burst lengths of eight addresses, either a significant number of memory arrays or data buses would be required with the memories of FIGS. 3 or 4.

Memory 100, of FIG. 1, has a reduced number of memory array blocks and a minimal width data bus. The memory includes data latches which are used to latch data provided on a common data bus and directed to the same array block. As such, a minimum number of array blocks and minimum data buses are required to implement a memory device which processes an entire burst line prior to receiving a new burst address. FIGS. 5 illustrates one embodiment of the latch circuitry provided in the present memory device. This embodiment includes a single data communication input, or bus, 300 which is inverted by inverter circuit 302 to provide complementary data signals on a pair of complementary bus outputs 304 and 306. The complementary data signals are selectively coupled to any of four latch circuits 308, 310, 312 and 314. The latch circuits are coupled to the memory cells or columns of an array block 320 via column pass devices 322. As such, each memory array block 320 has a plurality of local data latch circuits which are selectively coupled to columns of the memory array block. As explained below, the local data latches allow a line of data to be latched using a single data input pair (complementary signals) and written to a memory block in a single write operation.

One embodiment of the latch circuit 308 is illustrated in FIG. 6. The circuitry includes a latch 330, pass transistors 332, and write pass transistors 334. The pass transistors are used to selectively couple the data inputs 304 and 306 to the latch circuit in response to an input signal on line 324, while the write pass transistors are used to selectively couple the latch 330 to the memory array in response to an input signal on line 326. Each latch circuit 330 includes a NAND gate 340 and an inverter 342. The NAND gate has one input 344 operating as a feedback path, while the other input 346 is used to reset the latch circuit to a predetermined output logic level. During operation, a low reset signal (input 328) forces the output of the NAND gate high and the latch circuit inverter output low. A second inverter 348 is provided to allow the signal provided to the write pass transistor to follow the input of the latch. Thus, when the reset signal is high, the output of invertor 348 follows the latch input.

A timing diagram of a burst write operation performed on the memory circuitry of FIG. 5 is provided in FIG. 7. At time T0 the reset signal 328 is low. The output connections (DL and DL*) of the four latch circuits 308-314, therefore, is low. When the reset signal transitions high, the latch circuits are free to follow their input signals. As illustrated, each of the four pass transistor gate signals, Pass 324<0:3>, are sequentially activated high to couple the data signal from 300 (or 306) to its respective latch 308-314. In this example, low, high, low and high signals provided on 300 and 306 are latched in latches 308, 310, 312 and 314, respectively. At Time T1, latch 308 is activated to latch data from lines 304 and 306. Latch 310 is activated at Time T2 to latch the input data. Likewise, latch 312 and 314 are activated at times T3 and T4, respectively. At time T4, therefore, a line of data is latched in the local latches and can be written to the memory array block in one write operation. After the last pass transistor has been activated (324<3>), the write pass transistors 334 of all the latch circuits are activated by a high transition of signal 326. This allows the entire line of data latched in the four latches to be written to the memory array in a single write operation. The reset signal can then transition low to reset the latch circuits. It will be appreciated by those skilled in the art that the column pass devices are operated to maintain isolation between the latch outputs and the memory array bit lines while the latch output is reset. Further, the pass transistors 332 can remain inactivated if a write mask operation is desired. That is, if a user desires not to write to some locations, the pass transistors 332 remain off in response to Pass 324<0:3> and the reset signal insures that the output signals are latched in a reset state.

A memory device has been described which includes a plurality of local latch circuits coupled between a data communication line and a common memory array block. The local latch circuits allow a series of data signals to be received on the data communication line and latched for writing to the memory array block in one memory write operation. Thus, a reduced number of data lines can be used while writing a burst line of data in a single memory array block in a single write operation.

Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement which is calculated to achieve the same purpose may be substituted for the specific embodiment shown. This application is intended to cover any adaptations or variations of the present invention. Therefore, it is manifestly intended that this invention be limited only by the claims and the equivalents thereof.

Wilford, John R.

Patent Priority Assignee Title
11151035, May 12 2019 International Business Machines Corporation Cache hit ratios for selected volumes within a storage system
11163698, May 12 2019 International Business Machines Corporation Cache hit ratios for selected volumes using synchronous I/O
11169919, May 12 2019 International Business Machines Corporation Cache preference for selected volumes within a storage system
11176052, May 12 2019 International Business Machines Corporation Variable cache status for selected volumes within a storage system
11237730, May 12 2019 International Business Machines Corporation Favored cache status for selected volumes within a storage system
6469954, Aug 21 2000 U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT Device and method for reducing idle cycles in a semiconductor memory device
6567338, Apr 19 1996 Integrated Device Technology, Inc. Fully synchronous pipelined RAM
6570816, Aug 21 2000 U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT Circuit and method for reducing memory idle cycles
6591354, Feb 23 1998 Integrated Device Technology, Inc. Separate byte control on fully synchronous pipelined SRAM
6621755, Aug 30 2001 U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT Testmode to increase acceleration in burn-in
6721233, Aug 21 2000 U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT Circuit and method for reducing memory idle cycles
6785188, Apr 19 1996 Integrated Device Technology, Inc. Fully synchronous pipelined RAM
7050342, Aug 30 2001 U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT Testmode to increase acceleration in burn-in
7069406, Jul 02 1999 Integrated Device Technology, Inc.; Integrated Device Technology, inc Double data rate synchronous SRAM with 100% bus utilization
9443615, Dec 04 2012 U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT Methods and apparatuses for memory testing with data compression
Patent Priority Assignee Title
4825416, May 07 1986 Advanced Micro Devices, Inc. Integrated electronic memory circuit with internal timing and operable in both latch-based and register-based systems
5261064, Oct 03 1989 Advanced Micro Devices, Inc. Burst access memory
5327390, Jul 25 1990 OKI SEMICONDUCTOR CO , LTD Synchronous burst-access memory
5361343, Jul 30 1991 Intel Corporation Microprocessor system including first and second nonvolatile memory arrays which may be simultaneously read and reprogrammed
5390149, Apr 23 1991 Texas Instruments Incorporated System including a data processor, a synchronous dram, a peripheral device, and a system clock
5617555, Nov 30 1995 ADVANCED DATA ACCESS LLC Burst random access memory employing sequenced banks of local tri-state drivers
5623624, Feb 01 1993 Micron Technology, Inc. Memory control architecture for high speed transfer options
5721859, Dec 23 1994 Round Rock Research, LLC Counter control circuit in a burst memory
5787489, Feb 21 1995 Micron Technology, Inc. Synchronous SRAM having pipelined enable
5978311, Mar 03 1998 U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT Memory with combined synchronous burst and bus efficient functionality
///////////
Executed onAssignorAssigneeConveyanceFrameReelDoc
Sep 02 1998WILFORD, JOHN R Micron Technology, IncASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0094440168 pdf
Sep 03 1998Micron Technology, Inc.(assignment on the face of the patent)
Apr 26 2016Micron Technology, IncU S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENTCORRECTIVE ASSIGNMENT TO CORRECT THE REPLACE ERRONEOUSLY FILED PATENT #7358718 WITH THE CORRECT PATENT #7358178 PREVIOUSLY RECORDED ON REEL 038669 FRAME 0001 ASSIGNOR S HEREBY CONFIRMS THE SECURITY INTEREST 0430790001 pdf
Apr 26 2016Micron Technology, IncMORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENTPATENT SECURITY AGREEMENT0389540001 pdf
Apr 26 2016Micron Technology, IncU S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENTSECURITY INTEREST SEE DOCUMENT FOR DETAILS 0386690001 pdf
Jun 29 2018U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENTMicron Technology, IncRELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS 0472430001 pdf
Jul 03 2018MICRON SEMICONDUCTOR PRODUCTS, INC JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENTSECURITY INTEREST SEE DOCUMENT FOR DETAILS 0475400001 pdf
Jul 03 2018Micron Technology, IncJPMORGAN CHASE BANK, N A , AS COLLATERAL AGENTSECURITY INTEREST SEE DOCUMENT FOR DETAILS 0475400001 pdf
Jul 31 2019JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENTMICRON SEMICONDUCTOR PRODUCTS, INC RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS 0510280001 pdf
Jul 31 2019JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENTMicron Technology, IncRELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS 0510280001 pdf
Jul 31 2019MORGAN STANLEY SENIOR FUNDING, INC , AS COLLATERAL AGENTMicron Technology, IncRELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS 0509370001 pdf
Date Maintenance Fee Events
May 01 2001ASPN: Payor Number Assigned.
Sep 16 2004M1551: Payment of Maintenance Fee, 4th Year, Large Entity.
Sep 24 2008M1552: Payment of Maintenance Fee, 8th Year, Large Entity.
Sep 19 2012M1553: Payment of Maintenance Fee, 12th Year, Large Entity.


Date Maintenance Schedule
Apr 17 20044 years fee payment window open
Oct 17 20046 months grace period start (w surcharge)
Apr 17 2005patent expiry (for year 4)
Apr 17 20072 years to revive unintentionally abandoned end. (for year 4)
Apr 17 20088 years fee payment window open
Oct 17 20086 months grace period start (w surcharge)
Apr 17 2009patent expiry (for year 8)
Apr 17 20112 years to revive unintentionally abandoned end. (for year 8)
Apr 17 201212 years fee payment window open
Oct 17 20126 months grace period start (w surcharge)
Apr 17 2013patent expiry (for year 12)
Apr 17 20152 years to revive unintentionally abandoned end. (for year 12)