A system and method for optimizing memory bus bandwidth, is achieved by utilization of the memory bus, either by utilizing the idle time of the memory bus, or by prioritizing prefetch requests to exploit the bank structure of the external memory. When a bus master of the memory bus makes a request to access a particular line in a memory device, the memory controller generates a request for accessing a line next to the current line that is requested by the bus master. data corresponding to the next line is retrieved from the memory device and stored in the memory-controller when the memory bus is idle. The stored data may be served to a bus master upon request for the data. However, the memory bus is not engaged when the data stored in the memory controller is served. Therefore idle time of the memory bus is utilized.

Patent
   8356143
Priority
Oct 22 2004
Filed
Oct 22 2004
Issued
Jan 15 2013
Expiry
May 16 2025
Extension
206 days
Assg.orig
Entity
Large
27
106
all paid
20. A method for optimization of memory bus bandwidth, comprising:
receiving a first request for accessing a particular line of data in a memory device, the first request being made by a first bus master of a plurality of bus masters;
generating a prefetch request for prefetching the data in a next address line of data following the particular line of data in the memory device;
arbitrating between the prefetch request and a second request made by one of said plurality of bus masters;
prefetching data corresponding to the next address line of data in the memory device into a memory controller;
storing the prefetched data in the memory controller; and
serving the prefetched data to said first bus master if the first bus master requests the prefetched data, the request being received by the memory controller.
1. A bus master prefetch unit for optimizing memory bus bandwidth, the bus master prefetch unit comprising:
means for receiving a request from a bus master of a plurality of bus masters for accessing a particular line of data in a memory device through a memory bus;
means for verifying if the received request is for data stored in the bus master prefetch unit;
means for generating at least one prefetch request for accessing at least one line of data in the memory device, the at least one line of data being next to the line of data for which the received request is received from the bus master;
means for arbitrating between said request from the bus master and said at least one prefetch request;
means for obtaining data from the memory device, the data corresponding to the prefetch request; and
a prefetch buffer for storing the obtained data as stored data, wherein the stored data is operable to be served to the bus master when the bus master requests the stored data.
14. A system for accessing a memory device, the system comprising:
a plurality of bus masters, wherein at least one bus master is enabled for prefetching;
a memory device;
a memory bus; and
a memory controller connected to the memory device through the memory bus, the memory controller comprising:
means for receiving a request from a bus master for accessing a particular line of data in the memory device through the memory bus;
means for verifying if the requesting bus master is enabled for prefetching;
means for verifying if the address of the particular line of data lies in a predefined set of addresses;
means for verifying if the received request is for data stored in the memory controller;
means for generating a prefetch request for accessing a line of data in the memory device, the line of data being next in address to the line of data for which the request from the bus master is received;
means for arbitrating between a plurality of requests from said plurality of bus masters and said prefetch request generated by the memory controller;
means for fetching data from the memory device; and
means for storing the prefetched data, wherein the stored data is operable to be served to a bus master when the bus master requests the stored data.
2. The bus master prefetch unit as recited in claim 1 wherein said at least one prefetch request is a request for one or more lines of data with sequentially increasing addresses.
3. The bus master prefetch unit as recited in claim 1 further comprising:
means for making a prefetch request for a next line of data following a line of data stored in the prefetch buffer when the line of data requested by the bus master is stored in the prefetch buffer.
4. The bus master prefetch unit as recited in claim 1 wherein said bus master prefetch unit is embedded in a memory controller.
5. The bus master prefetch unit as recited in claim 1 further comprising means for coupling the bus master prefetch unit to a memory controller.
6. The bus master prefetch unit as recited in claim 1 further comprising means for determining if the memory bus is idle.
7. The bus master prefetch unit as recited in claim 1 further comprising means for supplying data to the bus master.
8. The bus master prefetch unit as recited in claim 1 further comprising means for determining if a requesting bus master is enabled for prefetching.
9. The bus master prefetch unit as recited in claim 1 further comprising means for determining if an address of the particular line of data lies in a predefined set of addresses.
10. The bus master prefetch unit as recited in claim 1 further comprising means for aborting the at least one prefetch request.
11. The bus master prefetch unit as recited in claim 1 further comprising means for identifying whether a request from a bus master for accessing the memory device is the last request from the bus master.
12. The bus master prefetch unit as recited in claim 1, wherein the prefetch buffer is capable of storing multiple lines of data.
13. The bus master prefetch unit as recited in claim 1 further comprising an idle timer for measuring idle time of the memory bus, wherein the means for generating request generates a request when the idle timer indicates that the idle time of the memory bus is equal to a predefined threshold idle time.
15. The system as recited in claim 14, wherein the memory controller further comprises means for supplying data to the bus master.
16. The system as recited in claim 14, wherein the memory controller further comprises means for aborting the prefetch request.
17. The system as recited in claim 14, wherein the memory controller further comprises means for identifying whether a request from a bus master for accessing the memory device is the last request from the bus master.
18. The system as recited in claim 14, wherein the means for storing is capable of storing multiple lines of data.
19. The system as recited in claim 14, wherein the memory controller further comprises an idle timer for measuring idle time of the memory bus, wherein the means for generating a prefetch request generates a request when the idle timer indicates that the idle time of the memory bus is equal to a predefined threshold idle time.
21. The method as recited in claim 20, wherein the step of generating a request for prefetching comprises:
identifying if the first bus master is enabled for prefetching; and
generating the prefetch request only if the first bus master is enabled for prefetching.
22. The method as recited in claim 20 further comprising:
aborting the prefetch request if a second bus master of said plurality of bus masters, which is enabled for prefetching, requests access to the memory device.
23. The method as recited in claim 20 further comprising:
aborting the prefetch request if the first request is identified to be the last request from the first bus master.
24. The method as recited in claim 20 further comprising:
measuring the idle time of the memory bus; and
prefetching data only if the memory bus is idle for a predefined threshold idle time.
25. The method as recited in claim 20, wherein said serving is performed simultaneously with said prefetching data from the memory device.
26. The method as recited in claim 20, wherein said arbitrating is based on a priority associated with each bus master and the amount of data requested.

1. Field of the Invention

The present invention relates generally to computer systems and more particularly to bandwidth utilization of a memory bus in a computer system wherein a bus master prefetch unit responds to a bus master request for accessing a first line of data by fetching a second adjacent line of data and storing it in a prefetch buffer for later access subsequent to accessing the first line.

2. Description of the Prior Art

In today's information based society, computer systems are widely used, for example in enterprises, homes, universities, manufacturing units, government organizations and research centers. Modern day computers need to perform several tasks simultaneously. These tasks may include execution of large and sophisticated applications that benefit from faster computer systems with higher processing speed.

The overall processing speed of a computer system depends on the speed of its various components. Today's computers employ high-speed processing units. However, each component of a computer system can limit the overall speed of the system. One such component that limits the processing speed of a computer system is the memory bus that connects a memory device, for example an external DRAM, to the other components of the computer system.

The memory bus may have many masters which may be controllers, for accessing the memory device through the memory bus. Several applications can access the memory device through the bus masters. Bus masters include various internal hardware components such as processors, Direct Memory Access (DMA) controllers and so forth. All the masters of the memory bus are connected to the memory bus through a memory controller. The memory controller arbitrates over the bus masters for access to the memory device by prioritizing requests from various bus masters according to predefined rules.

Requests for access to the memory device are queued in the memory controller. The memory controller allows the masters to access the memory device one by one. Each request has to wait for its turn to gain access to the memory device. This limits the overall speed of processing. Further, there are times when there is no request in queue. In such times, the memory bus remains idle.

High bandwidth devices are very common in today's applications for most computer peripherals and consumer electronic devices. High bandwidth devices include masters like the USB and the display driver. These devices have specific bandwidth and data rate requirements for efficient performance and functionality of the device. Lack of bandwidth in accessing the memory device hurts the actual system performance.

