Movatterモバイル変換


[0]ホーム

URL:


US5754819A - Low-latency memory indexing method and structure - Google Patents

Low-latency memory indexing method and structure
Download PDF

Info

Publication number
US5754819A
US5754819AUS08/282,525US28252594AUS5754819AUS 5754819 AUS5754819 AUS 5754819AUS 28252594 AUS28252594 AUS 28252594AUS 5754819 AUS5754819 AUS 5754819A
Authority
US
United States
Prior art keywords
bit
memory
bits
address
equality
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
US08/282,525
Inventor
William L. Lynch
Gary R. Lauterbach
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sun Microsystems Inc
Original Assignee
Sun Microsystems Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sun Microsystems IncfiledCriticalSun Microsystems Inc
Priority to US08/282,525priorityCriticalpatent/US5754819A/en
Assigned to SUN MICROSYSTEMS, INC.reassignmentSUN MICROSYSTEMS, INC.ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: LAUTERBACH, GARY R., LYNCH, WILLIAM L.
Assigned to SUN MICROSYSTEMS, INC.reassignmentSUN MICROSYSTEMS, INC.RECORD TO CORRECT STREET NAME FROM "GARCIAN" TO GARCIAAssignors: LAUTERBACH, GARY R., LYNCH, WILLIAM L.
Priority to DE69528615Tprioritypatent/DE69528615T2/en
Priority to EP95111551Aprioritypatent/EP0694845B1/en
Priority to JP7211201Aprioritypatent/JPH0863974A/en
Application grantedgrantedCritical
Publication of US5754819ApublicationCriticalpatent/US5754819A/en
Anticipated expirationlegal-statusCritical
Expired - Lifetimelegal-statusCriticalCurrent

Links

Images

Classifications

Definitions

Landscapes

Abstract

A significant reduction in the latency between the time the addressed components of memory are ready and the time addressed data is available to the address components of memory is achieved by processing the raw address information faster than the addition used in the prior art. XOR memory addressing replaces the addition of the base and offset address components with an XOR operation, eliminating carry propagation and reducing overall latency. In another embodiment, a sum-addressed memory (SAM) also eliminates the carry propagation and thus reduce the latency while providing the correct base+offset index to access the memory word line corresponding to the correct addition; thus a SAM causes no XOR duplicate problems.

Description

INTRODUCTION
This invention pertains to memory systems, and more specifically to a method and structure for addressing memories with low latency.
Modern processors address memory, including cache memories, with base+offset addressing. FIG. 1 is a diagram depicting one embodiment of a typical prior art addition-indexedmemory 10, which can if desired serve as a cache memory. Addition-indexedmemory 10 includesdata array 11 having a plurality of word lines, such as word lines 11-0 through 11-7, which are capable of being accessed by access signals provided by AND gates 12-0 through 12-7, respectively, in order to provide a selected one of the data words stored indata array 11 onoutput bus 13. The addresses applied to AND gates 12-0 through 12-7 are derived byaddress addition circuit 15, which receives a base address a2, a1, a0, and an offset address b2, b1, b0, which are added in order to provide select signals s0, s0, s1, s1, s2, s2 for application to the array decoder formed by AND gates 12-0 through 12-7.
The latency from the time when the address components 12-0 through 12-7 are ready until the time the addressed data is available includes the time required foraddition circuit 15 to add base and offset address data. This excess latency typically manifests itself in a pipelined processor as a load-use penalty; the load results are unavailable until two cycles after the machine scalarity exacerbates the problem twofold: load-delay slots must become load-delay groups, requiring many more instructions to be issued to hide the latency, and the effect of the latency becomes relatively more significant as the baseline performance of the machine improves. Thus, while uniscalar machines may show only 0.05 CPI/1.8 CPI=3% performance loss due to one load delay slot, as described in Olukotun, Kunle, Trevor Mudje, and Richard Brown, "Performance Optimization of Pipelined Primary Caches", 19th Annual International Symposium on Computer Architecture, 1992, pages 181-90, simulations of a three-scalar machine show 10% performance loss due to a single load delay slot.
As well as data caches, other CPU memory units are also addressed after an addition of base and offset address information. Instruction caches frequently require additions before indexing; both sequential code (incrementing) and pc-relative branches require some form of addition before cache indexing. Table Lookaside Buffers (TLBs) also usually require a base+offset addition before translation begins. Register windows may also be implemented with a base pointer plus offset address.
SUMMARY
In accordance with the teachings of this invention, a significant reduction in the latency between the time the addressed components of memory are ready and the time addressed data is available to the address components of memory is achieved by processing the raw address information faster than the addition used in the prior art.
In one embodiment of this invention, XOR memory addressing replaces the addition of the base and offset address components with an XOR operation. XORing the raw base and offset address information eliminates carry propagation and thereby reduces the overall latency, while the resulting duplicated entries only somewhat increase complexity. The XOR speed improvement arises primarily from the lack of any information transfer among the bits (i.e., a carry chain).
In another embodiment, a sum-address-memory (SAM) also eliminates the carry propagation and thus reduces the latency while providing the correct base+offset index. Like XOR memories of this invention, sum-addressed-memories reduce the address-component-ready to data-available latency. SAMs reduce latency less than XOR memories, but access the memory word line corresponding to the correct addition; thus a SAM causes no XOR duplicate problems and when used as a cache memory has a miss rate equal to a conventional cache memory.
Neither the XOR or SAM method and structures of this invention have carry propagation: XOR and SAM logic require constant latency regardless of the number of bits while addition latency increases with the number of bits. Thus, the advantage of XOR and SAM over prior art addition-before-indexing increases with memory size.
BRIEF DESCRIPTION OF THE DRAWING
FIG. 1 is a diagram depicting a typical prior art addition indexed memory;
FIG. 2 is a diagram depicting one embodiment of a circuit suitable for use in accordance with the teachings of this invention in which base and offset address bits are added for the sole purpose of performing the tag checks;
FIG. 3 is a diagram depicting one embodiment of a memory structure of this invention, utilizing exclusive ORing of the base and offset components of the address;
FIG. 4 is a diagram depicting on embodiment of a SAM of this invention;
FIGS. 5a through 5d are a schematic diagram depicting embodiments of the ei functions of equation (7);
FIG. 6 is a diagram depicting one embodiment of a sum-address-memory constructed in accordance with the teachings of this invention;
FIG. 7 is a diagram of one embodiment of a SAM decoder of this invention capable of performing with a late carry;
FIG. 8 is a diagram depicting a multiple bit SAM of this invention; and
FIG. 9 is a diagram depicting one embodiment of a sum-content-addressable memory (SCAM) of this invention.
DETAILED DESCRIPTIONXOR Memories
In accordance with one embodiment of this invention, base and offset address components are combined by exclusive OR operations, rather than additions. The use of an exclusive OR operation increases speed in that, unlike an addition operation, no carry operations are required.
XORing the base and offset address components eliminates carry propagation and reduces the overall latency but the resulting duplicated entries somewhat increase complexity. The XOR speed improvement arises primarily from the lack of any information transfer among the bits (i.e., a carry chain). The addition of the address components must still occur for the tag check, but this addition may now proceed concurrently with cache access, for example utilizing the circuitry shown in the exemplary block diagram of FIG. 2.
Referring to FIG. 2, in this example, a 32 bit base address and a 32 bit offset address are received onbusses 201 and 202, respectively, and are applied toaddition circuitry 203, which provides a 30 bit result onoutput bus 204 tocomparator circuitry 205. Simultaneously the base and offset address information is provided viabusses 201 and 202 to exclusive ORcircuitry 206 which provides index output data tomemory array circuit 207, which provides a 30 bit tag word viabus 208 tocomparator circuit 205, enablingcomparator circuit 205 to provide a one bit hit signal onoutput lead 209 indicating whether the addressed data is in the cache memory. Note that in this example the cache line size is four bytes so that the lower two bits of the 32 bit address is not needed to index cache or check the tag. Simultaneously, the memory array circuit (such as shown in FIG. 3) provides 32 bits of output data ondata bus 313. Thus, although the addition of the address base and address offset components still take place in order to accomplish the tag check, this addition operation takes place concurrently with cache access, and thus no latency is incurred.
Both direct-mapped and set-associative caches map a large address range into the smaller index range of the cache with a hash function. Typically a modulus function of the cache index range is used as the hash function because it is very simple to implement as described, for example, in Smith, Alan Jay, "Cache Memories", Computing Surveys, 14(3):473-530, September, 1982, (i.e., after the base+offset addition the low order N address bits index the cache). A tag on each cache entry disambiguates the many addresses that can map into a single cache index.
Like conventional caches, XOR caches of this invention also use a hash function to map a large address range into a smaller cache index range, but that hash function combines the base and offset components of a memory reference with an exclusive-OR rather than an addition. The result of the exclusive-or of the low order bits of the address components is used to index the cache.
FIG. 3 shows the arrangement of one embodiment of cache index generation in an cache memory of this invention, with the low latency hash function provided by exclusive OR operation performed byaddress manipulation circuitry 315. Functions other than exclusive OR functions can also be used in accordance with the teachings of this invention. As shown in FIG. 3, one embodiment of an exclusive ormemory circuit 300 constructed in accordance with the teachings of this invention includes memory array 311 (corresponding generally tomemory array circuit 207 of the embodiment of FIG. 2) including a plurality of word lines 311-0 through 311-7, each storing a data word. A selected one of the data words is read out viaoutput bus 313 in response to memory access signals provided by AND gates 312-0 through 312-7, each correspond to an associate one of the word lines inmemory array 311. AND gates 312-0 through 312-3 are driven by signals generated from the base address component a2, a1, a0 and the offset address component, b2, b1, b0, as combined by exclusive OR gate circuitry 315 (corresponding generally to exclusive ORcircuitry 206 of the embodiment of FIG. 2).
The XOR memory of this invention uses a subset of the address bits to index the cache and thus shares with memories of the prior art the unavoidable characteristic of mapping many addresses to the same index. The XOR cache has the additional characteristic, not shared with conventional cache indexing, of mapping one address to several indices. This mapping of one to many arises when two sets of address components sum to identical indexes but XOR to different indexes. For example, a base of five and an offset of one have a traditional index of six, but an XOR index of four. The same address results from a base of six and an offset of zero, but the XOR index is six rather than the four of the other base-index pair. In this embodiment, the XOR cache tag includes the "index" bits from the actual address because the location no longer specifies those bits, as shown in Table
              TABLE 1                                                     ______________________________________                                    Base    Offset         Index  Tag                                         ______________________________________                                    5       1              4      6                                           6       0              6      6                                           ______________________________________
