Electrical computers and digital data processing systems: input/ – Input/output data processing – Data transfer specifying
Reexamination Certificate
2002-01-07
2004-07-20
Gaffin, Jeffrey (Department: 2182)
Electrical computers and digital data processing systems: input/
Input/output data processing
Data transfer specifying
C710S010000, C710S033000, C711S005000, C711S105000, C711S154000, C711S169000, C711S170000, C711S171000, C711S172000, C712S001000, C712S210000, C712S220000, C712S225000
Reexamination Certificate
active
06766385
ABSTRACT:
BACKGROUND
This invention relates to data communications in a computer system, and more particularly to a memory controller operable to issue variable length read and write commands.
Modern computer systems typically include a host processor coupled to a host bridge. The host bridge interfaces the processor to the rest of the computer system. The host bridge may include a memory controller that is coupled to a system memory, for example Dynamic Random Access Memory (DRAM). A single memory controller can support a plurality of memory channels, where each memory channel is an electrically independent interface with the memory channel's own data bus connecting the memory channel to the memory controller. The larger the number of memory channels, the larger the aggregate bandwidth (amount of information transferred per second between the DRAM and the memory controller). Increasing the number of memory channels also increases the aggregate storage capacity of the memory subsystem by allowing more memory modules/devices to be connected to a single controller.
Most memory controllers perform read and write commands in fixed size amounts of data. This amount of data is called a “line”. A line contains L bytes of data. For example, when the memory controller performs a read operation, the controller receives a single line of data (L bytes) for each read command issued. Likewise, when the memory controller performs a write operation, the memory controller transmits a line of data (L bytes) for each write command issued. In an n-channel implementation, each of the channels returns a line of data for each read command. The total amount of data returned to the controller is L*n bytes if all channels are populated. For write commands, the controller transmits L*n bytes, with L bytes being written to each usable memory channel.
Referring to 
FIG. 1
, timing diagram 
100
 illustrates the operation of a memory controller supporting two channels 
101
 and 
102
 with a fixed burst length L=4. As shown, only channel 
101
 is populated. Assuming a requesting agent requests R=8 bytes of data 
104
A-H, the controller would be required to issue two read commands 
105
A and 
105
B. The first read command 
105
A would issue at the rising edge of clock 
0
106
, and the second read command 
105
B would issue at the rising edge of clock 
4
107
. In contrast, assuming both channels are populated and the controller uses multiple channels in a lock-step fashion—i.e., each channel receives the same read and write commands and the data is split between the channels—the controller would only be required to issue one read command of length L=4. The single read command would enable the controller to receive the full L*n or 8 bytes. By requiring a larger number of read or write commands in the event that all channels are not populated, conventional memory controllers suffer performance and efficiency losses.
REFERENCES:
patent: 4484303 (1984-11-01), Provanzano et al.
patent: 5179663 (1993-01-01), Iimura
patent: 5608686 (1997-03-01), Takai
patent: 5781918 (1998-07-01), Lieberman et al.
patent: 5809338 (1998-09-01), Klein
patent: 5854942 (1998-12-01), Penokie
patent: 5893927 (1999-04-01), Hovis
patent: 5896551 (1999-04-01), Williams et al.
patent: 5901298 (1999-05-01), Cummins et al.
patent: 6003120 (1999-12-01), Hardin
patent: 6108723 (2000-08-01), Simms et al.
patent: 6148380 (2000-11-01), Dodd et al.
patent: 6154419 (2000-11-01), Shakkarwar
patent: 6185637 (2001-02-01), Strongin et al.
patent: 6298420 (2001-10-01), Chittor et al.
patent: 6304947 (2001-10-01), Killig et al.
patent: 6393500 (2002-05-01), Thekkath
patent: 6412048 (2002-06-01), Chauvel et al.
patent: 6457075 (2002-09-01), Koutsoures
patent: 6470409 (2002-10-01), Ridgeway
patent: 6473814 (2002-10-01), Lyons et al.
patent: 6523085 (2003-02-01), Hodges et al.
patent: 6609163 (2003-08-01), Nguyen et al.
patent: 6615308 (2003-09-01), Fanning
patent: 2002/0007435 (2002-01-01), Banks et al.
patent: 2003/0182513 (2003-09-01), Dodd et al.
Dodd James M.
Halbert John B.
Johnson Brian P.
Wells Jay C.
Gaffin Jeffrey
Nguyen Tanh
LandOfFree
Device and method for maximizing performance on a memory... does not yet have a rating. At this time, there are no reviews or comments for this patent.
If you have personal experience with Device and method for maximizing performance on a memory..., we encourage you to share that experience with our LandOfFree.com community. Your opinion is very important and Device and method for maximizing performance on a memory... will most certainly appreciate the feedback.
Profile ID: LFUS-PAI-O-3197135