Several attempts have been made to utilize this idle time of the memory bus to optimize the bandwidth usage of the memory bus. In order to increase the overall speed of bus master accesses to the memory device, the concept of prefetching of data is employed. Prefetching of data means getting data from slow external memory devices ahead of time. This is done so that a resource requesting data will not have to wait for the data to be fed from the memory device when it is actually needed. This reduces the overall latency of reading data from the external memory.

Several patents exist that deal with optimization of the memory bus bandwidth. One such patent is U.S. Pat. No. 5,881,248, titled “System and Method for Optimizing System Bus Bandwidth in an Embedded Communication System” assigned to Advanced Micro Devices, Inc. This patent relates to a communication system that includes a receive buffer, a memory, a CPU, a direct memory access (DMA) controller and a bus arbitrator. Each of these components is coupled to the memory bus. The buffer operates to generate a low or high priority DMA transfer request. When the buffer generates a low priority DMA request, the DMA controller and/or bus determine if the system bus is otherwise not being utilized. If the system bus if not being utilized, the DMA transfer is allowed. Thus, the system utilizes the idle time of the memory bus.

Another patent that deals with the optimization of memory bus bandwidth is U.S. Pat. No. 6,233,656, titled “Bandwidth Optimization Cache”, assigned to LSI Logic Corporation. The patent relates to optimizing bus bandwidth utilization in an environment where bus accesses range in size from a single word to multi-word burst accesses. The system achieves this by prefetching and caching additional words when responding to a single word access request. Prefetching of data means retrieving and storing data even if there is no request for the data. This data may be served to a requester if it requests the data at a future later time. The invention includes receiving a read request from a client, checking the contents of a cache to determine whether the cache contains the information sought in the read request and returning the information from the cache if a cache hit results. If the data is not in the cache, a bus transaction is initiated by fetching a block of memory containing the information from a memory store, sending the information to the client, and caching the additional remaining information included with the fetched block of memory. The system disclosed in the above mentioned patent includes a cache memory, which stores a chunk of data that includes the requested data. This cache based prefetch mechanism concentrates on speeding up data access for the requester that the Cache services. Cache based mechanisms, however, do not optimize the external memory bus bandwidth utilization.

Another disclosure that deals with the optimization of memory bus bandwidth is US Patent Application Number 20030126355, entitled “Distributed Memory Module Cache Prefetch”. The disclosure relates to a distributed memory module cache including a tag memory and associated logic implemented at the memory controller end of a memory channel. The memory controller is coupled to a memory module. The data cache and associated logic are located in one or more buffer components in each of the memory modules. The disclosed system has the ability to read a current line of data out of a memory module DRAM and to load the next cache line of data into the memory module data cache. This allows the utilization of excess DRAM interconnect bandwidth, while preserving limited memory bus bandwidth.

However, the existing systems do not effectively optimize the memory bus bandwidth for bus master accesses using the concept of prefetching. Further, external memory devices such as SDRAM and DDR SDRAM organize data in a set of two or more banks. Each bank again is organized into a set of rows and columns. Every time a data is read from this memory, the particular row of the bank, which has this data, is “opened” for reading. This bank is then “closed” by the memory when the data in the memory is “refreshed” or when data is read from a different row of the same bank. An overhead in terms of power consumption and time is incurred whenever a bank has to be opened or closed in the memory. The existing systems do not utilize the bank structure of memory devices to speed up bus master accesses to the memory device.

In light of the preceding discussion, there exists a need for an efficient and cost effective memory bus bandwidth optimization system for bus master accesses. There is a requirement for a system and method that can intelligently fetch data that is likely to be used by the system in the future from the memory device. There is also a need for a system that has lower power consumption. Furthermore, there is a need for a system and method that utilizes the memory bus bandwidth in an intelligent and calculated fashion.

An object of the present invention is to provide a system and method for optimizing memory bus bandwidth and enhancing the speed of retrieving data requested by bus masters from a memory device.

Another object of the method and system of the present invention is to intelligently predict future requests for data that is likely to be used by one of the memory bus masters.

Another object of the method and system of the present invention is to feed the data back to the bus masters at a much faster rate compared to retrieving data directly from the memory device.

Yet another object of the present invention is to provide a programmable feature, wherein one or more bus masters may be enabled for prefetching.

A still further object of the present invention is to provide a programmable feature, wherein a definite set of addresses in the memory can be enabled for prefetching.

A further object of the method and system of the present invention is to perform prefetch in a way such that it does not interfere with the actual requests from bus masters.

Another object of the present invention is to utilize the bank structure of an external memory device in the most efficient form so as to minimize latency of accesses for data to external memory. This is done by immediately serving the prefetch request after the actual request from the bus master has been sent to the external memory. The prefetched address in the present invention is the next sequential address in the memory, and therefore the likelihood of this address being in an open row is very high. This reduces the number of times the memory bank has to be opened or closed, and therefore the effective latency at which data is fed to the requester is reduced. Moreover, reduction of the number of transitions the external control signals to the memory have to so through reduces the power consumption of the entire system.

Furthermore, an object of the system of the present invention is to provide a cost effective system for efficient utilization of memory bus bandwidth.

Another object of the present invention is to equip the prefetch unit with a prefetch abort controller, which minimizes any redundant requests for data that would otherwise be performed by the prefetch unit after the last request from the bus master.

Briefly, a preferred embodiment of the present invention is directed to a method and system for the optimization of memory bus bandwidth by the utilization of memory bus idle time. The system comprises a memory device, a plurality of bus masters, a memory bus and a memory controller. The bus masters access the memory device through the memory bus. The bus masters are connected to the memory bus through the memory controller. The memory controller allows the bus masters to access the memory device one by one. The memory controller may have many requesters/masters accessing the external memory apart from just the bus masters.

The memory controller also includes an arbitration unit and a bus master prefetch unit. The arbitration unit receives requests for accessing the memory device from various bus masters, and prioritizes these requests according to a predefined set of rules.

The bus master prefetch unit determines if a requesting bus master is enabled for prefetching, or if the request is directed for data that is stored in a prefetch enabled chunk of data in the memory device. Prefetching of data means retrieving and storing data for future use even if there is no request for the data. Further, when a prefetch enabled bus master makes a request for accessing a particular line in the memory device, the bus master prefetch unit aborts a previous prefetch request and generates a new request for accessing the next in address line in the memory device. This request is queued in the arbitration unit along with other requests from bus masters/requesters. The prefetch request could be serviced either immediately after the actual request, or, alternatively could be serviced when the memory bus is idle, i.e., when there are no other requests to be served through the memory bus. Either of the above options can be chosen by the firmware based on its requirement. For the prefetch request being served, data from the memory device is retrieved and stored in a prefetch buffer in the bus master prefetch unit. When a bus master makes a request for data stored in the prefetch buffer, this data is served to the bus master without engaging the memory bus. In this manner, idle time of the memory bus is utilized for fetching data in advance.

The prefetch mechanism as described above has several advantages over prior art cache mechanisms for bus bandwidth optimization. In the method and system of the present invention, the prefetch mechanism predicts data which is likely to be used in the future. Requests for predicted data are made in sequentially increasing or decreasing order of addresses. The sequential order of the addresses being fetched is a derivative of the natural property of the bus masters to fetch and store a huge chunk of data in contiguous locations in memory. In the prior art cache mechanism, however, the fetched data is ‘wrapped around’ the actually requested address. ‘Wrapped around’ data includes addresses both before and after the address of the actually requested address. This wrapped around data is not necessarily in sequentially increasing or decreasing order.