Apart from the necessary extra tag bits, the one-to-many mapping of the XOR memory of this invention results in two problems: an increased miss rate relative to the same size traditional cache, and greater difficulty in handling writes to the cache. One address can occupy many indices in an XOR cache memory of this invention; this duplicating reduces the effective size of the cache thereby increasing its miss rate. At the same time any writes to the XOR cache memory of this invention requires an update of all of the indices which contain the write address, in order to maintain consistency. We call data from a single address residing in multiple cache locations a "duplicate".
There are several ways of handling the duplicates in an XOR cache memory of this invention. If we allow duplicates to be entered into the cache then we must be able to update all of the duplicate entries for a particular address on a write to that address. In one embodiment of this invention, this is accomplished with a content addressable memory with one entry per cache index that matches on the address resident in the corresponding cache index. In this embodiment, a write is performed by presenting the write address to the CAM cells which drive the word lines of all of the duplicate cache indexes that contain the address.
In an alternative embodiment of this invention, the solution to the problem of duplicates is to prevent their creation while filling the XOR cache. In this embodiment, the XOR cache is included in a second-level cache so that a record is maintained in each second level cache line of the XOR cache index that was filled from that line. On a subsequent miss of the XOR cache the previous XOR index that was filled from the second level cache line is invalidated and updated with the new XOR index. This method ensures that at any given time data from one address can be resident at only one index in the XOR cache. By disallowing duplicates the problem of writing to the cache is solved; however there is a possible miss rate penalty to be paid. If one address is alternately referred to by base+offset components that map to two different XOR cache indices, the resultant activity will be to constantly fill one index and invalidate the other. Fortunately this seems to be a rare occurrence; Table 2 compares the miss rates of an XOR cache memory system of this invention with duplicates disallowed to a prior art cache memory of the same size on the SPEC92int programs. SPEC92int and the programs specified in Table 2 are benchmark programs available from the Standard Performance Evaluation Corporation of Fairfax, Va. The XOR cache memory system of this invention miss rate is 10% higher than the prior art cache. The percent of misses that invalidate a duplicate was measured to be quite infrequent and is also shown in Table
              TABLE 2                                                     ______________________________________                                    XOR 1KB cache miss rate comparison                                                 miss rate (% instructions)                                                                       % misses                                  SPEC92int                       invalidate                                Program    conventional  XOR    duplicates                                ______________________________________                                    008.espresso                                                                         4.86          5.32   2.58                                      022.li     4.37          5.56   1.18                                      023.eqntott                                                                          2.69          2.85   0.009                                     026.compress                                                                         4.59          5.13   0.02                                      00.72.sc   3.29          3.69   1.03                                      085.gcc    3.74          4.34   0.39                                      ______________________________________
