This invention relates generally to memory devices, and, more particularly, to a memory device and method that facilitates access by multiple memory access devices, as well as memory systems and computer systems using the memory devices.
As computer and computer system architecture continues to evolve, the number of processing cores and threads within cores is increasing geometrically. This geometric increase is expected to continue, even for simple, relatively inexpensive computer system. For server systems, system sizes measured in the number of processors are increasing at an even faster rate.
Although this rapid increase in the number of corers and threads enhances the performance of computer systems, it also has the effect of making it difficult to apply the increasing parallelism to single applications. This limitation exists even for high-end processing tasks that naturally lend themselves to parallel processing, such as, for example, weather prediction. One of the major reasons for this limitation is that the number of communication paths between processors, cores, and threads increases disproportionately to the number of times the task is divided into smaller and smaller pieces. Conceptually, this problem can be analogized to the size of a processing being represented by the volume of a 3D cube. Each time this volume is divided into smaller cubes, the total surface area of the cubes, which represents data that must be communicated between the processors working on sub-cubes, increases. Every time that the number of processors goes up by a factor of eight the total amount of information to be communicated between the greater number of processors doubles.
One reason for these problems caused by increasing parallelism is that most systems communicate by sending messages between processors, rather than sharing memory. This approach results in high latencies and high software overheads, although it may simplify some complex system architecture, operating system, and compiler issues. Unfortunately, as the level of parallelism increases, the processors in the system reach the point where all they are doing is managing message traffic rather than actually doing useful work.
There is therefore a need for a system and method that can reduce software overhead and eliminate or at least reduce performance bottlenecks thereby improving system performance and architectural scalability at relatively low cost.
A computer system 10 according to one embodiment is shown in
The system controller 20 drives a display 26 through a graphics accelerator 28, which may include a graphics processor and graphics memory of conventional design. Also connected to the system controller 20 is an input/output (“I/O”) bus 30, such as a peripheral component interconnect (“PCI”) bus, to which are connected a keyboard 32, a mass storage device 34, such as a hard disk drive, and other peripheral devices 36.
The computer system 10 also includes system memory 40, which may be a dynamic random access memory (“DRAM”) device. The system memory 40 is controlled by memory controller circuitry 44 in the system controller 20 through a memory bus 46, which normally includes a command/status bus, an address bus and a data bus. However, the system memory 40 departs from conventional systems by including in the system memory 40 an on-board cache system 50 that enhancers the ability of the parallel processors 141-N to access the system memory 40 in an efficient, low latency manner. It should also be understood that the cache system 50 may be used in the system memory 40 or other memory devices in a computer or other processor-based systems that differ from the computer system 10 shown in
The use of a cache system in the system memory 40 may provide several advantages, particularly as the demands on memory devices increases with increasing parallelism. The cache system can significantly reduce the amount of hardware required for the parallel processors 141-N to communicate with other and/or access the system memory 40, and it can reduce processor and network complexity in high-end systems. Although placing a cache function within the system memory 40 does not provide cache bandwidth the same as in the typical case in which a cache, like the L2 cache 24, is implemented on or in communication with the processors 141-N, it does provide for sharing data between the processors 141-N as well as between threads being executed by the processors 141-N without resulting in bank timing and other issues that lower sustained memory bandwidth. Additionally, unlike caches in or associated with processors, a cache system in the system memory 50 avoids the need for a cache system for each of a large numbers of processors, cores, and threads, thereby minimizing die size and interconnect and pin issues. Also, depending on the system and network architectures, data coherency design can be greatly simplified by sharing data through memory-level caching. In most systems, the cache system would functions as a Level 3 (“L3”) cache since the system 10 will generally include L1 cache in the parallel processors 141-N in addition to the L2 cache 24. A cache system in the system memory 40 can also reduce read latency for memory requests and improve performance because data that is found in the cache system avoids DRAM memory cycles, tFAW limits, etc. Additionally, many applications may benefit by increased memory buffering compared to the capacity of page/row buffers in each memory bank. The cache system can also provide improved communication processes, also possibly improving sustained system performance without changing peak bandwidths that may result in increased costs of higher pin counts, etc. The cache system or a cache system according to some other embodiment can be implemented in the system memory 40 while keeping the internal organization of the memory system substantially the same as in conventional system memories. For example, bank timing and memory data rates can be substantially the same. Further, the cache system need not be particularly fast as the operations needed are generally simple and fit with current and anticipated memory clock rates.
A portion of a system memory device according to one embodiment is shown in
The DRAM device 60 also includes a Cache System 90, which includes a Cache Memory 94 that is associated with the Bank 64, which also includes memory cells arranged in rows and columns. If a DRAM device 60 includes multiple banks 64, a Cache System 90 may be associated with each Bank 64. The Cache Memory 94 may have a capacity that is large enough to store several pages or lines of the Bank 64. The Cache System 90 also includes a Tag Buffer 96 and a Tag Comparator 98.
The Cache Memory 94 will normally store a changing subset of what is in the Bank 64. Also, data stored at a specific memory line/address can generally reside in multiple places in the Cache Memory 94. As a result, when a cache reference is made, there is a lookup/translation made to convert the requested memory address to a specific location in the cache. The translation is normally done by storing in the Tag Comparator 98 the address of each line as it is stored in the Cache Memory 94. The Tag Buffer 96 uses a portion of the corresponding address of the Bank 64 to access another portion of the referenced address, which is known as a Tag Address. The Tag Address stored in the Tag Buffer 96 is applied to the Tag Comparator 98, which determines if the Tag Address matches corresponding bits in the referenced address. In the event of a match, which is known as a tag “hit,” the Tag Comparator 98 outputs the Tag Address as a Cache Row Address to select the row of memory cells in the Cache Memory 94 that stores that data. In the event there is no match, which is known as a tag “miss,” the Tag Comparator 98 does not output a Cache Row Address to the Cache Memory 94. In response to a miss, data must be fetched from the memory Bank 64 if the reference was a read. For writes, an immediate read reference can be triggered by the write command, and the data from the read is then merged into the cache line with the original command's write data as well as any new data written since. Alternatively, merging command-write and memory-read data can be postponed until the cache line is evicted from the Cache Memory 94.
In interactions with the Memory Bank 64, each row of the Cache Memory 94 is generally treated as a whole entity, just like when executing normal bank references. Similarly, read and write references appear to be normal I/O transfers. The number of lines in each Cache Memory 94 associated with a respective bank is always a power of two. For example, if the Bank 14 uses 2 KByte pages, then 8 cache lines per Bank 64 provide 16 KBytes of cache per Bank 14. If there are 8 Banks 64 in a memory device, then there are 128 KBytes of cache memory in the device. A memory module (not shown) having 16 memory devices would then have 2 MBytes of cache/buffer memory. As a fair portion of memory accesses will result in cache hits, the use of the Cache System 90 in memory devices may reduce cycle-time and limitations resulting from a large number of banks. The interface to the DRAM device 60 used by the memory controller circuitry 44 may be any suitable design, including interfaces designed according to DDR2 and -3 specifications and data rates. The Cache System should not increase power very much over standard DRAMs as standard functions are done and only one line of the cache per memory bank is active at a time, just as if it were a normal memory row-buffer. There generally will be some added power in the Tag Comparator 98, which checks to see if requested data is present in the Cache memory 60 or instead must be retrieved from the Bank 64. This added power could be largely eliminated if the memory controller 44 (
The memory controller 44 may interface with the Cache System 90 using a variety of techniques. For example, the memory controller 44 may send references to the system memory 40 regardless of whether the requested data is stored in the Cache Memory 94 or not. If the requested data is not stored in the Cache Memory 94, it can be written to the Cache Memory 94 for subsequent access. If the requested data is stored in the Cache Memory 94, then it is returned more quickly than if the data had to be fetched from the Bank 64. This is the simplest way to use the Cache System 90 since it functions in the same manner as a conventional L2 cache. As there are timing differences when data is in the cache Memory 94 or in the Bank 64, the memory controller 44 must be designed so that it can accommodate those differences. For example, if requested data is not stored in the Cache Memory 94, the memory controller 44 may have to issue the request a second time after the requested data has been loaded to the cache. The memory controller 44 must therefore be designed with the timing flexibility required to operate in this manner.
The memory controller 44 may also interface with the Cache System 90 using other techniques. For example, the memory controller 44 may be designed to keep a record of what lines of data are stored in the Cache Memory 94 and to fully control the operation of the Cache System 90. In such a case the Cache System 90 functions like an address-variable data buffer. However, the Cache System 90 must be designed so that it supplies the memory controller 44 with signals to provide information about the status of the Cache System 90.
If line of data referenced by a memory command, such as an activate command, is to be loaded into the Cache System 90, then the Cache System 90 can be designed to precharge the Bank 64, so that the Bank 64 is decoupled from operations in the Cache System 90. However, data must remain valid in the Cache System 90, possibly for a very long time such as, for example, when the Bank 64 is placed in a powerdown/Self Refresh mode. During this time, data may still be fetched from the Cache Memory 94. By automatically precharging rows of data in the Bank 64 that are being transferred to the Cache Memory 94, there is no need to write the cache lines back to Bank 64 during or before refresh operations. Alternatively, the Cache System 90 can be designed so that a row in the Bank 64 is being refreshed, the row in the Cache Memory 94 storing the corresponding data can be used to write the data back into the Bank 64. In any case, lines of data that are modified in the Cache Memory 94 must be written to the Bank 64 before they can be replaced by another line.
In another embodiment, the Cache System 90 operates by providing an indication that the referenced line is not to be loaded to the Cache Memory 94, and a normal read or write occurs in the Bank 64. In this case, it would be necessary for the memory controller 44 to provide an explicit precharge to the DRAM device 60, either as a separate command or as an auto-precharge in a read/write/CAS reference. This duplicates current operations for DRAMs.
As mentioned above, refresh logic can be expanded so that when a row in the Bank 14 whose contents are stored in the Cache Memory 94 is to be refreshed, the line in the Cache Memory 94 is written to the row in the Bank 64 instead. This approach maintains coherency between the Bank 64 and the Cache Memory 94 if any writes to Cache Memory 94 have been performed. If the memory controller 44 is managing the Cache System 90, then a write to the Bank 64 in this manner is unnecessary as the memory controller 94 must instead issue a specific Precharge-Write to the DRAM device 60 to store a cache line in the Bank 64. This Precharge-Write is most easily done before an Activate command loads new contents to the Cache Memory 94. Other techniques may, of course, be used to postpone writing the old contents of a line before reading new contents. This reduces read latency at the cost of some additional circuitry in cache management.
Alternatively, the Cache System 90 can be entirely decoupled from the refresh of the Bank 64. In such case, the data stored in the Cache Memory 94 can store the data that was stored in the row of memory cells of the Bank 64 that are being refreshed. The contents of the Bank 64 will then be coherent with the data stored in the Cache Memory 64 and my be considered valid. In this case, the memory controller 44 should be designed so that it is responsible for ensuring that cache lines are written back to the Bank 64 before new lines are loaded. In alternative embodiments, the Cache System 90 can be designed to automatically perform this function, or the memory controller 44 can be designed to explicitly evict cache lines in the event the memory controller 44 is to fully control the Cache System 90.
In some embodiments, each line of the Cache Memory 94 be a fraction of a line in the Bank 64, such as half, quarter, or eighth of a line the Cache Memory line would be 512, 256, or 128 bytes, respectively, for Bank 94 lines of 1K bytes. This approach can decrease the needed size of the Cache Memory 94. In other embodiments, the size of each line in the Cache Memory 94 can be configurable through a mode register (not shown), which is typically used in memory devices.
In some embodiments, the memory bus 46 (
In other embodiments, the memory bus 46 (
If a cache reference is made that causes a miss sequence, the DRAM 60 processes the miss so that all non-cache references cause an automatic precharge in the Bank 64. When a cache reference is made for data that is, in fact, not in the Cache Memory 94, a cache line is chosen and assigned to hold data for all references to that line, which is know as “allocation.” If the original reference is a read, data is loaded from the Bank 64, and all data in the allocated line is set valid. If a write operation is the original reference, then only the written portion of the line is valid. If a cache read reference hits, the Cache System 90 returns the referenced data with a hit signal. If a write reference hits, the write data is written into a line of the Cache Memory 94, marking that data as changed. The Cache System 90 then returns a hit signal. If a write reference misses, a line to be evicted is found. The evicted line is moved to another storage device, such as the Bank 64 or a line buffer (not shown), the new write data are written into the evicted line in the Cache Memory 94, and that data are marked as “changed.” These “changed” signals are used when evicted lines are written back to the Bank 64, so that correct data can be stored/restored back to the bank 64. As data are accepted into the freed-up line, a bank cycle is started to store any write data written to the evicted line while it was in the Cache Memory. This is done by reading the needed row from the Bank 64 using the tag address for the evicted line, merging write data from the evicted line with the read data from the Bank 64, and writing the result back to the Bank 64. A miss signal is then returned to the memory controller 44. If a subsequent read reference arrives for a line in which miss processing is already underway, a miss is returned. Finally, any miss reference allocates an unallocated/invalid sub-cache line if one is properly available.
In general, it is preferable for an operation that consists of two or more parts to be performed as a single indivisible operation. An example is where a byte in a 32-bit word is updated (read and then written) while preventing access to the word while the update is being executed. Functions like these, which are sometime referred to as “atomic,” are desired when parallel processes access and update shared data.
Portions of a cache line containing portions holding data that must be written back to the Bank 64 when the line is invalidated must to marked to indicate that fact. Data in a cache line that must be written back to Bank 64 is most often referred to as “dirty.” However, when data from a write command is written to a portion of a cache line, the cache line is considered “changed.” On the other hand, if an evicted line has no changes—data in the line was only read—the contents of the Bank 64 can be considered valid and a bank cycle can be avoided. However, the design of the memory controller 44 can be simplified if a line eviction evicted lines always cause a memory cycle; otherwise the memory controller 44 has to track each line's changed state. As a result, the Bank 64 should always store evicted lines without regard to whether that line is changed and/or been written to while in the Cache Memory 94. If the contents of a line in the Cache Memory 94 are in a state or are processed so that the line does not hold valid data or data that is different than the current contents of the Bank 64, the line can be reallocated with new contents. If portions of a line are marked changed as explained above, then invalidation involves writing those portions back to the Bank 64 and then setting a line's Invalid flag. If nothing in a cache line has been written/changed, then the invalid flag is simply set. At startup all lines are marked invalid.
Rather than have a line from the Bank 64 be able to be placed at any location in the Cache Memory 94 (which can take a lot of logic to support), some of the row bits of the requested address can be used to restrict which cache addresses can hold the line. If a particular line can be placed in only two places in the Cache Memory 94 so that only two memory tags must be examined, this is known as a 2-way set associative implementation. If a line can go in only four places, this is known as a 4-way set associative implementation. As the level of associativity is increased, the memory performance is increased as well as the logic expense to support the improvement. However, 1-way a set associative implementation should be avoided because it does not provide good performance because of almost constant cache evictions, which can slow the operation of the Cache System 90 to limits governed by the memory cycle time.
In the even the system memory 40 includes multiple banks of memory cells, a portion of the Cache Memory 64, which can be considered a sub-cache, may be associated with each memory bank. This allows full overlap of operations between banks as well as operations involving cache references. Each piece of the Cache Memory 64 is as independent of the others as each bank is independent of the other banks. For each memory bank there can also be cache references ongoing with memory references as long as all the cache references ‘hit’ or memory operations interleave cache operations.
References sent by the memory controller 44 without the cache status signal active are considered “normal” references to a row of the Bank 64. It is normally an error to make a row-buffer, non-cache memory reference to data that is stored in the Cache Memory 94. If this is done the memory returns a hit status signal, indicating the situation. In some embodiments, all references are considered to the Cache Memory 64. If the cache status signal is not active for a request and the data is not in the Cache Memory 64, a normal page/row buffer reference is made without data being placed into the Cache Memory. If the referenced data is, in fact, stored in the Cache Memory 94, that data is returned instead of what is stored in the Bank 64.
In the embodiment shown in
When making a cache reference so the cache status signal is active, a precharge request evicts the referenced cache line back to the Bank 64 at completion of the reference if the reference is a hit. Any data in the page/row of the Bank 64 is invalidated; the row buffer must not be awaiting a precharge signal or command to keep memory valid. This means that the row-buffer/normal/non-cache references are normally expected to be used in a close-page mode. If a read or write cache reference w/precharge misses, then the reference acts as if it is non-cached except that if a line would be evicted without the precharge then that still takes place and the evicted line is written back to the Bank 64 and the associated cache line marked invalid. Eviction will not be accomplished only if the line that would have been allocated is already invalid. Making a cache read reference w/precharge is an easy way for the memory controller 44 to evict (store to the Bank 64) a specific line or to create space in the Cache Memory 94 for a line that will be loaded in the future.
The memory controller 44 can also send specific cache activate commands to cause a row to be loaded into the Cache Memory. In such case, the memory controller 44 can normally only send read or write references, and the Cache System 90 will respond with either a hit or miss from each reference. Doing this supports a processor's ‘Prefetch’ function if extant.
If eviction is controlled by the memory controller 44 rather than the Cache System 90, the controller can have full knowledge of what memory lines are active in the Cache Memory 94. This is because evicting a line leaves that position in the Cache Memory 94 invalid/unallocated. Another line can then be loaded into the Cache Memory 94 without causing further misses, given that the new line can be allocated to the unallocated line's position. The memory controller 44 can also make miss references ahead of the time when data will actually be needed. This means that the memory controller 44 can know exactly what the cache hits and misses will be. This allows the memory controller 44 to use the Cache System 90 as a data buffer and not as a normal cache. With an added cache status signal as explained above, the memory controller 44 still has full memory access while being able to use the cache/buffer.
The use of the Cache System 90 in the DRAM 60 can easily support burst-of-4 (“b-o-4”) operation. This is because the row bits of a memory address are used as Tag entries to see if the data requested is currently in the Cache Memory 94 and to reference them from the Bank 64 if needed. It thus takes two memory clocks to send references to the DRAM 90, even if the memory controller 44 operated as if the referenced data is stored in the Cache Memory 94. Cache references thus pair RAS and CAS requests. A cache/RAS reference does a tag translation so that a subsequent cache/CAS reference can be done. If the cache/RAS reference hits then no memory reference is made. If the cache/RAS reference misses, then an eviction sequence is started, if needed, and a read reference is made if the cache/CAS reference is a read.
The column bits of a cache reference are used to select the needed data from a cache line. If the memory bus 46 and the interface between the memory controller 44 and the DRAM 90 allow a subset of the row bits to be sent at the same time as the column bits, or if commands are sent DDR, like data bits, then b-o-2 could reasonably be supported. Because of the cache, the IO pins are decoupled from bank cycle timing. However, additional signal lines could be included to indicate that there is no miss testing needed for this reference, and the other additional signals could reference the cache entry. If there are 16 cache lines in each bank then a total of 5 additional signals would be required. Alternatively, a cache state such as allocated/invalid could be made available through an extension of configuration/mode registers (not shown) that are typically included in memory devices. When making cache references, the RAS and CAS lines can be used to indicate specific cache commands. For example, to make an Activate reference w/o moving any data.
One embodiment of a 2-way set-associative implementation is shown in
It should never occur that both of the selected tags match as this means that a line is in the cache twice. Not all bits of a requested address are used in the equality testing. Some of the bits are used to choose one of the set-associated groups and are not stored in the Tag buffer either. The true outputs of the Equal Comparators 100, 104 are applied to respective AND gates 110, 114, which also receive respective bits from the cache. In the event of a match, an enabling signal to read a requested row is generated by an OR gate 118, which receives respective outputs from the AND gates 110, 114. The signal output by the OR 118 indicates the data stored designated by the requested address is present in a corresponding row of the Cache Memory 94.
The “CB's” in the Tag Buffer 96 stands for Change Bits. When write operations are sent to the Cache System 90, bits are set in the corresponding tag entry to record the column addresses written in that line. These bits are then used when a cache line is evicted and the data replaced in the Bank 64. There are some other bits, generally kept in the Tag Buffer 96, that are not shown here. These support LRU (Least Recently Used, for assisting in line evictions) operation for example, or might include a bit that, if set, prevents a line in the cache from being written/changed.
With reference to
When a line is to be evicted from the Cache Memory 94 so that another line can take its place, the request address of the new line, indicates the choices in the line to be evicted. Generally the line that has the fewest or oldest references is picked for eviction. In other embodiments, simpler eviction procedures are used, such as picking the line to be evicted at random. In the embodiment shown in the figures, a function can be sent to evict a particular line as a command from the memory controller 44. This may provide higher performance at relatively little or no cost.
In another embodiment, if Change Bits (“CBs”) are supported down to the lowest level (4-bit nibble), then a large number of CBs are provided for each line of the Cache Memory 94. In still another embodiment, a read reference is made to the Bank 64 when a write miss happens, and the Cache System 90 merges data into the allocated cache line. This means that the whole line can then be written back to the Bank 64 when the line is evicted. However, the write data of the original miss reference and any subsequent references must be held until read data from the Bank 64 are returned to validate the line in the Cache Memory 94, or change bits (or a simplified equivalent) must be used to enable a correct data merge to be performed. As mentioned above, in the event of a cache miss, all row address bits are used to reference the Bank 64.
From the foregoing it will 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.
This application is a continuation of U.S. patent application Ser. No. 11/893,604, filed Aug. 15, 2007, U.S. Pat. Ser. No. 7,822,911. This application is incorporated by reference herein in its entirety and for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
4787041 | Yount | Nov 1988 | A |
4789925 | Lahti | Dec 1988 | A |
4796232 | House | Jan 1989 | A |
4975878 | Boddu et al. | Dec 1990 | A |
5067071 | Schanin et al. | Nov 1991 | A |
5163139 | Haigh et al. | Nov 1992 | A |
5420994 | King et al. | May 1995 | A |
5457482 | Rhoden et al. | Oct 1995 | A |
5488583 | Ong et al. | Jan 1996 | A |
5524225 | Kranich | Jun 1996 | A |
5678021 | Pawate et al. | Oct 1997 | A |
5682344 | Seyyedy | Oct 1997 | A |
5737757 | Hassoun et al. | Apr 1998 | A |
5802541 | Reed | Sep 1998 | A |
5835925 | Kessler et al. | Nov 1998 | A |
5907861 | Seyyedy | May 1999 | A |
5978915 | Lisart et al. | Nov 1999 | A |
6026478 | Dowling | Feb 2000 | A |
6049487 | Plants et al. | Apr 2000 | A |
6081876 | Brewer et al. | Jun 2000 | A |
6321314 | Van Dyke | Nov 2001 | B1 |
6343346 | Olnowich | Jan 2002 | B1 |
6378049 | Stracovsky et al. | Apr 2002 | B1 |
6563754 | Lien et al. | May 2003 | B1 |
6611904 | Uguen | Aug 2003 | B1 |
6868019 | Mohr et al. | Mar 2005 | B2 |
7174429 | Revilla et al. | Feb 2007 | B2 |
7203791 | Lee et al. | Apr 2007 | B2 |
7320100 | Dixon et al. | Jan 2008 | B2 |
7421564 | Rahim et al. | Sep 2008 | B1 |
7565593 | Dixon et al. | Jul 2009 | B2 |
7574576 | Kato et al. | Aug 2009 | B2 |
7676728 | Resnick et al. | Mar 2010 | B2 |
20030018860 | Krueger | Jan 2003 | A1 |
20030056143 | Prabhu | Mar 2003 | A1 |
20030221091 | Henry et al. | Nov 2003 | A1 |
20040093458 | Kanno et al. | May 2004 | A1 |
20040093467 | Shen et al. | May 2004 | A1 |
20040193837 | Devaney et al. | Sep 2004 | A1 |
20040202034 | Lee | Oct 2004 | A1 |
20050022065 | Dixon et al. | Jan 2005 | A1 |
20050097276 | Lu et al. | May 2005 | A1 |
20050144375 | Bains et al. | Jun 2005 | A1 |
20050207257 | Skidmore | Sep 2005 | A1 |
20050219901 | Gilton | Oct 2005 | A1 |
20060047886 | Leaback | Mar 2006 | A1 |
20060190671 | Jeddeloh | Aug 2006 | A1 |
20060274577 | Pascucci et al. | Dec 2006 | A1 |
20070067556 | Dixon et al. | Mar 2007 | A1 |
20070091707 | Hidaka | Apr 2007 | A1 |
20070101238 | Resnick et al. | May 2007 | A1 |
20070113150 | Resnick et al. | May 2007 | A1 |
20070150671 | Kurland | Jun 2007 | A1 |
20080155217 | Kato et al. | Jun 2008 | A1 |
20080183984 | Beucler et al. | Jul 2008 | A1 |
20080189557 | Pipitone et al. | Aug 2008 | A1 |
20090006800 | Bellofatto et al. | Jan 2009 | A1 |
20090049250 | Resnick | Feb 2009 | A1 |
20090049264 | Resnick | Feb 2009 | A1 |
20090138675 | Marr et al. | May 2009 | A1 |
20090138680 | Johnson et al. | May 2009 | A1 |
20090138687 | Kang | May 2009 | A1 |
20110119467 | Cadambi et al. | May 2011 | A1 |
20110191548 | Miller et al. | Aug 2011 | A1 |
20120023294 | Resnick | Jan 2012 | A1 |
20120102275 | Resnick | Apr 2012 | A1 |
20130013876 | Resnick | Jan 2013 | A1 |
Number | Date | Country |
---|---|---|
0718769 | Jun 1996 | EP |
200635383 | Oct 2006 | TW |
200729859 | Aug 2007 | TW |
Entry |
---|
“International Search Report and Written Opinion”, International Application No. PCT/US2008/071087, mailed Feb. 18, 2009. |
Office Action dated Aug. 31, 2012 received for TW application No. 097130739. |
“IEEE 100 The Authoritative Dictionary of IEEE Standard Terms”, IEEE, Seventh Ed., Dec. 2000, pp. 787-788. |
Fang, et al., “Active Memory Operations”, ACM, Jun. 2007, 232-241. |
First Office Action dated Oct. 30, 2012 for TW application No. 097130579. |
Number | Date | Country | |
---|---|---|---|
20110029712 A1 | Feb 2011 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11893604 | Aug 2007 | US |
Child | 12902043 | US |