Furthermore, in the case of the prefetch mechanism of the present invention, the prefetch controller and the prefetch buffer may be embedded in the memory controller. This configuration of the prefetch unit being embedded in the memory controller helps the prefetch controller work in a tightly coupled fashion with the memory controller. This helps the prefetch controller and the memory controller work together to utilize the external memory bus efficiently whenever the bus is idle. Hence, the memory bus bandwidth is better utilized. The Cache based prefetch mechanism of the prior art, however, only tries to optimize the speed of processor accesses.

In an embodiment of the present invention, the bus master prefetch unit includes an idle timer, which measures the time that the memory bus remains idle. A prefetch request is served only if the idle timer indicates that the memory bus has been idle for more than a programmable threshold time.

In another embodiment of the present invention, the prefetch buffer in the bus master prefetch unit has multiple lines of buffer for storing data. In this embodiment, the system is capable of prefetching multiple lines of data from addresses, which are sequentially addressed after accessing the address that is requested by the bus master.

The system of the present invention also includes a prefetch abort controller, that is capable of identifying whether a request is the last request from a requesting bus master. If the request is identified as the last request, a prefetch request that was generated due to a previous request from the bus master is aborted. In this manner, the system provides an efficient method for utilization of memory bus bandwidth.

The preferred embodiments of the present invention will hereinafter be described in conjunction with the appended drawings provided to illustrate and not to limit the invention, wherein like designations denote like elements, and in which:

FIG. 1 is a block diagram showing an operational environment for the present invention;

FIG. 2 is a block diagram of a memory controller in accordance with a preferred embodiment of the present invention;

FIG. 3 is a block diagram representing the bus master prefetch unit;

FIGS. 4A and 4B are a flowchart representing the method for generation of a prefetch request;

FIGS. 5A, 5B, 5C, and 5D are timing diagrams comparing serving of data from a prefetch buffer and serving of data directly from a memory device; and

FIG. 6 is a flowchart representing the method of serving a prefetch request in the case of a bus idle time prefetch.

Terminology used:

Bus: A Bus is a transmission line or path in a computer system. This path is usually in the form of electrical wires, metallic connections or other transmission media.

Memory bus: The bus that connects a memory device to other parts of the computer system is called a memory bus. Signals may be dropped off or picked up at every point that is connected to the path.

Memory bus bandwidth: Memory bus bandwidth refers to the capacity of the memory bus to carry information. Memory bus bandwidth can be measured in terms of the amount of information that can be carried through the memory bus in given period of time.

Idle time of memory bus: Idle time of the memory bus is the time that the memory bus is not in use, i.e., the time when the memory bus is not carrying any information.

Prefetching: The concept of retrieving and storing data, even when there is no external request for the data, is called prefetching. This data may be served to a requester upon request for the data at a later time.

Bus master: Bus master is a hardware or software component that uses the bus for receiving or sending information. In the context of the present disclosure, bus masters use the memory bus for accessing the memory device.

Arbitration: Arbitration refers to prioritizing various requests that are received by a controller. In the context of the present disclosure, arbitration refers to deciding the sequence in which various requests for accessing the memory device from bus masters are served.

Buffer: A buffer is a memory device with limited capacity that stores data.

The present invention provides a system and method for optimizing memory bus bandwidth and enhancing the speed of retrieving data requested by bus masters from a memory device. Optimization of memory bus bandwidth is achieved by utilization of idle time of the memory bus. The idle time is utilized for prefetching data from the external memory that is predicted to be used in the future.

FIG. 1 is a block diagram showing an illustrative operational environment for the present invention. One or more bus masters require information from the memory device 110. Four such bus masters 102, 104, 106, and 108 are shown in FIG. 1. Although four bus masters have been depicted in FIG. 1, it will be apparent to one skilled in the art that there can be any number of masters requesting access to the memory device. Bus masters 102, 104, 106, and 108 are connected to a memory controller 114 through a bus 116. Memory controller 114 routes requests from various AHB bus masters and other requesters to memory device 110, and performs the processes according to the present invention that will be explained in detail in the following text of the specification. For example, requester 118 and 120 are connected to memory controller 114 as shown in the figure. Requesters 118 and 120 may be, for example, a processing unit that needs to access the memory device 110. Bus 116 may be, for example, an Advanced High-performance Bus (AHB)™ and bus masters 102, 104, 106 and 108 may be a display driver, an audio playback driver or other such bus masters. Memory device 110 may be, for example, SRAM, SDRAM, PBSRAM and so forth. External memories like SDRAM & DDR SDRAM are commonly used memory devices in most of the computer peripherals and myriads of consumer electronic devices. This is because of their low cost and very high densities. These memories organize data in a set of two or more banks. Each bank again is organized into a set of rows and columns. Every time a particular data is read from this memory, the particular row of the bank which has the data is ‘opened’ for reading. This bank is closed again later by the memory when the data in the memory is ‘refreshed’ or when data is read from a different row of the same bank. An overhead in terms of time is incurred whenever a bank has to be opened or closed in the memory. It can therefore be easily understood that the fastest way of reading data from memory is to sequentially access all data from the same row. This kind of access provides the most optimal performance for read accesses from external memory.

Data in such memory devices are stored in the from of data words or half words. Each data word/half word is a chunk of data whose size can be 4 bytes, 8 bytes, and so forth. A set of 4, 8 or more data words is referred to as a line of data. A data line is the maximum size of data that can be fetched by the memory-controller in one burst.

Each byte/half word/word has an address associated with it. For example, a bytewide memory (i.e., a memory whose width is 8 bits/1 byte) would have an address for every byte. Similarly a half word-wide memory would have an address for every half word. In the case of a data line, the address of the first word in the data line is considered to be the address of the data line. The address of the first word in the data line is hereinafter referred to as the address of the data line.

The requests from bus masters 102, 104, 106, and 108, and requesters 118 and 120 are called bus master requests. These bus masters could be Direct Memory Access (DMA) controllers. The bus masters usually request data sequentially due to the inherent nature of the devices they service. This concept of sequential requests from bus masters has been explained using a couple of examples in the background section. These requests are directed to a chunk of data including several lines. These lines have sequential addresses. These requests are muted through a memory bus 112.

Bus masters 102, 104, 106, and 108 request memory controller 114 for accessing memory device 110. The bus masters request one particular line in the memory device at a time. These requests are queued in memory controller 114. Memory controller 114 arbitrates over these requests. Only one request is served at a time because with only a single memory bus, the memory controller can service only one request at a time. Memory controller 114 therefore prioritizes the requests from bus masters 102, 104, 106, and 108 and allows bus masters 102, 104, 106, and 108 to access memory device 110 one by one. Memory controller 114 prioritizes the request according to certain predefined rules. These rules may include, among other factors, associating different priorities to different requests depending on the particular requesting bus master, and the amount of data requested.

When a request for accessing the memory device 110 is served, data is transferred though memory bus 112 as bursts of data. Every computer system supports a predefined maximum burst transfer size. This maximum burst transfer size may be of one, two or more lines of data. Bus masters 102, 104, 106, and 108 may make a request for data less than one data line. Memory controller 114 may be implemented in the form of a hardware device or a programmable firmware device.

FIG. 2 is a block diagram of the memory controller 114 in accordance with a preferred embodiment of the present invention. Memory controller 114 includes an arbitration unit 202 and a bus master prefetch unit 203. FIG. 2 shows the prefetch unit 203, integrally included within the memory controller 114. The necessary interconnections between the prefetch unit 203 and the memory controller will be understood by those skilled in the art and are not shown in detail. The prefetch unit 203 can alternatively be a separate unit from the memory controller 114 with the required interconnections, which will be understood by that skilled in the art. Arbitration unit 202 arbitrates over the requests made by the bus masters 102, 104, 106, and 108 for accessing the memory device 110. Bus master prefetch unit 203 includes a prefetch request issue unit 204, a prefetch data receive logic 206, a prefetch buffer 208, and a data send logic 210. Bus master prefetch unit 203 may be a hardware device of a programmable firmware device within memory controller 114. Bus master prefetch unit 203 has various programmable features, which will be discussed in detail in the following text of the present disclosure.