SAM Memories
In an alternative embodiment of this invention, a sum-addressed memory (SAM) is provided.
A sum-addressed memory (SAM) also eliminates the carry propagation and thus reduces the latency while providing the correct base+offset index. SAM memories incur only slightly more latency than XOR memory indexing and significantly less latency than performing addition before cache indexing. Like the XOR memories of this invention, sum-addressed-memories of this invention reduce the address-component-ready to data-available latency. SAM memory reduce latency less than XOR memory, but access the memory location corresponding to the correct addition; thus a SAM memory causes no XOR duplicate problems and thus when used as a cache memory has a miss rate equal to a conventional cache.
Memories of this invention perform functions of multiple input variables in the decoder of RAM arrays beyond the normal decoding function. The normal decoding function takes one length-n input vector and decodes it into 1 of 2n outputs, which then drives a word line. SAM decoders take a number of length-n input vectors and decodes into 1 of 2n outputs equal to the evaluation of the function for those vectors. SAM can evaluate functions which "ripple", i.e. where an output bit depends on the evaluation of the function for other input bits.
SAM operates on overlapping segments of the input vectors, as depicted in FIG. 4. Base address bits form vector a, having a plurality of segments a0 through a3 and offset address bits form vector b, having a plurality of segments b0 through b3 in the exemplary FIG. 4. These segments need not be identically sized for correct operation. Thus, if desired, each segment can be of any size, and the amount of overlap can be different from segment to segment, so long as the segments overlap by the number of bits necessary to communicate the necessary ripple information from one segment to the next, based on the maximum influence on more significant bit positions as a result of a computation at a given bit position. For the addition embodiment of this invention, the necessary overlap is only one bit. Thus as shown in FIG. 4, overlap is provided by overlap vectors O1 through O3. For a 53×53 bit multiply (as a standard double precision multiply) embodiment of this invention, the necessary overlap is 6 bits to accommodate the maximum influence of six bits.
The output of each of the segment SAM circuits as shown in FIG. 4, is a 2j of 2n fully decoded output, where j is the amount of necessary overlap for the implemented function, and n is the number of bits of that SAM circuit. Of interest, this is distinct from the prior art of predecoding addresses, in that predecoding decodes n address bits to a single one of 2n output lines and does not evaluate a function of multiple address input vectors. In the embodiment of FIG. 4, input segments of address bits are operated on by functions 415-0 through 415-3 to provide a set of decoded output signals on decoded busses 416-0 through 416-3, having bit lengths of 2n.sbsp.0 through 2n.sbsp.3, respectively, where n0 is the number of bits associated with function 415-0, and the like. A SAM circuit with equal segments of size n and equal overlap of size j is termed an "n-j" bit SAM circuit. The ANDing of the decoded lines into the word line will select the final 2j of all the possible word lines. Either 1) one of the segments must use the overlap to fully decode into 1 of 2n, or 2) a plurality of word lines holding 2j elements is read from the RAM and a desired element is later selected by a 1 of 2j multiplex selection. If there is no carry in bit, the low-order segment may not be overlapped by any "lower-order" information (i.e., lower order bits of the function not used to index the RAM), and thus will naturally come down to 1 of 2n. Any lower-order information such as the carry in bit(s) will provide the information necessary to either fully decode the low-order segment to 1 of 2n or to select the 1 of 2j outputs, as with all other segments.
The embodiment of FIG. 4 evaluates a 2-input function with inter-segment communication of overlapping bits. As an example, one overlapping bit is an appropriate implementation of the addition function. In this embodiment, carry in bit Cin provides the lower-order information which fully decodes the low-order segment to 1 of 2n.sbsp.0
In alternative embodiments, the function calculated to provide a memory address decode need not be a addition of A and B. In these alternative embodiments, any desired function which ripples is used, that is any function which has the effect on the overlapped bits of an address portion to determine the output of that portion.
A+B=K
It is known in the prior art that the result of an equality test A+B=K can be evaluated quickly. In accordance with this invention, we have determined that the equality test A+B=K is useful for calculating the fully decoded output signals of FIG. 4, for example. Given three n-bit vectors A=aa-1 an-2 . . . a0, B=bn-1 bn-2 . . . b0, and K=kn-1 kn-2 . . . k0, the carry in (ciin) and carry out (ciout) of each bit position i are uniquely determined if A+B=K. If for every bit position the carry out from the previous bit position is the necessary carry in to give ki as the answer, then A+B=K. More formally, define the propagate, generate, carry out, and sum for the ith bit as, respectively, ##EQU1## A+B=K can be determined by testing si against ki for all bit positions i; an add followed by a compare. However, if the answer is K, then ##EQU2## Note that ciin and ci-1out do not depend on propagation, rather only on a, b, and k from their respective bit positions. If ##EQU3## is true then a simple inductive proof (given formally by Cortadella and Llaberia in "Evaluating A+B=K Conditions in Constant Time," IEEE International Symposium on Circuits and Systems, 1988, pages 243-6 and in "Evaluation of A+B=K Conditions Without Carry Propagation", IEEE Transactions on Computers, November, 1992, 41(11):1484-8) established that starting with c-1out as the overall carry in proves that A+B=K.
A+B=K Equality Testing to Provide Fast Decode
The decoder array of RAMs can be considered to perform a large ANDing of the address lines. FIG. 1 shows the logic of a RAM decoder (the actual implementation may vary) for an eight entry RAM with three address bits. The AND gates of the decoder array simultaneously test S=K for each word line K.
Single bit SAM example
This high degree of decoding parallelism is used to advantage to produce a SAM; each word-line AND independently tests to see if A+B equals that word-line's K. To perform this highly parallel test, the "address" sent down the address lines into the decoder clearly cannot depend on K. To this end, define an equality function ##EQU4## and conditionalize ei with ki ki-1', giving ##EQU5## Conditionalizing the carry in and carry out equations results in computationally simple formulas: ##EQU6## For each bit position there are four cases of e1kiki-1 ##EQU7##
FIGS. 5a through 5d are examples of circuits providing logical functions for these examples of ei functions, except for the low-order bit position, where the carry in, c-1, replaces the i-1 terms ##EQU8##
Logically these equations can be performed in two levels of exclusive-OR gates, or they can be implementable in one complex gate. If area or power constrain more than speed, then the significant number of common terms allows slower implementations with fewer gates.
FIG. 6 is a schematic diagram of one embodiment of aSAM memory system 400 constructed in accordance with the teachings of this invention. As shown in FIG. 6,memory array 411 includes a plurality of word lines 411-0 through 411-7, each storing a word which is capable of being selectively accessed by AND gates 412-0 through 412-7 and output onoutput bus 413. In accordance with the teachings of this invention, signals are provided to AND gates 412-0 through 412-7 from sum-addressedcircuitry 415 in response to base address word a2, a1, a0, and offset address b2, b1, b0, and carry in bit c-1. Sum-addressedcircuitry 415 includes a plurality of equality function circuits for providing an equality comparison between Cin and Cout of consecutive bits, using for example the circuits of FIGS. 5a-5d. These equality functions provide the 2j of 2n decoding of the sum function. The number of equality function circuits required is 2n+1 equality circuit functions for all the high order bits, and 2n function circuits for the low order bits, for an n bit SAM or SCAM of this invention, which is discussed later.
The number of address lines per address bit intodecoder 415 doubles from two (true and complement of each address bit), as shown in FIG. 1, to four, (true and complement of each of the two address bits) while each word line decoder AND gate ANDs the same number of terms as in a prior art decoder array (such as is shown in FIG. 1). Thus, insidedecoder array 412, SAM decoding resembles two-bit pre-decoding. Two of the four equality gates per pair of address bits are on at once, corresponding to two sequential addresses. For a 1-bit SAM, two of these four lines into the decoder array are complements of the other two (this characteristic does not hold for the multiple-bit SAM).
The base and offset of the address arrive intoSAM decoder array 415. However, if the lower bits of the address do not index the memory, as is the case in a cache memory which uses low order bits of the address as a line offset and not as an index; then SAM decoding cannot decode these low-order bits, as they vary for a given index. The SAM decoder thus requires the carry-in c-1 bit, which is the result of the addition of the low order bits of the base and offset addresses.
Fortunately, the number of low order bits not used to index the memory, as in a cache, is typically small, and the carry-out c-1 of the low-order bits can be calculated quickly. In one embodiment, the SAM address lines responsive to the carry-out bit c-1 are intentionally made faster than other SAM address lines, to further prevent a reduction in overall circuit speed as a result of the need to calculate the carry bit c-1. A fast carry-out circuit from the low order bits is necessary; fortunately this circuit is typically small and as only the single carry-out bit is needed, in one embodiment power is allocated to speed this calculation and prevent delaying the overall memory access. Alternatively, a (k,k+1) pair of consecutive memory locations are read from the memory and one of these is then selected by the late-arriving carry-in bit c-1. This second embodiment preferably utilizes either effectively dual-porting or banking the memory into even and odd banks, and may require twice as many bit-lines and/or twice as many word-lines as waiting for the carry-in.
In an alternative embodiment, as shown in the example of FIG. 7, an embodiment of a SAM construction in accordance with the teachings of this invention capable of operating with late carry bits is shown. The late carry SAM indexedmemory 700 of FIG. 7 includes a plurality of word lines, such as word lines 711-0 through 711-7, split into a plurality of data rays, such as even data array 711-even containing word line 711-0, 711-2, 711-4, and 711-6, and odd data array 711-odd including word line 711-1, 711-3, 711-5, and 711-7.Decoder circuitry 715 receives a base address word A2, A1, A0 and offset address or b2, b1, b0, and it manipulates that data utilizing ei functions in order to provide output words todecoder array 712 which utilizes, for example, a plurality of AND gates 712-0 through 712-7 corresponding to word line 711-0 through 711-7. Odd and even data arrays 711-odd and 711-even thus provide, for each addressing operation, an output data word tomultiplexer 719.Multiplexer 719 selects the appropriate one of these data words in response to an ei function responsive to a0, b0, and the carry bit c-1, in order to provide the desired one of the data words onoutput data bus 713. Of interest, in this embodiment, the generation of carry bit c-1 is delayed somewhat from the availability of the base and offset address words. However, since odd and even data arrays 711-odd and 711-even are responsive to the base and offset address words without regard to the delayed carry bit, the delay in providing the carry bit c-1 corresponds generally to the time delay between the availability of the base and offset address words and the accessing of odd and even data arrays 711-odd and 711-even. Thus, when the delayed carry bit c-1 becomes available, the operation ofmultiplexer 719 takes place on the by then available output data words from odd and even data array 711-odd and 711-even.
Multiple-bit SAM Memories
In the previously described embodiment of the SAM decoder, each word line decoder AND gate has n inputs, where n is the number of bits in each cell's address K. For each address bit i, a group of four "equality" signals are computed: ei00, ei01, ei10, and ei11 (an exception to this rule is the least-significant bit position, where only e00c and e11c are required). The resulting 4n-2 signals are distributed to the decoder gates, where N is the number of address bits. These decoder gates then pick off one signal from the equality group for each address bit i, as determined by the bit i and bit i-1 values of the gate's address. We call this a "single-bit" SAM decoder, because there is an equality group for each bit of the address. This approach works well for small memories, but, as memory size increases, we encounter physical limits to the fan-in of word line decoder gates. One solution to this problem is for each equality group to examine more bit positions of the address inputs. This is analogous to the "predecode" technique used in conventional RAMs. For example, a "two-bit" SAM memory has an equality group for each two adjacent address bit positions.
FIG. 8 is a diagram of an exemplary two-bit SAM, used to describe a multiple bit SAM constructed in accordance with the teachings of this invention, which also applies to multiple bit SAMs of more than two bits. As shown in FIG. 8, a multiple bit SAM of this invention includes adata array 811 including a plurality of word lines 811-0 through 811-7. Word lines 811-0 through 811-7 are accessed bydecoder array 812, for example including a plurality of AND gates 812-0 through 812-7 corresponding to word lines 811-0 through 811-7, respectively.SAM decoder array 815 includes a plurality of ei functions responsive to an appropriate permutation of bits from the base address, offset address, and carry bit c-1. In terms of the single-bit equality functions that have been previously described, the exemplary two-bit equality functions are: ##EQU9## The LSB group is again a special case: ##EQU10##
For a SAM memory with an n-bit address (for simplicity, assume n is even), there are n/2 equality groups, each (except the low-order group) having eight equality signals. This gives a total of 4n-4 equality signals, which is approximately the same number required in the single-bit scheme. Each word line decoder gate has n/2 inputs, one from each group; the loading on each equality signal is half what it was in the single-bit scheme.
In one embodiment, these two-bit equality functions are generated from the single-bit equality functions by a single level of 2-input AND gates, as in a conventional RAM predecoder; the longest path from input to equality is thus two levels of XOR/XNOR (for the single-bit equality functions) plus an AND level. In an alternative embodiment, the two-bit equality function are generated directly from the inputs. The fact that the two-bit equality functions examine adjacent bits allows some algebraic simplification. For example, if we define ui =ai V bi and substitute, the two-bit equality functions reduce to ##EQU11##
The longest path in the two-bit equality function (assuming that all inputs are available simultaneously) is an XOR/XNOR followed by a 3-input AND followed by a 3-input OR. Each of the 4n+4 equality signals requires a 3--3--3-AND-OR gate. Built in this manner, the AND-OR gates load the intermediate nets more than for a 1-bit SAM, as shown in Table 3 corresponding with this example.
              TABLE 3                                                     ______________________________________                                    SAM intermediate net loading (fanout)                                     Signal        1-bit SAM                                                                          2-bitSAM                                          ______________________________________                                    p             2        20p             2        12g             2        14g             0         6u             2         6u             0        14                                                 ______________________________________
