Information
-
Patent Grant
-
6741253
-
Patent Number
6,741,253
-
Date Filed
Tuesday, October 9, 200124 years ago
-
Date Issued
Tuesday, May 25, 200421 years ago
-
Inventors
-
Original Assignees
-
Examiners
Agents
-
CPC
-
US Classifications
Field of Search
US
- 345 531
- 345 536
- 345 537
- 345 539
- 345 545
- 345 556
- 345 558
- 345 561
- 345 565
- 711 108
- 711 109
- 711 155
- 714 48
- 714 763
- 714 764
- 714 766
-
International Classifications
-
Abstract
A system and method for accessing a memory array where retrieved data is stored in a memory and upon the writing of the data in its modified form, the originally stored data is updated with the modification prior to being written back to the memory array. In this manner, a new error correction code can be calculated prior to writing the data without the need to access the memory array again.
Description
TECHNICAL FIELD
The present invention is related generally to the field of computer graphics, and more particularly, to an embedded memory system and method having efficient utilization of read and write bandwidth of a computer graphics processing system.
BACKGROUND OF THE INVENTION
Graphics processing systems often include embedded memory to increase the throughput of processed graphics data. Generally, embedded memory is memory that is integrated with the other circuitry of the graphics processing system to form a single device. Including embedded memory in a graphics processing system allows data to be provided to processing circuits, such as the graphics processor, the pixel engine, and the like, with low access times. The proximity of the embedded memory to the graphics processor and its dedicated purpose of storing data related to the processing of graphics information enable data to be moved throughout the graphics processing system quickly. Thus, the processing elements of the graphics processing system may retrieve, process, and provide graphics data quickly and efficiently, increasing the processing throughput.
Processing operations that are often performed on graphics data in a graphics processing system include the steps of reading the data that will be processed from the embedded memory, modifying the retrieved data during processing, and writing the modified data back to the embedded memory. This type of operation is typically referred to as a read-modify-write (RMW) operation. The processing of the retrieved graphics data is often done in a pipeline processing fashion, where the processed output values of the processing pipeline are rewritten to the locations in memory from which the pre-processed data provided to the pipeline was originally retrieved. Examples of RMW operations include blending multiple color values to produce graphics images that are composites of the color values and Z-buffer rendering, a method of rendering only the visible surfaces of three-dimensional graphics images.
In conventional graphics processing systems including embedded memory, the memory is typically a single-ported memory. That is, the embedded memory either has only one data port that is multiplexed between read and write operations, or the embedded memory has separate read and write data ports, but the separate ports cannot be operated simultaneously. Consequently, when performing RMW operations, such as described above, the throughput of processed data is diminished because the single ported embedded memory of the conventional graphics processing system is incapable of both reading graphics data that is to be processed and writing back the modified data simultaneously. In order for the RMW operations to be performed, a write operation is performed following each read operation. Thus, the flow of data, either being read from or written to the embedded memory, is constantly being interrupted. As a result, full utilization of the read and write bandwidth of the graphics processing system is not possible.
One approach to resolving this issue is to design the embedded memory included in a graphics processing system to have dual ports. That is, the embedded memory has both read and write ports that may be operated simultaneously. Having such a design allows for data that has been processed to be written back to the dual ported embedded memory while data to be processed is read. However, providing the circuitry necessary to implement a dual ported embedded memory significantly increases the complexity of the embedded memory and requires additional circuitry to support dual ported operation. As space on an graphics processing system integrated into a single device is at a premium, including the additional circuitry necessary to implement a multi-port embedded memory, such as the one previously described, may not be an reasonable alternative.
Another issue that can further complicate efficient utilization of read write memory bandwidth is implementing an error correction code (ECC) scheme in an embedded memory system. In general, ECCs are used to maintain the integrity of data written to memory, and can, in some instances when an error in the data is detected, correct the errors. In operation, when data are written to memory, a calculation is performed on the data to produce a code. The code, which is stored with the data, is used to detect and correct errors in the data. When the data is read from memory, the code calculation is once again performed on the retrieved data, and the resulting code is compared with the code that was stored with the data. Ideally, the two codes are the same, indicating that the data has not changed since being written to memory. However, if the two codes are different, an error in the data has occurred, and, through the use of the code, a corrected set of data may be produced. Thus, although the data retrieved from memory may have an error, the data that is actually provided to a requesting entity will be correct. In the case the error in the data cannot be corrected by the code, the condition is reported.
The general use of ECC techniques in memory systems is known in the art. For example, use of Hamming codes, Reed-Solomon codes, and the like, for ECC is well understood. Such techniques have been used at various memory levels, including at the embedded memory level. However, these ECC schemes are generally cumbersome and negatively impact memory access rates. In systems where high data read and write throughput is desired, overcoming these issues while maintaining data throughput becomes a daunting proposition.
Therefore, there is a need for a method and embedded memory system having ECC capability that can utilize the read and write bandwidth of a graphics processing system more efficiently during a read-modify-write processing operation.
SUMMARY OF THE INVENTION
The present invention is directed to a system and method for accessing a memory array where retrieved data is stored in a memory and upon the writing of the data in its modified form, the originally stored data is updated with the modification prior to being written back to the memory array. In this manner, a new error correction code can be calculated prior to writing the data without the need to access the memory array again. The system includes a memory having a plurality of memory locations for storing data in a first-in-first-out (FIFO) manner, a content addressable memory (CAM) coupled to the memory and having an input to receive memory addresses and having a plurality of memory locations for storing memory addresses, each of which corresponds to a memory location of the memory. The CAM provides an activation signal to access a memory location of the memory in response to receiving a memory address matching the corresponding stored memory address. The system further includes a first switch coupled to the output of the memory to selectively couple the output of the memory to the write bus or an output bus, a combining circuit having a first input, a second input coupled to the output of the memory, and further having an output coupled to the input of the memory, the combining circuit combining data applied to the first and second inputs and providing the result at the output, and a second switch to selectively couple the first input of the combining circuit to the read bus or an input bus. A FIFO control circuit is coupled to the combining circuit, the first and second switches, and the memory. In response to receiving a read request, the FIFO control circuit coordinates the storing of the requested data in the memory and providing the requested data to the output bus, and in response to receiving a write request, the FIFO control circuit coordinates the combining of modified data received from the input bus with corresponding original data previously stored in the memory and providing the combined data for error correction code calculation and writing to the location in the memory array from where the corresponding original data was originally read.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1
is a block diagram of a system in which embodiments of the present invention may be implemented.
FIG. 2
is a block diagram of a graphics processing system in the system of FIG.
1
.
FIG. 3
is a block diagram of a portion of a memory system according to an embodiment of the present invention.
DETAILED DESCRIPTION OF THE INVENTION
Embodiments of the present invention provide a memory system and method having error correction capability that allows for efficient read-modify-write operations and error correction code calculation. Certain details are set forth below to provide a sufficient understanding of the invention. However, it will be clear to one skilled in the art that the invention may be practiced without these particular details. In other instances, well-known circuits, control signals, timing protocols, and software operations have not been shown in detail in order to avoid unnecessarily obscuring the invention.
FIG. 1
illustrates a computer system
100
in which embodiments of the present invention may be implemented. The computer system
100
includes a processor
104
coupled to a memory
108
through a memory/bus interface
112
. The memory/bus interface
112
is coupled to an expansion bus
116
, such as an industry standard architecture (ISA) bus or a peripheral component interconnect (PCI) bus. The computer system
100
also includes one or more input devices
120
, such as a keypad or a mouse, coupled to the processor
104
through the expansion bus
116
and the memory/bus interface
112
. The input devices
120
allow an operator or an electronic device to input data to the computer system
100
. One or more output devices
124
are coupled to the processor
104
to receive output data generated by the processor
104
. The output devices
124
are coupled to the processor
104
through the expansion bus
116
and memory/bus interface
112
. Examples of output devices
124
include printers and a sound card driving audio speakers. One or more data storage devices
128
are coupled to the processor
104
through the memory/bus interface
112
and the expansion bus
116
to store data in, or retrieve data from, storage media (not shown). Examples of storage devices
128
and storage media include fixed disk drives, floppy disk drives, tape cassettes and compact-disc read-only memory drives.
The computer system
100
further includes a graphics processing system
132
coupled to the processor
104
through the expansion bus
116
and memory/bus interface
112
. Optionally, the graphics processing system
132
may be coupled to the processor
104
and the memory
108
through other types of architectures. For example, the graphics processing system
132
may be coupled through the memory/bus interface
112
and a high speed bus
136
, such as an accelerated graphics port (AGP), to provide the graphics processing system
132
with direct memory access (DMA) to the memory
108
. That is, the high speed bus
136
and memory bus interface
112
allow the graphics processing system
132
to read and write memory
108
without the intervention of the processor
104
. Thus, data may be transferred to, and from, the memory
108
at transfer rates much greater than over the expansion bus
116
. A display
140
is coupled to the graphics processing system
132
to display graphics images. The display
140
may be any type of display, such as those commonly used for desktop computers, portable computers, and workstations, for example, a cathode ray tube (CRT), a field emission display (FED), a liquid crystal display (LCD), or the like.
FIG. 2
illustrates circuitry included within the graphics processing system
132
for performing various graphics and video functions. As shown in
FIG. 2
, a bus interface-
200
couples the graphics processing system
132
to the expansion bus
116
and optionally high-speed bus
136
. In the case where the graphics processing system
132
is coupled to the processor
104
and the memory
108
through the high speed data bus
136
and the memory/bus interface
112
, the bus interface
200
will include a DMA controller (not shown) to coordinate transfer of data to and from the host memory
108
and the processor
104
. A graphics processor
204
is coupled to the bus interface
200
and is designed to perform various graphics and video processing functions, such as, but not limited to, generating vertex data and performing vertex transformations for polygon graphics primitives that are used to model 3D objects. The graphics processor
204
is coupled to a triangle engine
208
that includes circuitry for performing various graphics functions, such as clipping, attribute transformations, rendering of graphics primitives, and generating texture coordinates for a texture map.
A pixel engine
212
is coupled to receive the graphics data generated by the triangle engine
208
. The pixel engine
212
contains circuitry for performing various graphics functions, such as, but not limited to, texture application or mapping, bilinear filtering, fog, blending, and color space conversion. A memory controller
216
coupled to the pixel engine
212
and the graphics processor
204
handles memory requests to and from a local memory
220
. The local memory
220
stores graphics data, such as pixel values. A display controller
224
is coupled to the memory controller
216
to receive processed values for pixels that are to be displayed. The output values from the display controller
224
are subsequently provided to a display driver
232
that includes circuitry to provide digital signals, or convert digital signals to analog signals, to drive the display
140
(FIG.
1
). It will be appreciated that the circuitry included in the graphics processing system
132
to practice embodiments of the present invention may be of conventional designs well understood by those of ordinary skill in the art.
Illustrated in
FIG. 3
is portion of a memory system according to an embodiment of the present invention. An error correction code (ECC) generator
302
and ECC checking circuitry
304
are coupled to the input and output busses of an embedded memory
306
. The embedded memory
306
is illustrated as having multiple banks of single-ported embedded memory
306
a-c
. Although only three banks are shown in
FIG. 3
, it will be appreciated that the number of banks of embedded memory can be modified without departing from the scope of the present invention. The ECC generator and checking circuitry
302
and
304
, as well as the embedded memory
306
, are conventional and can be implemented using a variety of circuitry and techniques well-known to those of ordinary skill in the art.
Coupled to the ECC generator
302
and the ECC checking circuitry
304
is a memory
310
. The memory
310
is divided into memories
310
a
and
310
b
, each being arranged in a first-in-first-out (FIFO) fashion. The output of the memories
310
a
and
310
b
are coupled to selection circuits
316
and
318
. The selection circuit
316
selectively couples data from either the memory
310
a
or the memory
310
b
to the ECC generator
302
for calculation of an error correction code and storage in the embedded memory
306
. The selection circuit
318
, on the other hand, selects data from the memories
310
a
and
310
b
to be provided in response to a read command issued to the embedded memory
306
. Coupled to the input of memories
310
a
and
310
b
through combinatorial circuits
326
and
330
are selection circuits
320
and
322
, all respectively. The selection circuits
320
and
322
selectively provide to the input of the memories
310
a
and
310
b
either the output of the embedded memory
306
and the ECC generator
302
, or data being written to the embedded memory
306
. The combinatorial circuits
326
and
330
are coupled to receive both the output of a respective selection circuit, and the output of the memory to which the combinatorial circuit is coupled. Thus, the output of the selection circuits
320
and
322
may be combined by combinatorial circuits
326
and
330
with the output of the respective memories
310
a
and
310
b
. As will be explained in more detail below, partial write data may be combined with pre-processed data stored in the memories
310
a
and
310
b
by the combinatorial circuits
326
and
330
to facilitate the calculation of error correction codes when writing the data back to the embedded memory
306
. In a partial write operation, only a portion of the total length of the data read is modified. Thus, data previously stored in the memory
310
can be updated with the modified portion, and subsequently, the updated data can be used for calculating a new error correction code.
A content addressable memory (CAM)
350
is coupled to the memory
310
. The CAM
350
is divided into CAMs
350
a
and
350
b
, which are coupled to the memories
310
a
and
310
b
, respectively, for maintaining organization of data stored in the memories
310
a
and
310
b
, and to allow for data to be stored and accessed by the respective memory address. The CAMs
350
a
and
350
b
are coupled to receive memory addresses of read and write operations directed to the embedded memory
306
. Each location in which a memory address can be stored in the CAMs
350
a
and
350
b
corresponds to a memory location in the memories
310
a
and
310
b
, respectively, into which data can be stored. Upon receiving a memory address for a read or write operation that matches one of the addresses stored in either CAM
350
a
or
350
b
, data can be read from or written to the associated memory location in the memory
310
.
Control of the selection circuits
316
,
318
,
320
, and
322
, and the combinatorial circuits
326
and
330
are delegated to a FIFO control circuit
356
. Coordination of reading and writing data and memory addresses to the memory
310
and the CAM
350
are also under the control of the FIFO control circuit
356
. As will be explained in more detail below, the FIFO control circuit
356
coordinates the operation of the selection circuits
316
,
318
,
320
, and
322
with the operation of the combinatorial circuits
326
and
330
, and the memory
310
and the CAM
350
such that high read and write bandwidth of an embedded memory system having ECC capability can be maintained with minimal performance costs.
As mentioned previously, the selection circuits
316
and
318
selectively couple the output of the memories
310
a
and
310
b
to provide data to the ECC generator
302
and the embedded memory
306
, or to provide data to a requesting entity in response to a read operation. The selection circuits
320
and
330
similarly selectively couple the input of the memories
310
a
and
310
b
to receive data from the embedded memory
306
and ECC check circuitry
304
, or to receive write data. In an embodiment of the present invention, the memories
310
a
and
310
b
provide data to and receive data from a graphics processing pipeline as described in U.S. patent application Ser. No. 09/736,861, entitled MEMORY SYSTEM AND METHOD FOR IMPROVED UTILIZATION OF READ AND WRITE BANDWIDTH OF A GRAPHICS PROCESSING SYSTEM to Radke, filed Dec. 13, 2001, which is incorporated herein by reference. In summary, the graphics processing pipeline and memory system described therein provides for uninterrupted read-modify-write operations in a memory having multiple single-ported banks of embedded memory. The multiple banks of memory are interleaved to allow data to be modified by the processing pipeline to be written to one bank of the embedded memory while reading pre-processed data from another bank. Another bank of the memory is precharged during the reading and writing operation in the other memory banks in order for the read-modify-write operation to continue into the precharged bank uninterrupted. As explained in more detail in the aforementioned patent application, the length of the graphics processing pipeline is such that after reading and processing data from a first bank, reading of pre-processed data from a second bank may be performed while writing modified data back to the bank from which the pre-processed data was previously read.
The operation of the memory system illustrated in
FIG. 3
will now be described briefly, followed by a more detailed description of its operation.
The memories
310
a
and
310
b
allow for data that has been read from the embedded memory
306
to be temporarily stored in its pre-processed form during the processing of that data, and then for the pre-processed data to be later combined with the resulting post-processed data before being written back to the embedded memory
306
. Thus, where only a portion of the of the original data is modified during the processing, the partial write data can be combined with the pre-processed data located in the memory
310
, and calculation of the error correction code by the ECC generator
302
for the modified data can be performed in-line when writing the data back to the embedded memory
306
. This technique avoids the need to read the pre-processed data a second time from the embedded memory
306
in order to calculate the correct ECC when performing a partial write operation.
In operation, when data is requested from the embedded memory
306
, the memory address of the requested data is stored in one of the CAMs
350
a
or
350
b
. As will be explained in more detail below, the particular CAM into which the memory address is written may be based on whether the memory address is even or odd. The requested data is read from the embedded memory
306
and the error code associated with requested data is compared by the ECC check circuitry
304
to confirm the integrity of the data. Corrections to the requested data are made if necessary and if possible. The requested data is then written in its pre-processed form to the memory location of memory
310
a
or memory
310
b
that is associated with the location in the CAM
350
to which the memory address is written. Thus, when the address is provided again to the CAM
350
, the pre-processed data will be accessed in the associated memory location of memory
310
. As mentioned previously, coordination of the CAM
350
, the selection circuits
320
and
322
, and the combinatorial circuits
326
and
330
, are controlled by the FIFO control circuit
356
in order to write the requested data into the appropriate memory location of the memory
310
. The requested data is further output to the selection circuit
318
to be provided to the requesting entity.
In the case where the data has been requested for processing, for example, through a graphics processing pipeline, the post-processed data may need to be written back to the location in the embedded memory
306
from which the data in its pre-processed from was retrieved. Further complicating the matter is that in the case of a partial write, it may be that only a portion of the entire data has been modified by the processing. Consequently, when writing the modified data back to the embedded memory
306
, a new error correction code will need to be calculated. In this situation, the entire length of data must be available and then combined with the partial write data before a new error correction code can be correctly calculated. In a conventional memory system, obtaining the full length of the pre-processed data requires a second read from the embedded memory, thus resulting in delays caused by the inherent memory access latency. Where data is being processed through a graphics processing pipeline such as one described in the aforementioned patent application, the additional delays in obtaining the pre-processed data, combining that data with the partial write data, and then calculating a new error correction code, will significantly reduce the processing throughput.
In contrast to conventional memory systems, when performing a partial write in embodiments of the present invention, a second access to the embedded memory
306
can be avoided because the pre-processed data is already present in the memory
310
from when the data was originally read from the embedded memory
306
. Upon performing the partial write, the partial write data is provided to selection circuits
320
and
322
, and the memory address to which the partial write is directed is provided to the CAM
350
. As a result of the pre-processed data being stored in the memory
310
, and being indexed according to its address, which is stored in the CAM
350
, receipt of the matching memory address by the CAM
350
will result in the pre-processed data being output by the memory
310
. The pre-processed data is provided from the output of the memory
310
to the respective combinatorial circuit
326
or
330
. The FIFO control circuit
356
directs the selection circuits
320
and
322
to provide at the respective outputs the partial write data, and then activates the combinatorial circuits
326
and
330
. As a result, the combinatorial circuit, having the pre-processed data and the partial write data applied to its inputs, will produce modified data including the partial write data that can be written back to the embedded memory
306
.
The modified data is then provided to the inputs of the selection circuits
316
and
318
. The FIFO control circuit
356
directs the selection circuit
316
to couple the output of the memories
310
a
or
310
b
, that is, the output of whichever memory had been storing the pre-processed data, to the input to the ECC generator
302
. An error correction code is calculated, and the write operation is completed when the modified post-processed data is written to the memory location in the embedded memory
306
that corresponds to the write address applied to the CAM
350
.
Although the previous example described the use of only one of the memories of the memory
310
and one of the CAMs of the CAM
350
, having two memories
310
a
and
310
b
and two CAMs
350
a
and
350
b
are preferred. As illustrated in
FIG. 3
, the memory
310
is divided into memories
310
a
and
310
b
, and the CAM
350
divided into CAMs
350
a
and
350
b
, each CAM coupled to a respective memory
310
a
and
310
b
in order to provide organization and access. It will be appreciated that selection of the memory
310
a
or
310
b
into which data will be written may be made based on several criteria, such as, whether the memory address of the data is even or odd, or the physical location of the array from which the data is retrieved. By having two sets of memories
310
a
and
310
b
, and CAMs
350
a
and
350
b
, reading and writing operations can be interleaved between the two memory and CAM sets to allow for efficient use of the read and write busses of the embedded memory
306
.
For example, when a first read command is issued, the first read address is stored in CAM
350
a
and the first pre-processed read data returned by the embedded memory
306
is stored in the associated memory location in the memory
310
a
. The first pre-processed read data is also provided to the requesting entity through the selection circuit
318
, which is under the control of the FIFO control circuit
356
. Concurrently with the execution of the first read command, a first write command is issued. The first write address is applied to the CAM
350
b
and the first post-processed write data is applied to the input of the selection circuits
320
and
322
. Assuming that the pre-processed data that yielded the first post-processed write data is present in the memory
310
b
, application of the address to the CAM
350
b
results in the pre-processed data being output to the combinatorial circuit
330
. Under the control of the FIFO control circuit
356
, the selection circuit
322
selects the write data to be applied to the combinatorial circuit
330
in order to be combined with the pre-processed data. The resulting modified data is then output and provided through the selection circuit
316
to ECC generator
302
to be written back to the embedded memory
306
.
At a time following the completion of the first read and write operations, a second read command is issued. A second read address for the second read command is directed to and stored in the CAM
350
b
, and a second pre-processed read data from the embedded memory
306
is stored in an associated memory location in the memory
310
a
. The selection circuit
318
is then directed by the FIFO control circuit
356
to provide the second pre-processed read data to the requesting entity. Concurrently, a second write command is issued. It will be assumed that the pre-processed data that yielded the second post-processed write data is present in the memory
310
a
. Thus, application of the address to the CAM
350
a
results in the pre-processed data being output to the combinatorial circuit
320
. The selection circuit
322
is commanded to select the second post-processed write data to be applied to the combinatorial circuit
320
in order to be combined with the pre-processed data just output by the memory
310
a
. To complete the second write command, the resulting combined data is then output and provided through the selection circuit
316
to ECC generator
302
to be written back to the embedded memory
306
.
As illustrated by the previous example, interleaving the use of the memory and CAM sets,
310
a
and
350
a
, and
310
b
and
350
b
, allows for read and write commands to be performed relatively concurrently. This feature is desirable where data is being processed through a graphics processing pipeline such as the one described in the aforementioned patent application. That is, the error correction capability of embodiments of the present invention can be combined with the read-modify-write technique provided by the processing pipeline structure and method to provide improved utilization of the read and write bandwidth of a graphics processing system while still including error correction capability.
It will be appreciated that the capacity or length of the memories
310
a
and
310
b
can be adjusted according the to desired functionality of the system. Where the memory and CAM pairs will be used with a graphics pipeline as described in the aforementioned patent, the memories
310
a
and
310
b
should be of sufficient length to accommodate the write-back portion of a read-modify-write operation to the memory array from which the original data was retrieved. The length of the memory may also be adjusted based on the space available. It will be further appreciated that the description provided herein, although well-known circuits, control signals, timing protocols, and software operations have not been shown in detail in the interest of brevity, is sufficient to enable one of ordinary skill in the art to practice the present invention.
From the foregoing it will also be appreciated that, although specific embodiments of the invention have been described herein for purposes of illustration, various modifications may be made without deviating from the spirit and scope of the invention. Accordingly, the invention is not limited except as by the appended claims.
Claims
- 1. In a memory system having at least one memory array, a read bus, a write bus, and error correction capability, an apparatus comprising:a memory having a plurality of memory locations for storing data in a first-in-first-out (FIFO) manner, the memory further having an output from which data is read and an input to which data is written; a content addressable memory (CAM) coupled to the memory and having an input to receive memory addresses and having a plurality of memory locations for storing memory addresses, each location corresponding to a memory location of the memory, the CAM providing an activation signal to access a memory location of the memory in response to receiving a memory address matching the corresponding stored memory address; a first switch coupled to the output of the memory to selectively couple the output of the memory to the write bus or an output bus; a combining circuit having a first input, a second input coupled to the output of the memory, and further having an output coupled to the input of the memory, the combining circuit combining data applied to the first and second inputs and providing the result at the output; a second switch to selectively couple the first input of the combining circuit to the read bus or an input bus; and a FIFO control circuit coupled to the combining circuit, the first and second switches, and the memory, in response to receiving a read request, the FIFO control circuit coordinating the storing of the requested data in the memory and providing the requested data to the output bus, and in response to receiving a write request, the FIFO control circuit coordinating the combining of modified data received from the input bus with corresponding original data previously stored in the memory and providing the combined data for error correction code calculation and writing to the location in the memory array from where the corresponding original data was originally read.
- 2. The apparatus of claim 1 wherein the memory array is an embedded memory array.
- 3. The apparatus of claim 1 wherein the combining circuit comprises a logic circuit.
- 4. The apparatus of claim 1 wherein the memory comprises a static random access memory.
- 5. The apparatus of claim 1, further comprising:a second memory having a plurality of memory locations for storing data in a first-in-first-out (FIFO) manner, the memory further having an output from which data is read and an input to which data is written; a second CAM coupled to the second memory and having an input to receive memory addresses and having a plurality of memory locations for storing memory addresses, each location corresponding to a memory location of the second memory, the second CAM providing an activation signal to access a memory location of the second memory in response to receiving a memory address matching the corresponding stored memory address; and a second combining circuit having a first input, a second input coupled to the output of the second memory, and further having an output coupled to the input of the second memory, the second combining circuit combining data applied to the first and second inputs and providing the result at its output.
- 6. The apparatus of claim 5 wherein the FIFO control circuit further coordinates the combining of modified data with previously stored data in the second memory substantially concurrently with the storing of the requested data in the memory, and the storing of data in the second memory substantially concurrently with the combining of the modified data with the original data previously stored in the memory.
- 7. In a memory system having at least one memory array, a read bus, a write bus, and error correction capability, an apparatus comprising:first and second memories, each memory having a plurality of memory locations for storing data in a first-in-first-out (FIFO) manner and further having an output from which data is read and an input to which data is written; first and second content addressable memories (CAMs), each CAM coupled to a respective memory and having an input to receive memory addresses and having a plurality of memory locations for storing memory addresses, each location corresponding to a memory location of the respective memory, each CAM providing an activation signal to access a memory location of the respective memory in response to receiving a memory address matching the corresponding stored memory address; a first selection circuit coupled to the outputs of the memories to selectively couple one of the outputs to the write bus a second selection circuit coupled to the outputs of the memories to selectively couple one of the outputs to an output bus; first and second combining circuits, each having a first input, a second input coupled to the output of a respective memory, and further having an output coupled to the input of the respective memory, each combining circuit combining data applied to the first and second inputs and providing the result at the output; third selection circuit coupled to the read bus and an input bus to selectively coupled the read bus or input bus to the first input of the first combining circuit; a fourth selection circuit coupled the read bus and an input bus to selectively coupled the read bus or input bus to the first input of the second combining circuit; a FIFO control circuit coupled to the first and second combining circuits, the first, second, third, and fourth selection circuits, and the first and second memories, in response to receiving a read request, the FIFO control circuit coordinating the storing of the requested data in one of the memories and providing the requested data to the output bus, and in response to receiving a write request, the FIFO control circuit coordinating the combining of modified data received from the input bus with corresponding original data previously stored in the other memory and providing the combined data for error correction code calculation and writing to the location in the memory array from where the corresponding original data was originally read.
- 8. The apparatus of claim 7 wherein the first and second memories comprise static random access memories.
- 9. The apparatus of claim 7 wherein the memory array comprises an embedded memory.
- 10. The apparatus of claim 7 wherein the first and second combining circuits comprise logic circuits.
- 11. A graphics processing system, comprising:at least one memory array; a read bus coupled to the memory array on which data is retrieved from the memory array; a write bus coupled to the memory array on which the data is provided to the memory array for storage; a memory having a plurality of memory locations for storing data in a first-in-first-out (FIFO) manner, the memory further having an output from which data is read and an input to which data is written; a content addressable memory (CAM) coupled to the memory and having an input to receive memory addresses and having a plurality of memory locations for storing memory addresses, each location corresponding to a memory location of the memory, the CAM providing an activation signal to access a memory location of the memory in response to receiving a memory address matching the corresponding stored memory address; a first switch coupled to the output of the memory to selectively couple the output of the memory to the write bus or an output bus; a combining circuit having a first input, a second input coupled to the output of the memory, and further having an output coupled to the input of the memory, the combining circuit combining data applied to the first and second inputs and providing the result at the output; a second switch to selectively couple the first input of the combining circuit to the read bus or an input bus; and a FIFO control circuit coupled to the combining circuit, the first and second switches, and the memory, in response to receiving a read request, the FIFO control circuit coordinating the storing of the requested data in the memory and providing the requested data to the output bus, and in response to receiving a write request, the FIFO control circuit coordinating the combining of modified data received from the input bus with corresponding original data previously stored in the memory and providing the combined data for error correction code calculation and writing to the location in the memory array from where the corresponding original data was originally read.
- 12. The graphics processing system of claim 11, further comprising:an error correction code (ECC) generator coupled to the write bus and the memory array for generating an ECC in response to writing data to the memory array; and an ECC check circuit coupled to the memory array and the read bus for confirming the integrity of the data based on an associated ECC.
- 13. The graphics processing system of claim 11 wherein the memory array is an embedded memory array.
- 14. The graphics processing system of claim 11 wherein the combining circuit comprises a logic circuit.
- 15. The graphics processing system of claim 11 wherein the memory comprises a static random access memory.
- 16. The graphics processing system of claim 11, further comprising:a second memory having a plurality of memory locations for storing data in a first-in-first-out (FIFO) manner, the memory further having an output from which data is read and an input to which data is written; a second CAM coupled to the second memory and having an input to receive memory addresses and having a plurality of memory locations for storing memory addresses, each location corresponding to a memory location of the second memory, the second CAM providing an activation signal to access a memory location of the second memory in response to receiving a memory address matching the corresponding stored memory address; and a second combining circuit having a first input, a second input coupled to the output of the second memory, and further having an output coupled to the input of the second memory, the second combining circuit combining data applied to the first and second inputs and providing the result at its output.
- 17. The graphics processing system of claim 16 wherein the FIFO control circuit further coordinates the combining of modified data with previously stored data in the second memory substantially concurrently with the storing of the requested data in the memory, and the storing of data in the second memory substantially concurrently with the combining of the modified data with the original data previously stored in the memory.
- 18. The graphics processing system of claim 11, further comprising a graphics processing pipeline coupled to the output and input busses for processing the data.
US Referenced Citations (13)
| Number |
Name |
Date |
Kind |
|
5809228 |
Langendorf et al. |
Sep 1998 |
A |
|
5831673 |
Przyborski et al. |
Nov 1998 |
A |
|
5860112 |
Langendorf et al. |
Jan 1999 |
A |
|
5987628 |
Von Bokern et al. |
Nov 1999 |
A |
|
6002412 |
Schinnerer |
Dec 1999 |
A |
|
6112265 |
Harriman et al. |
Aug 2000 |
A |
|
6115837 |
Nguyen et al. |
Sep 2000 |
A |
|
6151658 |
Magro |
Nov 2000 |
A |
|
6272651 |
Chin et al. |
Aug 2001 |
B1 |
|
6366984 |
Carmean et al. |
Apr 2002 |
B1 |
|
6401168 |
Williams et al. |
Jun 2002 |
B1 |
|
6470433 |
Prouty et al. |
Oct 2002 |
B1 |
|
6523110 |
Bright et al. |
Feb 2003 |
B1 |