Though FIG. 2 shows the bus master prefetch unit 203 incorporated within memory controller 114, the bus master prefetch unit 203 may exist as a separate hardware device, which may be coupled to memory controller 114 by means of electrical connections.

Prefetch request issue unit 204 is capable of generating requests for accessing the memory device 110. Prefetch data receive unit 206 is capable of receiving data from the memory device 110 and sending it to the prefetch buffer 208. Prefetch buffer 208 may be of a size equal to the maximum burst transfer size that is supported by the system on which it is employed. In one embodiment of the present invention, the prefetch buffer 208 is capable of storing multiple lines of data. Data send logic 210 is capable of sending data stored in prefetch buffer 208 to a requesting bus master.

When bus master 102 requests memory controller 114 for accessing a particular line of data in the memory device 110, the prefetch request issue unit 204 generates a request for accessing the next in address line of data in the memory device 110. This request is queued in the arbitration unit 202.

The prefetch request can be queued in two ways. In the first case, the prefetch request is served immediately after a request from bus master 102 is served. Serving of the prefetch request immediately after the actual request from bus master 102 speeds up the data retrieval from memory for the prefetch request. This is because the actual request preceding the prefetch request keeps the required row of the external memory open. The prefetch request now has to just read the data from the open row and hence does not have to incur the overhead of opening a row. On the other hand, if the address of the prefetch request data is separated from the address of the actual request data, the overhead for closing and opening of rows is incurred. In the second case, when there are no requests from bus masters to be served, arbitration unit 202 allows bus master prefetch unit 203 to access memory device 110. Data receive logic 206 receives data corresponding to the next in address line of data in memory device 110. The received data is stored in prefetch buffer 208. When bus master 102 requests some data, bus master prefetch unit 203 checks if the data is stored in prefetch buffer 208. If the data is found in prefetch buffer 208, data send logic 210 extracts the data from prefetch buffer 208 and sends it to bus master 102.

Consider for example a case where the bus master 102 is a high bandwidth display driver that accesses the memory device 110 through memory bus 112. Bus master 102 needs to access certain data in the memory device 110, and this data may include several lines of data stored in the memory device 110. Suppose bus master 102 sends a request for line L1 in the memory device 110. Since data is requested sequentially by the bus master corresponding to the display driver, it is likely that bus master 102 will also require line L2 at a later moment, which is the next in address line of data to line L1 in memory device 110. On receiving a request for L1, prefetch request issue unit 204 generates a request for accessing line L2. After this request for L1 is served, the prefetch receive logic 206 fetches data from line L2 and stores it in the prefetch buffer 208. When or if the bus master 102 requests line L2, data send logic 210 sends the L2 data that is stored in prefetch buffer 208 to bus master 102, and therefore data is served to the requesting bus master i.e. the bus master 102 without engaging memory bus 112. Note here that upon receiving the request for L2, a new prefetch request will simultaneously be issued for line L3, which is located sequentially after line L2 in the memory. This would be used by the bus master when/if it comes back with a request for L3. Observe here that the latency of servicing data for new requests from a bus master is drastically reduced using this process. Memory bus 112 in the mean while may be used to serve other requests, and thus the overall speed of the system is increased.

In a preferred embodiment of the present invention, bus master prefetch unit 203 provides a programmable feature where one or more bus masters may be enabled for prefetching. Further, Bus master prefetch unit 203 is configured for identifying if a requesting bus master is enabled for prefetching. This is achieved by providing a user programmable feature enabled by programming a register that is understood by the system. The user can selectively enable prefetch for one or more bus masters on bus 116. Bus master prefetch unit 203 continuously reads the user programmed register and uses this register to determine which of the bus masters is/are enabled for prefetching.

There are two ways in which the selective prefetch can be enabled. In the first case, every bus master's request for data from the external memory is accompanied by a ‘master identity’ (MID). This MID is used by the prefetch unit to identify which master is presently requesting data. The prefetch unit compares this information against the register that is programmed by the firmware, which indicates the particular master/masters for which the prefetch is enabled. This information is compared with the MID from the master request by the prefetch unit to determine if the prefetch unit should respond to the particular bus master's request.

The second method involves an ‘address based’ prefetch recognition. In this method, the prefetch unit 203 looks at the address of the data, requested by the bus master. This is compared against the registers that the firmware programs. These registers indicate the bounds of addresses (lower bound and upper bound) within which prefetch needs to be performed. If the present address being requested by the bus master is within the bounds, the prefetch unit will issue a prefetch request for the next line after the current request from bus master.

The following example illustrates a bus master with prefetch enabled based on the first option mentioned above. Consider, for example, that bus master 102 is enabled for prefetching, whereas bus master 104 is not enabled for prefetching. In that case, if bus master 102 makes a request for accessing a particular line in the memory device, prefetch request issue unit 204 generates a request for accessing the next address line in memory device 110. On the other hand, if bus master 104 makes a request for accessing a particular line in the memory device, the request is queued in arbitration unit 202 and no prefetch request is triggered. In such cases, prefetching will take place only if the request for accessing memory device 110 is from a bus master that is enabled for prefetching. It will be apparent to one skilled in the art that the second method of selective prefetch may be executed in a similar manner as the method described herein.

The above feature wherein a particular bus master is enabled for prefetch and another is not enabled is particularly useful in cases where one bus master has a very high bandwidth requirement compared to the other bus masters. In such cases it is preferable that a bus master that has a higher bandwidth requirement is served data at a much faster rate than the other bus masters. For example, if there is an AHB bus master like the IDE bus master, which requires data at a high transfer rate, and an audio playback driver which requires a lesser transfer rate bus, the user may enable the IDE bus master over the low bandwidth audio playback driver bus master.

The above-mentioned feature of selective prefetch enable for a bus master is particularly useful in cases where prefetch requests are aborted frequently (also referred to as prefetch request thrashing). For example, consider the case when bus master 102 sends a request for accessing a particular line of data L1 in memory device 110. Prefetch request issue unit 204 generates a prefetch request for line of data L2. Line L2 being next in address to line L1. Before the prefetch request is served, bus master 104 sends a request for accessing another line, for example, line L5 in the memory device. Due to this request, the previous prefetch request for line L2 gets prematurely aborted and prefetch request issue unit 204 generates a new prefetch request for line L6, the line next in address to line L5 in the memory device. This may cause frequent change of prefetch requests, and hence, relevant data is not fetched. Now consider a case when bus master 102 is enabled for prefetching and bus master 104 is disabled for prefetching. In this case, the request generated by prefetch request issue unit 204 for line L2 is not aborted when a request from bus master 104 is received. Therefore, the requests generated by prefetch request issue unit 204 are not aborted frequently and consequently relevant data is prefetched in prefetch buffer 208.

The prefetch-enabled bus masters are also useful when data in prefetch buffer 208 gets overwritten very frequently (also referred to as prefetch buffer thrashing). For example, consider a case when bus master 102 sends a request for accessing a particular line, L1, in the memory device. Prefetch request issue unit 204 generates a request for accessing line L2 in the memory device. This request is served and data corresponding to line L2 is stored in prefetch buffer 203. Subsequently, if bus master 104 sends a request for accessing line L5 in memory device 110, prefetch request issue unit 204 generates a new request for line L6. When this request gets served, previous data in prefetch buffer 203 corresponding to data in line L2 is replaced with data corresponding to line L6. This adds an overhead to memory bus 112 and results in a lot of wasted transfers from the memory device 110. Now consider the case when bus master 102 is enabled for prefetching and bus master 104 is disabled for prefetching. In this case, the data stored in prefetch buffer 203 corresponding to line L2 is riot overwritten. Therefore, the data stored in prefetch buffer 203 is not overwritten frequently and consequently relevant data is served to bus master 102.