SCAM Memories
In an alternative embodiment of this invention, a sum-content-addressable memory (SCAM) is taught. Unlike the previously described SAM memories of this invention, in which address lines and equality functions are hard wired, in a SCAM of this invention, circuitry is utilized to allow equality functions to be selected based upon contents stored in the content addressable memory. The SCAM cell implements a conditional equality of the correct e0kiki-1 terms based on the contents of adjacent cells. However, SCAM requires more logic than a normal Content Addressable Memory (CAM) cell of the prior art. The "constant" K (the word line address in a RAM) becomes a variable in a SCAM, and thus in one embodiment, the pseudo-address lines consist of components of the carry equality (from the intermediate signal paths of FIGS. 5a-5d) rather than the four conditionalized carry equalities (from the final output lines of FIGS. 5a-5d). XOR, AND, and OR operations of the address components suffice to construct the equality signals in a one-bit SCAM cell.
FIG. 9 depicts one embodiment of a SCAM constructed in accordance with this invention. Referring to FIG. 9,SCAM 900 receives base address words a1, and a0, and an offset address word b1, b0, as well as carry bit c-1. These address bits are applied to equality functions as shown, in order to generate appropriate decoded signals for application to multiplexers 951-m, 952-m, 951-n, and 952-n. These multiplexers are controlled by stored bits which serve to select the appropriate e functions corresponding to the value of the plurality of consecutive stored bits (for the LSB with carry-in, fewer stored bits). The outputs from multiplexers 951-m and 952-m are applied to AND gate 953-m, in order to determine if there is an m-match, indicating no error has been detected, i.e. the equality functions are appropriately selected across the entire width of the stored memory value. Similarly, the output bits from multiplexers 951-n and 952-n are applied to AND gate 953-n to determine if there is an n-match. In accordance with the teachings of this invention, whenSCAM 900 is configured using addition functions to be more than a 2-bit SCAM, AND gates 953-m and 953-n receive an increased number of decoded output signals from the equality function circuitry as it is currently shown, and with respect to its generic description, such as more than two bits. In a simple configuration, the n-match and m-match signals are directly used as word line select signals.
In one embodiment of this invention, the carry-in bit used as a late select after the SCAM has cycled and matched up to two consecutively valued entries, one even, one odd, as previously described with respect to the SAM of this invention.
Conclusions
The XOR, SAM, and SCAM methods and structures taught by this invention reduce the address-components-ready to data-ready latency in memories accessed with base+offset addresses over the conventional addition followed by memory access. Candidates for these techniques include main memory data caches, instruction caches, register windows, and TLBs.
XOR memories decrease latency the most of these techniques, reducing latency to just one 2-input XOR gate over the RAM access. However, XOR memories introduce duplicate-entry problems because the memory location accessed may not always be the same for a given memory address. Extra hardware is necessary to prevent these problems, and when used as a cache memory, the miss rate deteriorates by about 10% (e.g., from 4.0 to 4.4 misses per 100 instructions) in the above example.
A SAM memory also reduces latency below add-then-index memory latency, reducing the latency to two 2-input XOR gates over the RAM access. A SAM memory indexes the correct memory location, and therefore has no duplicate-entry problems and when used as a cache memory, has a miss rate identical to a conventional cache.
All publications and patent applications mentioned in this specification are herein incorporated by reference to the same extent as if each individual publication or patent application was specifically and individually indicated to be incorporated by reference.
The invention now being fully described, it will be apparent to one of ordinary skill in the art that many changes and modifications can be made thereto without departing from the spirit or scope of the appended claims.