In another embodiment, the bus master prefetch unit 203 is also provided with a programmable switch that enables a selective prefetch abort mechanism. When this feature is enabled, a prefetch request is aborted and is replaced only when a bus master, which is enabled for prefetching, sends a request when the current prefetch is in progress. If this feature is not enabled, a prefetch request may be aborted if a bus master, which is not enabled for prefetching, sends a request for accessing memory device 110. This feature, again, prevents the problems of frequent change of prefetch requests, redundant prefetching and underutilization of the memory device bus.

FIG. 3 is a block diagram representing the bus master prefetch unit 203. In another embodiment, bus master prefetch unit 203 is provided with an idle timer 302. Idle timer 302 is capable of measuring idle time of memory bus 112. Idle time of the memory bus is the time for which memory bus 112 is out of use i.e. the time when the memory bus is not used for serving any requests. When a prefetch request, along with other requests from bus masters, is queued in arbitration unit 202, the bus master requests are given preference over prefetch requests. When the last bus master request is served, idle timer 302 starts to measure the memory bus idle time. Bus master prefetch unit 203 waits until idle timer 302 indicates that the idle time has exceeded a threshold idle time. This threshold idle time is programmable by the user. The user can specify the number of cycles the bus master prefetch unit 203 has to wait before it retrieves data from the memory device 110 through the memory bus 112. Based on specific application requirements that are running on the system, the user can program an optimal number of cycles that the bus master prefetch unit 203 has to wait before issuing a prefetch request. The prefetch request is served only after the idle time of memory bus 112 has exceeded the threshold idle time. If a bus master sends a request before the threshold idle time has lapsed, the bus master request is served prior to the prefetch request and idle timer 302 is reset. Bus master requests may be delayed if the idle timer feature is not enabled. For example, consider a prefetch request being served as soon as memory bus 112 is idle. Suppose bus master 102 makes a request for accessing line L1 of data in memory device 110. Prefetch request issue unit 204 generates a request for accessing line L2 of data. As soon as memory bus 112 is found idle, the prefetch request for line L2 begins to get served. In this case, if a request from bus master 104 comes up just after the prefetch request begins to get served, then bus master 104 has to wait until the prefetch request is fully served. This leads to delay in serving of actual requests from bus masters. This disadvantage is overcome using the idle timer feature.

In another embodiment of the present invention, prefetch buffer 208 is capable of storing multiple lines of data. When a request from bus master 102 is received, prefetch request issue unit 204 also generates a request for an address, including two lines after the current address that is requested by bus master 102. If the bus master requested line of data is stored in the prefetch buffer 208, it may be served to bus master 102 simultaneously with prefetching of data in the next in address line of memory device 110.

For example, consider the case when bus master 102 requests line L1 in memory device 110. In response, the prefetch request issue unit 204 generates a request for both L2 and L3 in that order, line L2 being next in address to line L1 and line L3 being next in address to line L2. Suppose prefetch requests for line L2 and L3 have been served and data corresponding to both these lines is stored in the prefetch buffer 208. Now, when the bus master requests data corresponding to line L2, data send unit 210 can send data corresponding to line L2 to bus master 102 simultaneously with the data receive unit 206 fetching data corresponding to line L4 from memory device 110. Line L4 being next in address to line L3. The data corresponding to line L4 is stored in the second line of the buffer in the prefetch buffer 208. Prefetch buffer 208 now has two lines of data corresponding to addresses L3 and L4.

Although the above discussion takes into consideration only one or two lines of buffer in prefetch buffer 208, it will be apparent to one skilled in the art that prefetch request issue unit 204 may generate more than two requests for sequential lines of data and prefetch buffer 208 is capable of storing more than two lines of data.

Bus master prefetch unit 203 is also provided with a prefetch abort controller 304. Prefetch abort controller 304 determines if a request received from bus master 102 is the last request for the programmed transfer. Prefetch abort controller 304 compares the address to which the prefetch needs to be issued against the address range to which the DMA bus master, i.e. bus master 102 is programmed to receive data. When a user programs the DMA controller to transfer a chunk of data, the start and end addresses are noted by the DMA controller. The register corresponding to the end addresses of the requested data is seen by the prefetch abort controller 304. Now, whenever a new prefetch request is to be serviced by bus master prefetch unit 203, it compares the prefetch address with the end address of the DMA request. If the prefetch address is greater than the end address that bus master 102 is supposed to transfer, prefetch abort controller 304 prevents bus master prefetch unit from generating any new prefetch request to memory bus 112.

The manner of execution of the system described above has been described in conjunction with FIGS. 4A and 4B.

FIGS. 4A and 4B are a flowchart representing the method for generation of a prefetch request. The steps performed during the operation of the preferred embodiment discussed above are illustrated in the flowchart.

At step 402, bus master 102 makes a request to memory controller 114 for accessing a particular address of line in memory device 110. The request is received by bus master prefetch unit 203. Thereafter at step 404, bus master prefetch unit 203 checks if the data requested by bus master 102 is stored in prefetch buffer 208 or if the data is being prefetched. If the data requested by bus master 102 is stored in prefetch buffer 208 or if the data is being prefetched, then step 406 is executed, otherwise step 408 is executed. At step 406, the data stored in prefetch buffer 208 is served to bus master 102. At step 408, the request by bus master 102 is queued in arbitration unit 202 and ongoing prefetch request is aborted. This request may be served according to the predefined rules of arbitration in arbitration unit 202. Subsequent to steps 406 or 408, whichever is executed, step 409 is executed. At step 409, the bus master prefetch unit 203 checks if it is programmed for selective bus master or selective address limit prefetch. If it is programmed for selective prefetch, step 410 is executed. At step 410, bus master prefetch unit 203 checks if it is programmed to prefetch for selective bus masters or for selective address limit for the requested data. If the bus master prefetch device is programmed for selective bus master prefetching then step 411 is executed, otherwise step 412 is executed. At step 411, bus master prefetch unit 203 checks if the requesting bus master, i.e. bus master 102, is enabled for prefetching or not. If the bus master is enabled for prefetching, then step 413 is executed. Similarly, at step 412, bus master prefetch unit 203 checks if the address of the requested data falls within the limits of addresses in memory device 110, which have been enabled for prefetching. If the requested data falls within the address limits, then step 413 is executed. At step 413, the prefetch abort controller identifies if the request received is the last request from bus master 102. If the request is the last request from bus master 102 then step 414 is executed. At step 414, prefetch request generated due to previous request from bus master 102 is aborted. If at step 413, the request is not the last request from the bus master, then step 416 is executed. At step 416, the prefetch request issue unit generates the address of the line of data next to the requested line of data in the memory device. Subsequently, at step 420, the prefetch request issue unit generates a request for accessing the addresses earlier generated in step 416.

FIG. 5 is a timing diagram comparing serving of data from prefetch buffer 208 and serving of data directly from memory device 110. FIG. 5A represents clock cycles that are generated in the system. FIG. 5B represents the timing of generation of a request from bus master 102 to access the memory device. The request is assumed to be for a line of data. FIG. 5C represents timing of serving of the line of data stored in prefetch buffer 208 to the bus master. FIG. 5D represents timing of engagement of memory bus 112 when the requested data is being served through memory bus 112.