Claims (18)

What is claimed is:
1. A memory comprising:
a first set of address leads for receiving one or more base address bits organized into a plurality of segments;
a second set of address leads for receiving one or more offset address bits organized into plurality of segments;
a data array comprising a plurality of word lines;
address manipulation circuitry comprising:
a plurality of low latency hash functions, other than adders, each responsive to a unique combination of said base and offset address bits and including overlap between segments of said base address bits and said offset address bits, for providing a plurality of hash output signals which are fully decoded and in which more than one of said fully decoded signal is high; and
a decoder array comprising a plurality of decoders, each associated with one of said word lines, for receiving a selected combination of said hash signals to address a desired one of said word lines.
2. A memory as in claim 1 wherein the amount of said overlap is determined at least in part by the function performed by said hash functions.
3. A memory as in claim 2 wherein the amount of said overlap is also determined by the number of bits manipulated by each said hash function.
4. A memory as in claim 1 wherein said segments need not be of the same number of bits.
5. A memory as in claim 1 wherein said overlaps need not be of the same number of bits.
6. A memory as in claim 1 wherein said address leads include carry in bits.
7. A memory as in claim 1 wherein said hash functions emulate adders.
8. A memory as in claim 1 wherein said hash functions comprise a plurality of equality functions.
9. A memory as in claim 8 wherein said equality functions comprise: ##EQU12## where: ei00, ei01, ei10, ei11 represent said equality functions corresponding to the ith bit position,
ai, ai-1 represent the ith and the (i-1)th position bit of said base address bits respectively; and
bi, bi-1 represent the ith and the (i-1)th position bit of said offset address bits respectively.
10. A memory as in claim 8 wherein said equality functions comprise: ##EQU13## where: ei000, ei001, ei010, ei011, ei100, ei101, ei110, ei111 represent two-bit equality functions corresponding to the ith bit position,
ei00, ei01, ei10, ei11 represent single-bit equality functions corresponding to the ith bit position, and
ei-100, ei-101, ei-110, ei-111 represent single-bit equality functions corresponding to the (i-1)th bit position.
11. A memory as in claim 8 wherein said input vectors include carry in bits and said equality functions further comprise: ##EQU14## where: e100c, e101c, e110c, e111c represent two-bit equality functions corresponding to bit position 1,
e100, e101, e110, e111 represent single-bit equality functions corresponding to bit position 1,
e00c, e01c represent single-bit equality functions corresponding to bit position 0, and
c represents said carry in bits.
12. A memory as in claim 8 wherein said input vectors include carry in bits and said equality functions comprise: ##EQU15## where:
u.sub.i =a.sub.i b.sub.i
where:
ai represents the ith position bit of said base address bits;
ai represents the ith position bit of said offset address bits;
ei000, ei001, ei010, ei011, ei100, ei101, ei110, ei111 represent two-bit equality functions corresponding to the ith bit position,
e100c, e101c, e110c, e111c represent two-bit equality functions corresponding to bit position 1,
ρi, ρi-1, ρ1, ρ0 represent the propagates corresponding to bit positions i, (i-1), 1, and 0 respectively,
gi-1, gi-2, g0 represent the generates corresponding to bit position (i-1), (i-2) and 0 respectively, and
c-1 represents said carry in bit.
13. A memory as in claim 1 wherein said data array comprises a plurality of word lines organized as a plurality of banks which are read simultaneously in response to said hash output signals, and selection circuitry for selecting a desired one of said plurality of read word lines as a function of a selected subset of said address bits.
14. A memory as in claim 13 wherein said hash functions emulate adders.
15. A memory as in claim 13 wherein said hash functions comprise a plurality of equality functions.
16. A memory as in claim 1 which further comprises selection circuitry for selecting desired ones of said hash output signals for application to said decoder, as a function of the contents of said overlapping segments of address bits.
17. A memory as in claim 16 which further comprises a lookup table to control said selection circuitry, based on said overlapping segments of address bits.
18. A memory as in claim 9 wherein said input vectors include carry in bits and said equality functions further comprise; ##EQU16## where: e00c, e01c represent equality functions corresponding to the low order bit positions,
a0 represents the 0th position bit of said base address bits,
b0 represents the 0th position bit of said offset bits, and
c represents said carry in bits.
US08/282,5251994-07-281994-07-28Low-latency memory indexing method and structureExpired - LifetimeUS5754819A (en)