An illustrative example has been discussed in order to compare serving of prefetched data from prefetch buffer 208 and serving of data directly from memory device 110. Bus master 102 generates a request for accessing a particular line of data in memory device 110. This request is sent to memory controller 114 between time instant 502 and time instant 504. The high in FIG. 5B between time instant 502 and time instant 504 represents the delivery of a request from bus master 102. If the requested data is stored in the prefetch buffer, then without the delay of a single clock cycle, data send logic 210 sends the data to the bus master. The high between time instant 504 and 506 in FIG. 5C represents the serving of data to the bus master. This data is served by data send logic 210. The data is being served to the bus master without any latency in four consecutive clock cycles. If the data requested by bus master 102 is not stored in the prefetch buffer, then the request from the bus master is queued in arbitration unit 202 at time instant 504. This request waits for arbitration before it gets served. This request has to wait for a period between time instant 504 and 508. At time instant 508, this request begins to get served. The memory device may be, for example, a 16 bit external SDRAM memory. FIG. 5D represents engagement of memory bus 112. The highs represent the memory bus being engaged and lows represent the memory bus being unused. The transfer of data from the memory device to the bus master continues until time instant 510. Here, the memory device is assumed to be half-word wide. Hence it takes two cycles for every word to be serviced to the requester from the memory device.

FIGS. 6A and 6B are a flowchart representing the method of serving a prefetch request in the vase when the bus idle time prefetch feature is used/operational. The steps involved in serving prefetched data are described in the sequence in which they are performed.

At step 602, a prefetch request is generated by prefetch request issue unit 204 and the request is received by arbitration unit 202. Thereafter, at step 604, the prefetch request is queued for arbitration in arbitration unit 202 along with the requests from other requesters. Thereafter, at step 606, bus master prefetch unit 203 checks if it is programmed to prefetch only after the idle timer has timed out or to prefetch immediately after the requested data has been served to the requesting bus master in response to the request from bus master 102. If bus master prefetch unit 203 is programmed to prefetch immediately after serving the requested data according to the bus master request, step 608 is executed. If it is programmed for idle time, step 610 is executed. At step 608, the prefetch request is served immediately after the bus master request. At step 610, the arbitration unit checks if there are any requests from bus masters 102, 104, 106, and 108. If there are requests from the bus masters, then at step 612 the arbitration unit allows one of the requesting bus masters to access the memory device 110. Step 610 is repeated subsequent to step 612. At step 610, if there are no requests from bus masters queued in the arbitration unit, step 614 is executed. At step 614, idle timer 302 is initiated. Subsequently, at step 616, the idle timer identities if the threshold idle time has lapsed. If the threshold idle time has lapsed, then at step 618, the prefetch request is served. Referring back to step 616, if the threshold idle time has not lapsed, step 620 is executed. At step 620 arbitration unit 202 checks if any new request has been received from a bus master during the idle time of the bus. If there is a new request, then step 612 is executed. If there is no new request, then step 616 is executed.

The disclosed system and method have several advantages, some of which are cited hereinafter.

An advantage of the disclosed system is that it performs effective prefetching of data. The system prefetches the next in address line of data when a particular line of data in the memory device is requested. The DMA bus masters are always programmed to transfer large chunks of sequential data in bursts. Therefore, when a bus master requests a particular line of data in the memory device, it is almost always true that the bus master would subsequently require accessing the next in address line of data.

The prefetch mechanism has the following advantages over prior art cache mechanisms for memory bus bandwidth optimization:

1. The prefetch mechanism of the present invention predicts data which is likely to be used in the future. Requests for the predicted data are made in sequentially increasing order of addresses. The prior art cache mechanism, however, fetches data ‘wrapped around’ the actually requested address. ‘Wrapped around’ data includes addresses both before and after the address of the actually requested address. This wrapped around data may or may not be in sequentially increasing order.

2. The prefetch mechanism of the present invention can be configured to generate a low priority request for accessing the predicted data. The prior art cache mechanism, however, does not generate any such low priority request. This is because most of the cache mechanisms are “requester performance centric” and are not designed for “effective” utilization of the external memory bus.

3. In the case of the prefetch mechanism of the present invention, a prefetch “hit” condition (which is the condition when the data required by the requester is present in the prefetch unit) would still generate a new prefetch request to the external memory bus. This request is generated to fetch new data that the bus master is expected to request for in its next request. In contrast, in the case of the prior art cache mechanism, if the data for the requested address results in a cache “hit” (which implies that the data is present in the cache), the system does not request any further data that the requester may require in the future.

4. In the case of the prefetch mechanism of the present invention, the prefetch controller and the prefetch buffer may be in the memory controller. This configuration of the prefetch unit being embedded in the memory controller helps the prefetch controller work in a tightly coupled fashion with the memory controller. This helps the prefetch controller and the memory controller work together to utilize the external memory bus efficiently whenever the bus is determined to be idle. Hence, the memory bus bandwidth is better utilized. On the other hand, a prior art system employing a cache mechanism does not have the cache incorporated within the memory controller. Moreover, the cache does not generate a low priority request to the memory controller and therefore may use up memory bus bandwidth to fetch un-needed data, eventually not required by any requester.

Furthermore, the prefetch mechanism of the present invention may be used in conjunction with a cache mechanism. This would further improve the performance of the system by reducing memory access latencies. This is because, although the Cache may not request any additional data, the prefetch unit can fetch the next line of data and store it in the prefetch buffer. Whenever the Cache comes back with a new request, the prefetch buffer can return this data from its buffer, which speeds up the data fetch time for the Cache. The prefetching of a next line of data also is in line with the concept of spatial locality that the Cache uses to fetch additional data other than the one being requested by the Cache's master/requester. The cache mechanism is essentially used to speed up requests for a requester. The prefetch mechanism of the present invention is used to optimize bandwidth utilization of the memory bus. Therefore, if the prefetch mechanism of the present invention is used in conjunction with the cache mechanism, both speeding up of requests and optimization of memory bus bandwidth is achieved.

The present invention employs an optimal size buffer. The buffer size is small enough not to burden an integrated circuit chip on which the invention is preferably implemented, from an area perspective. Therefore, the cost of implementing such a system is not very high. Simultaneously, the buffer size is big enough to make sure that the system performs effectively. The buffer size is usually chosen to be equal to the maximum request size that can be issued by any bus master. This is to ensure that whenever a bus master generates a new request, all data required to serve this request is present in the prefetch buffer. This data can be served immediately to the bus master without any additional latency.

Another advantage of the present invention is that it can be programmed to serve a prefetch request immediately after a request for memory access has been made that causes the prefetch request. Since the two requests are essentially for data stores in addresses next to each other, the data row in the memory device does not have to open and dose to access the prefetch request. Therefore the overall speed of memory access is increased.

An added advantage of the present invention is that the specific bus master for which prefetch can be enabled can be changed dynamically by the user. This allows the user to enhance an application depending on the specific requirements of the application at that particular instant. For example, if at a time instant it is crucial for the application to read data from the memory device and serve it to the display driver bus master at a high rate, then the user can program the bus master prefetch unit to enable prefetch for the display driver bus master or also to disable the prefetch for other bus masters. If at a later instant it is required by the application to read data from the memory and store it in the IDE disk at a high bandwidth, then the display driver bus master prefetch can be disabled and prefetch can be enabled for the IDE bus master. This flexibility allows the user to enhance the overall system performance.

Another added advantage of the system of the present invention is that it provides an idle timer for prefetch. This idle timer lets the user inform the system about the threshold time that the system needs to consider before the memory controller can consider the memory device bus to be idle.

The system, as described in the present invention or any of its components, may be embodied in the form of a computer system. Typical examples of a computer system includes a general-purpose computer, a programmed microprocessor, a micro-controller, a consumer electronics device, a mobile electronics equipment or device, a peripheral integrated circuit element, and other devices or arrangements of devices that are capable of implementing the steps that constitute the method of the present invention.

The computer system comprises a computer, an input device, a display unit and the Internet. Computer comprises a microprocessor. Microprocessor is connected to a communication bus. Computer also includes a memory. Memory may include Random Access Memory (RAM) and Read Only Memory (ROM). Computer system further comprises storage device. It can be a hard disk drive or a removable storage drive such as a floppy disk drive, optical disk drive and the like. Storage device can also be other similar means for loading computer programs or other instructions into the computer system.