Priority Applications (4)

Application NumberPriority DateFiling DateTitle
US08/282,525US5754819A (en)1994-07-281994-07-28Low-latency memory indexing method and structure
DE69528615TDE69528615T2 (en)1994-07-281995-07-22 Method and structure for indexing memory with low latency
EP95111551AEP0694845B1 (en)1994-07-281995-07-22Low-latency memory indexing method and structure
JP7211201AJPH0863974A (en)1994-07-281995-07-27Memory in which waiting time is shortened

Applications Claiming Priority (1)

Application NumberPriority DateFiling DateTitle
US08/282,525US5754819A (en)1994-07-281994-07-28Low-latency memory indexing method and structure

Publications (1)

Publication NumberPublication Date
US5754819Atrue US5754819A (en)1998-05-19

Family

ID=23081903

Family Applications (1)

Application NumberTitlePriority DateFiling Date
US08/282,525Expired - LifetimeUS5754819A (en)1994-07-281994-07-28Low-latency memory indexing method and structure

Country Status (4)

CountryLink
US (1)US5754819A (en)
EP (1)EP0694845B1 (en)
JP (1)JPH0863974A (en)
DE (1)DE69528615T2 (en)

Cited By (34)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
WO1999064953A1 (en)*1998-06-081999-12-16Intel CorporationRedundant form address decoder for cache system storing aligned data
US6172933B1 (en)1998-09-042001-01-09Intel CorporationRedundant form address decoder for memory system
US6341327B1 (en)1998-08-132002-01-22Intel CorporationContent addressable memory addressable by redundant form input
US6507531B1 (en)2000-03-292003-01-14Intel CorporationCache column multiplexing using redundant form addresses
US6594739B1 (en)*2001-09-112003-07-15Emc CorporationMemory system and method of using same
US6681313B1 (en)*1999-06-232004-01-20International Business Machines CorporationMethod and system for fast access to a translation lookaside buffer
US6707752B2 (en)2001-06-222004-03-16Intel CorporationTag design for cache access with redundant-form address
US20040064674A1 (en)*2002-09-302004-04-01International Business Machines CorporationApparatus and method for generating memory access signals, and memory accessed using said signals
US6754689B2 (en)1999-12-232004-06-22Intel CorporationMethod and apparatus for performing subtraction in redundant form arithmetic
US6763368B2 (en)1999-12-232004-07-13Intel CorporationMethod and apparatus for performing single-cycle addition or subtraction and comparison in redundant form arithmetic
US6813628B2 (en)1999-12-232004-11-02Intel CorporationMethod and apparatus for performing equality comparison in redundant form arithmetic
US20040221132A1 (en)*2000-12-202004-11-04Kjell TorkelssonEfficient mapping of signal elements to a limited range of identifiers
US6826588B2 (en)1999-12-232004-11-30Intel CorporationMethod and apparatus for a fast comparison in redundant form arithmetic
US20050216705A1 (en)*2000-11-292005-09-29Nec CorporationData dependency detection using history table of entry number hashed from memory address
US20060059310A1 (en)*2004-09-102006-03-16Cavium NetworksLocal scratchpad and data caching system
US7089360B1 (en)*2000-03-222006-08-08Intel CorporationShared cache wordline decoder for redundant and regular addresses
US20070094479A1 (en)*2005-10-252007-04-26Bearden David RSystem and method for memory array access with fast address decoder
US20070201298A1 (en)*2006-02-272007-08-30Freescale Semiconductor, Inc.Bit line precharge in embedded memory
US20070280030A1 (en)*2006-05-232007-12-06Freescale Semiconductor, Inc.Contention-free hierarchical bit line in embedded memory and method thereof
US20080222361A1 (en)*2007-03-092008-09-11Freescale Semiconductor, Inc.Pipelined tag and information array access with speculative retrieval of tag that corresponds to information access
US7558925B2 (en)2004-09-102009-07-07Cavium Networks, Inc.Selective replication of data structures
US7594081B2 (en)2004-09-102009-09-22Cavium Networks, Inc.Direct access to low-latency memory
US20100229043A1 (en)*2006-02-072010-09-09Bratin SahaHardware acceleration for a software transactional memory system
US20110106866A1 (en)*2009-11-052011-05-05Grayson Brian CHash Function for Hardware Implementations
US9021194B2 (en)2011-08-192015-04-28Freescale Semiconductor, Inc.Memory management unit tag memory
US9116799B2 (en)2013-06-302015-08-25Freescale Semiconductor, Inc.Method for detecting bank collision at a memory and device therefor
US9323534B2 (en)2013-03-152016-04-26Freescale Semiconductor, Inc.Method and apparatus for detecting a collision between multiple threads of execution for accessing a memory array
US9367475B2 (en)2012-04-052016-06-14Freescale Semiconductor, Inc.System and method for cache access
US9367437B2 (en)2013-03-152016-06-14Freescale Semiconductor, Inc.Method and apparatus for reducing the number of speculative accesses to a memory array
US20160170884A1 (en)*2014-07-142016-06-16Via Alliance Semiconductor Co., Ltd.Cache system with a primary cache and an overflow cache that use different indexing schemes
US20160259728A1 (en)*2014-10-082016-09-08Via Alliance Semiconductor Co., Ltd.Cache system with a primary cache and an overflow fifo cache
US10997085B2 (en)*2019-06-032021-05-04International Business Machines CorporationCompression for flash translation layer
CN113806251A (en)*2021-11-192021-12-17沐曦集成电路(上海)有限公司System for sharing memory management unit, building method and memory access method
US20230229630A1 (en)*2022-01-192023-07-20Nvidia CorporationProcessing variable-length data

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US5754819A (en)*1994-07-281998-05-19Sun Microsystems, Inc.Low-latency memory indexing method and structure
GB2399199B (en)*2000-04-112004-10-27Cube Ltd PA method and apparatus for wire-speed application layer classification of data packets
AU4870801A (en)*2000-04-112001-10-23P-Cube Ltd.A method and apparatus for wire-speed application layer classification of data packets
JP3817449B2 (en)2001-07-302006-09-06株式会社ルネサステクノロジ Data processing device

Citations (5)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US4215402A (en)*1978-10-231980-07-29International Business Machines CorporationHash index table hash generator apparatus
EP0440908A2 (en)*1990-01-111991-08-14International Business Machines CorporationA technique for generating an address during an instruction decode cycle in a RISC processor
EP0694845A1 (en)*1994-07-281996-01-31Sun Microsystems, Inc.Low-latency memory indexing method and structure
US5515522A (en)*1994-02-241996-05-07Hewlett-Packard CompanyCoherence index generation for use by an input/output adapter located outside of the processor to detect whether the updated version of data resides within the cache
US5530834A (en)*1993-03-301996-06-25International Computers LimitedSet-associative cache memory having an enhanced LRU replacement strategy

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US4215402A (en)*1978-10-231980-07-29International Business Machines CorporationHash index table hash generator apparatus
EP0440908A2 (en)*1990-01-111991-08-14International Business Machines CorporationA technique for generating an address during an instruction decode cycle in a RISC processor
US5530834A (en)*1993-03-301996-06-25International Computers LimitedSet-associative cache memory having an enhanced LRU replacement strategy
US5515522A (en)*1994-02-241996-05-07Hewlett-Packard CompanyCoherence index generation for use by an input/output adapter located outside of the processor to detect whether the updated version of data resides within the cache
EP0694845A1 (en)*1994-07-281996-01-31Sun Microsystems, Inc.Low-latency memory indexing method and structure

Non-Patent Citations (7)

* Cited by examiner, † Cited by third party
Title
"Wired-in Hash Function for Data Cache Address Calculation", IBM TDB, vol. 34. No. 12, May 1992.
Evaluating A B K Conditions in Constant Time, Cortadella et al., IEEE, pp. 243 245.*
Evaluating A+B=K Conditions in Constant Time, Cortadella et al., IEEE, pp. 243-245.
Evaluation of A B K Conditions Without Carry Propagation, Cortadella et al., IEEE Transactions on Computers, vol. 41, No. 11, Nov. 1992.*
Evaluation of A+B=K Conditions Without Carry Propagation, Cortadella et al., IEEE Transactions on Computers, vol. 41, No. 11, Nov. 1992.
Semiconductor Memories, A Handbook of Design, Manufacture and Application, Betty Prince, Second Ed., John Wiley & Sons.*
Wired in Hash Function for Data Cache Address Calculation , IBM TDB, vol. 34. No. 12, May 1992.*