The computer system executes a set of instructions that are stored in one or more storage elements, in order to process input data. The storage elements may also hold data or other information as desired. The storage element may be in the form of an information source or a physical memory element present in the processing machine.

The set of instructions may include various commands that instruct the processing machine to perform specific tasks such as the steps that constitute the method of the present invention. The set of instructions may be in the form of a software program. The software may be in various forms such as system software or application software. Further, the software might be in the form of a collection of separate programs, a program module with a larger program or a portion of a program module. The software might also include modular programming in the form of object-oriented programming. The processing of input data by the processing machine may be in response to user commands, or in response to results of previous processing or in response to a request made by another processing machine.

While the preferred embodiments of the invention have been illustrated and described, it will be clear that the invention is not limited to these'embodiments only. Numerous modifications, changes, variations, substitutions and equivalents will be apparent to those skilled in the art without departing from the spirit and scope of the invention as described in the claims.

Ghosh, Subir K., Bulusu, Ravi P.

Patent Priority Assignee Title
10042749, Nov 10 2015 International Business Machines Corporation Prefetch insensitive transactional memory
10061703, Nov 10 2015 International Business Machines Corporation Prefetch insensitive transactional memory
10146692, Nov 10 2015 International Business Machines Corporation Deferred response to a prefetch request
10152419, Nov 10 2015 International Business Machines Corporation Deferred response to a prefetch request
10162743, Nov 10 2015 International Business Machines Corporation Prefetch insensitive transactional memory
10162744, Nov 10 2015 International Business Machines Corporation Prefetch insensitive transactional memory
10372611, Nov 10 2015 International Business Machines Corporation Deferred response to a prefetch request
10474576, Nov 10 2015 International Business Machines Corporation Prefetch protocol for transactional memory
10474577, Nov 10 2015 International Business Machines Corporation Prefetch protocol for transactional memory
10534713, Nov 10 2015 International Business Machines Corporation Deferred response to a prefetch request
10558560, Nov 10 2015 International Business Machines Corporation Prefetch insensitive transactional memory
10740270, Jun 26 2015 Hewlett Packard Enterprise Development LP Self-tune controller
10915439, Nov 10 2015 International Business Machines Corporation Prefetch insensitive transactional memory
10929297, Nov 10 2015 International Business Machines Corporation Prefetch protocol for transactional memory
11899587, Dec 13 2021 RELATIVITY ODA LLC Document locking and cache memory management in cloud computing
8595394, Jun 26 2003 Nvidia Corporation Method and system for dynamic buffering of disk I/O command chains
8683132, Sep 29 2003 Nvidia Corporation Memory controller for sequentially prefetching data for a processor of a computer system
8694688, Jun 26 2003 Nvidia Corporation Disk controller for implementing efficient disk I/O for a computer system
8700808, Dec 01 2003 Nvidia Corporation Hardware support system for accelerated disk I/O
9195493, Mar 27 2014 International Business Machines Corporation Dispatching multiple threads in a computer
9213569, Mar 27 2014 International Business Machines Corporation Exiting multiple threads in a computer
9223574, Mar 27 2014 International Business Machines Corporation Start virtual execution instruction for dispatching multiple threads in a computer
9563562, Nov 27 2012 Nvidia Corporation Page crossing prefetches
9639471, Nov 27 2012 Nvidia Corporation Prefetching according to attributes of access requests
9652413, Jul 20 2009 SHENZHEN XINGUODU TECHNOLOGY CO , LTD Signal processing system and integrated circuit comprising a prefetch module and method therefor
9697128, Jun 08 2015 International Business Machines Corporation Prefetch threshold for cache restoration
9772867, Mar 27 2014 International Business Machines Corporation Control area for managing multiple threads in a computer
Patent Priority Assignee Title
5455913, May 14 1990 TAIWAN SEMICONDUCTOR MANUFACTURING CO , LTD System and method for transferring data between independent busses
5546548, Mar 31 1993 Intel Corporation Arbiter and arbitration process for a dynamic and flexible prioritization
5649230, Mar 31 1992 SAMSUNG ELECTRONICS CO , LTD System for transferring data using value in hardware FIFO'S unused data start pointer to update virtual FIFO'S start address pointer for fast context switching
5717954, Oct 13 1995 Hewlett Packard Enterprise Development LP Locked exchange FIFO
5761468, May 15 1996 Oracle America, Inc Hardware mechanism for optimizing instruction and data prefetching by forming augmented prefetch instructions
5768548, Apr 15 1992 Intel Corporation Bus bridge for responding to received first write command by storing data and for responding to received second write command by transferring the stored data
5790817, Sep 25 1996 MICROSEMI SEMICONDUCTOR U S INC Configurable digital wireless and wired communications system architecture for implementing baseband functionality
5822568, May 20 1996 Advanced Micro Devices, INC System for improving the real-time functionality of a personal computer which employs an interrupt servicing DMA controller
5864876, Jan 06 1997 Creative Technology, Ltd DMA device with local page table
5881248, Mar 06 1997 Advanced Micro Devices, Inc. System and method for optimizing system bus bandwidth in an embedded communication system
5923859, Apr 13 1995 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P Dual arbiters for arbitrating access to a first and second bus in a computer system having bus masters on each bus
5940866, Dec 13 1995 LENOVO SINGAPORE PTE LTD Information handling system having a local address queue for local storage of command blocks transferred from a host processing side
5968143, Dec 13 1995 International Business Machines Corporation Information handling system for transfer of command blocks to a local processing side without local processor intervention
6016528, Oct 29 1997 ST Wireless SA Priority arbitration system providing low latency and guaranteed access for devices
6018803, Dec 17 1996 Intel Corporation Method and apparatus for detecting bus utilization in a computer system based on a number of bus events per sample period
6029223, Aug 02 1996 Round Rock Research, LLC Advanced programmable interrupt controller
6029228, Dec 31 1996 Texas Instruments Incorporated Data prefetching of a load target buffer for post-branch instructions based on past prediction accuracy's of branch predictions
6085276, Oct 24 1997 Hewlett Packard Enterprise Development LP Multi-processor computer system having a data switch with simultaneous insertion buffers for eliminating arbitration interdependencies
6085278, Jun 02 1998 QUARTERHILL INC ; WI-LAN INC Communications interface adapter for a computer system including posting of system interrupt status
6098114, Nov 14 1997 Summit Data Systems LLC Disk array system for processing and tracking the completion of I/O requests
6101568, Aug 25 1998 STMicroelectronics, Inc. Bus interface unit having dual purpose transaction buffer
6157980, Mar 23 1998 International Business Machines Corporation Cache directory addressing scheme for variable cache sizes
6175634, Aug 28 1995 Intel Corporation Adaptive noise reduction technique for multi-point communication system
6182112, Jun 12 1998 Unisys Corporation; CHARLES A JOHNSON Method of and apparatus for bandwidth control of transfers via a bi-directional interface
6185634, Sep 27 1996 EMC Corporation Address triggered DMA controller with an indicative signal including circuitry for calculating a new trigger address value based on the sum of the current trigger address and the descriptor register data with a trigger address register
6205524, Sep 16 1998 Xylon LLC Multimedia arbiter and method using fixed round-robin slots for real-time agents and a timed priority slot for non-real-time agents
6226695, Sep 29 1995 International Business Machines Corporation; IBM Corporation Information handling system including non-disruptive command and data movement between storage and one or more auxiliary processors
6233656, Dec 22 1997 AVAGO TECHNOLOGIES GENERAL IP SINGAPORE PTE LTD Bandwidth optimization cache
6266742, Oct 27 1997 International Business Machines Corporation; IBM Corporation Algorithm for cache replacement
6298407, Mar 04 1998 Intel Corporation Trigger points for performance optimization in bus-to-bus bridges
6314472, Dec 01 1998 Intel Corporation Abort of DRAM read ahead when PCI read multiple has ended
6345341, Jun 24 1999 International Business Machines Corporation Method of cache management for dynamically disabling O state memory-consistent data
6397296, Feb 19 1999 Hitachi America, Ltd Two-level instruction cache for embedded processors
6418496, Dec 10 1997 Intel Corporation System and apparatus including lowest priority logic to select a processor to receive an interrupt message
6442634, Aug 31 1998 LinkedIn Corporation System and method for interrupt command queuing and ordering
6480939, Dec 29 2000 Intel Corporation Method and apparatus for filtering prefetches to provide high prefetch accuracy using less hardware
6526518, May 22 1997 Creative Technology, Ltd Programmable bus
6560657, Dec 23 1999 Intel Corporation System and method for controlling peripheral devices
6571318, Mar 02 2001 Advanced Micro Devices, Inc. Stride based prefetcher with confidence counter and dynamic prefetch-ahead mechanism
6574712, Nov 08 1999 International Business Machines Corporation Software prefetch system and method for predetermining amount of streamed data
6578102, Apr 18 2000 International Business Machines Corporation Tracking and control of prefetch data in a PCI bus system
6631434, Nov 15 1999 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P Dynamic early indication system for a computer
6681281, Nov 17 2000 Advanced Micro Devices, Inc. System and method for implementing a multi-level interrupt scheme in a computer system
6681285, Jul 22 1999 Rovi Guides, Inc Memory controller and interface
6696854, Sep 17 2001 AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED Methods and circuitry for implementing first-in first-out structure
6696954, Oct 16 2000 Avante International Technology, Inc Antenna array for smart RFID tags
6745258, Aug 22 2000 Hewlett Packard Enterprise Development LP Raid system having multiple reply queues for use with multiprocessor host
6751038, Oct 29 1999 Kabushiki Kaisha Toshiba Data write control system and method therefor
6754755, Aug 10 2000 Hewlett Packard Enterprise Development LP Service request system using an activity indicator to reduce processing overhead
6782457, Dec 28 1999 Intel Corporation Prioritized bus request scheduling mechanism for processing devices
6801963, Jul 24 2002 Intel Corporation Method, system, and program for configuring components on a bus for input/output operations
6842803, Jul 09 2001 AMD TECHNOLOGIES HOLDINGS, INC ; GLOBALFOUNDRIES Inc Computer system with privileged-mode modem driver
6877048, Mar 12 2002 GLOBALFOUNDRIES Inc Dynamic memory allocation between inbound and outbound buffers in a protocol handler
6898649, Dec 29 2000 Zarlink Semiconductor Limited Arbiter for queue management system for allocating bus mastership as a percentage of total bus time
6901467, Feb 23 2001 VALTRUS INNOVATIONS LIMITED Enhancing a PCI-X split completion transaction by aligning cachelines with an allowable disconnect boundary's ending address
6904473, May 24 2002 Xyratex Technology Limited Direct memory access controller and method of filtering data during data transfer from a source memory to a destination memory
6907480, Jul 11 2001 Seiko Epson Corporation Data processing apparatus and data input/output apparatus and data input/output method
6910106, Oct 04 2002 Microsoft Technology Licensing, LLC Methods and mechanisms for proactive memory management
6915363, Dec 13 2001 Seagate Technology LLC System for selectively controlling spin-up control for data storage devices in an array using predetermined out of band (OOB) signals
6950892, Apr 10 2003 International Business Machines Corporation Method and system for managing distributed arbitration for multicycle data transfer requests
6957290, Oct 06 2000 AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED Fast arbitration scheme for a bus
6996684, Oct 03 2002 VIA Technologies Inc.; Via Technologies Inc Multiple-grant controller with parallel arbitration mechanism and related method
6999426, Jan 19 2000 NEC Corporation Data bus control method for artificial satellite load and system thereof
7032046, Sep 30 2002 BEIJING ESWIN COMPUTING TECHNOLOGY CO , LTD Resource management device for managing access from bus masters to shared resources
7096291, Apr 04 2002 VIA Technologies, Inc. Method and device for arbitrating bus grant
7124232, May 08 2003 Fujitsu Limited Bus connection circuit and bus connection system having plural request queues, a bus interface portion outputting request signals, an arbiter performing arbitration of plural requests and a bus interface portion outputting a request signal indicating allocation of pre-fetch buffers corresponding to arbitrated requests
7139878, Jun 20 2003 SHENZHEN XINGUODU TECHNOLOGY CO , LTD Method and apparatus for dynamic prefetch buffer configuration and replacement
7143219, Dec 31 2002 Intel Corporation Multilevel fair priority round robin arbiter
7177985, May 30 2003 ARM Finance Overseas Limited Microprocessor with improved data stream prefetching
7263566, Dec 30 2004 Qualcomm Incorporated Method and apparatus of reducing transfer latency in an SOC interconnect
7376846, Oct 14 2001 HEWLETT-PACKARD DEVELOPMENT COMPANY, L P Charging and communication cable system for a mobile computer apparatus
7389466, Aug 12 1999 Texas Instruments Incorporated ECC in computer system with associated mass storage device, and method for operating same
7505461, May 06 2003 138 EAST LCD ADVANCEMENTS LIMITED Data transfer control device, electronic instrument, and data transfer control method
7525986, Oct 28 2004 Intel Corporation Starvation prevention scheme for a fixed priority PCI-Express arbiter with grant counters using arbitration pools
7600058, Jun 26 2003 Nvidia Corporation Bypass method for efficient DMA disk I/O
7706756, Feb 28 2006 MURATA MANUFACTURING CO , LTD RF power module
7895385, Dec 09 2008 Nvidia Corporation Establishing communication over serial buses in a slave device
20010001873,
20010014928,
20020023204,
20020056027,
20020144054,
20030191880,
20030229743,
20030229762,
20040024947,
20040024948,
20040049641,
20040064649,
20040083341,
20040088458,
20040117606,
20040123043,
20040201647,
20050081014,
20050138254,
20050216607,
20060041721,
20060041722,
20060041723,
20060095677,
20070198758,
20090055566,
20090089477,
20090228631,
20100057973,
////
Executed onAssignorAssigneeConveyanceFrameReelDoc
Oct 22 2004NVIDIA Corporatin(assignment on the face of the patent)
Oct 27 2004BULUSU, RAVI P PORTALPLAYER, INC ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0162220039 pdf
Oct 28 2004GHOSH, SUBIR K PORTALPLAYER, INC ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0162220039 pdf
Nov 06 2006PORTALPLAYER, INC Nvidia CorporationMERGER SEE DOCUMENT FOR DETAILS 0196680704 pdf
Date Maintenance Fee Events
Apr 19 2016STOL: Pat Hldr no Longer Claims Small Ent Stat
Jun 24 2016M1551: Payment of Maintenance Fee, 4th Year, Large Entity.
Jun 24 2020M1552: Payment of Maintenance Fee, 8th Year, Large Entity.
Jun 20 2024M1553: Payment of Maintenance Fee, 12th Year, Large Entity.


Date Maintenance Schedule
Jan 15 20164 years fee payment window open
Jul 15 20166 months grace period start (w surcharge)
Jan 15 2017patent expiry (for year 4)
Jan 15 20192 years to revive unintentionally abandoned end. (for year 4)
Jan 15 20208 years fee payment window open
Jul 15 20206 months grace period start (w surcharge)
Jan 15 2021patent expiry (for year 8)
Jan 15 20232 years to revive unintentionally abandoned end. (for year 8)
Jan 15 202412 years fee payment window open
Jul 15 20246 months grace period start (w surcharge)
Jan 15 2025patent expiry (for year 12)
Jan 15 20272 years to revive unintentionally abandoned end. (for year 12)