Cited By (54)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
WO1999064953A1 (en)*1998-06-081999-12-16Intel CorporationRedundant form address decoder for cache system storing aligned data
US6341327B1 (en)1998-08-132002-01-22Intel CorporationContent addressable memory addressable by redundant form input
US6172933B1 (en)1998-09-042001-01-09Intel CorporationRedundant form address decoder for memory system
US6681313B1 (en)*1999-06-232004-01-20International Business Machines CorporationMethod and system for fast access to a translation lookaside buffer
US6763368B2 (en)1999-12-232004-07-13Intel CorporationMethod and apparatus for performing single-cycle addition or subtraction and comparison in redundant form arithmetic
US20040267863A1 (en)*1999-12-232004-12-30Bharat BhushanMethod and apparatus for performing single-cycle addition or subtraction and comparison in redundant form arithmetic
US7395304B2 (en)1999-12-232008-07-01Intel CorporationMethod and apparatus for performing single-cycle addition or subtraction and comparison in redundant form arithmetic
US6826588B2 (en)1999-12-232004-11-30Intel CorporationMethod and apparatus for a fast comparison in redundant form arithmetic
US6813628B2 (en)1999-12-232004-11-02Intel CorporationMethod and apparatus for performing equality comparison in redundant form arithmetic
US6754689B2 (en)1999-12-232004-06-22Intel CorporationMethod and apparatus for performing subtraction in redundant form arithmetic
US7089360B1 (en)*2000-03-222006-08-08Intel CorporationShared cache wordline decoder for redundant and regular addresses
US6507531B1 (en)2000-03-292003-01-14Intel CorporationCache column multiplexing using redundant form addresses
US7418583B2 (en)*2000-11-292008-08-26Nec CorporationData dependency detection using history table of entry number hashed from memory address
US20050216705A1 (en)*2000-11-292005-09-29Nec CorporationData dependency detection using history table of entry number hashed from memory address
US20040221132A1 (en)*2000-12-202004-11-04Kjell TorkelssonEfficient mapping of signal elements to a limited range of identifiers
US7197622B2 (en)*2000-12-202007-03-27Telefonaktiebolaget Lm EricssonEfficient mapping of signal elements to a limited range of identifiers
US6707752B2 (en)2001-06-222004-03-16Intel CorporationTag design for cache access with redundant-form address
US6594739B1 (en)*2001-09-112003-07-15Emc CorporationMemory system and method of using same
US6883072B2 (en)*2001-09-112005-04-19Emc CorporationMemory system and method of using same
US20040030848A1 (en)*2001-09-112004-02-12Walton John K.Memory system and method of using same
US6944088B2 (en)2002-09-302005-09-13International Business Machines CorporationApparatus and method for generating memory access signals, and memory accessed using said signals
US20040064674A1 (en)*2002-09-302004-04-01International Business Machines CorporationApparatus and method for generating memory access signals, and memory accessed using said signals
US20060059316A1 (en)*2004-09-102006-03-16Cavium NetworksMethod and apparatus for managing write back cache
US9141548B2 (en)2004-09-102015-09-22Cavium, Inc.Method and apparatus for managing write back cache
US20060059310A1 (en)*2004-09-102006-03-16Cavium NetworksLocal scratchpad and data caching system
US7941585B2 (en)2004-09-102011-05-10Cavium Networks, Inc.Local scratchpad and data caching system
US7558925B2 (en)2004-09-102009-07-07Cavium Networks, Inc.Selective replication of data structures
US7594081B2 (en)2004-09-102009-09-22Cavium Networks, Inc.Direct access to low-latency memory
US20070094479A1 (en)*2005-10-252007-04-26Bearden David RSystem and method for memory array access with fast address decoder
US20070094480A1 (en)*2005-10-252007-04-26Freescale Semiconductor, Inc.System and method for memory array access with fast address decoder
US8943292B2 (en)2005-10-252015-01-27Freescale Semiconductor, Inc.System and method for memory array access with fast address decoder
US7669034B2 (en)2005-10-252010-02-23Freescale Semiconductor, Inc.System and method for memory array access with fast address decoder
US8521965B2 (en)*2006-02-072013-08-27Intel CorporationHardware acceleration for a software transactional memory system
US20100229043A1 (en)*2006-02-072010-09-09Bratin SahaHardware acceleration for a software transactional memory system
US20070201298A1 (en)*2006-02-272007-08-30Freescale Semiconductor, Inc.Bit line precharge in embedded memory
US7286423B2 (en)2006-02-272007-10-23Freescale Semiconductor, Inc.Bit line precharge in embedded memory
US20070280030A1 (en)*2006-05-232007-12-06Freescale Semiconductor, Inc.Contention-free hierarchical bit line in embedded memory and method thereof
US20080222361A1 (en)*2007-03-092008-09-11Freescale Semiconductor, Inc.Pipelined tag and information array access with speculative retrieval of tag that corresponds to information access
US7984229B2 (en)2007-03-092011-07-19Freescale Semiconductor, Inc.Pipelined tag and information array access with speculative retrieval of tag that corresponds to information access
US20110106866A1 (en)*2009-11-052011-05-05Grayson Brian CHash Function for Hardware Implementations
US8359346B2 (en)*2009-11-052013-01-22Freescale Semiconductor, Inc.Hash function for hardware implementations
US9542334B2 (en)2011-08-192017-01-10Nxp Usa, Inc.Memory management unit TAG memory with CAM evaluate signal
US9021194B2 (en)2011-08-192015-04-28Freescale Semiconductor, Inc.Memory management unit tag memory
US9367475B2 (en)2012-04-052016-06-14Freescale Semiconductor, Inc.System and method for cache access
US9323534B2 (en)2013-03-152016-04-26Freescale Semiconductor, Inc.Method and apparatus for detecting a collision between multiple threads of execution for accessing a memory array
US9367437B2 (en)2013-03-152016-06-14Freescale Semiconductor, Inc.Method and apparatus for reducing the number of speculative accesses to a memory array
US9116799B2 (en)2013-06-302015-08-25Freescale Semiconductor, Inc.Method for detecting bank collision at a memory and device therefor
US20160170884A1 (en)*2014-07-142016-06-16Via Alliance Semiconductor Co., Ltd.Cache system with a primary cache and an overflow cache that use different indexing schemes
US11620220B2 (en)*2014-07-142023-04-04Via Alliance Semiconductor Co., Ltd.Cache system with a primary cache and an overflow cache that use different indexing schemes
US20160259728A1 (en)*2014-10-082016-09-08Via Alliance Semiconductor Co., Ltd.Cache system with a primary cache and an overflow fifo cache
US10997085B2 (en)*2019-06-032021-05-04International Business Machines CorporationCompression for flash translation layer
CN113806251A (en)*2021-11-192021-12-17沐曦集成电路(上海)有限公司System for sharing memory management unit, building method and memory access method
CN113806251B (en)*2021-11-192022-02-22沐曦集成电路(上海)有限公司System for sharing memory management unit, building method and memory access method
US20230229630A1 (en)*2022-01-192023-07-20Nvidia CorporationProcessing variable-length data

Also Published As

Publication numberPublication date
JPH0863974A (en)1996-03-08
DE69528615T2 (en)2003-06-18
DE69528615D1 (en)2002-11-28
EP0694845A1 (en)1996-01-31
EP0694845B1 (en)2002-10-23

Similar Documents

PublicationPublication DateTitle
US5754819A (en)Low-latency memory indexing method and structure
US5093778A (en)Integrated single structure branch prediction cache
US6594728B1 (en)Cache memory with dual-way arrays and multiplexed parallel output
US6480938B2 (en)Efficient I-cache structure to support instructions crossing line boundaries
EP0042000B1 (en)Cache memory in which the data block size is variable
US6425055B1 (en)Way-predicting cache memory
US4905141A (en)Partitioned cache memory with partition look-aside table (PLAT) for early partition assignment identification
US6216200B1 (en)Address queue
US5752260A (en)High-speed, multiple-port, interleaved cache with arbitration of multiple access addresses
US5737750A (en)Partitioned single array cache memory having first and second storage regions for storing non-branch and branch instructions
US6266755B1 (en)Translation lookaside buffer with virtual address conflict prevention
EP0508577A1 (en)Address translation mechanism
US5125085A (en)Least recently used replacement level generating apparatus and method
EP0690386A1 (en)Address translator and method of operation
US5479641A (en)Method and apparatus for overlapped timing of cache operations including reading and writing with parity checking
US5530824A (en)Address translation circuit
US5893930A (en)Predictive translation of a data address utilizing sets of associative entries stored consecutively in a translation lookaside buffer
US5713001A (en)Circuit for converting address operands supplied by a program to hashed virtual address
US5539894A (en)Method and apparatus for optimizing a sector cache tag, block and sub-block structure base on main memory size
EP0284751B1 (en)Cache memory
US5535351A (en)Address translator with by-pass circuit and method of operation
US5953747A (en)Apparatus and method for serialized set prediction
US5452418A (en)Method of using stream buffer to perform operation under normal operation mode and selectively switching to test mode to check data integrity during system operation
US5530822A (en)Address translator and method of operation
US5854943A (en)Speed efficient cache output selector circuitry based on tag compare and data organization

Legal Events

DateCodeTitleDescription
ASAssignment

Owner name:SUN MICROSYSTEMS, INC., CALIFORNIA

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LYNCH, WILLIAM L.;LAUTERBACH, GARY R.;REEL/FRAME:007100/0161

Effective date:19940728

ASAssignment

Owner name:SUN MICROSYSTEMS, INC., CALIFORNIA

Free format text:RECORD TO CORRECT STREET NAME FROM "GARCIAN" TO GARCIA;ASSIGNORS:LYNCH, WILLIAM L.;LAUTERBACH, GARY R.;REEL/FRAME:007267/0079

Effective date:19940728

STCFInformation on status: patent grant

Free format text:PATENTED CASE

FPAYFee payment

Year of fee payment:4

FPAYFee payment

Year of fee payment:8

FPAYFee payment

Year of fee payment:12


[8]ページ先頭

©2009-2025 Movatter.jp