Multi-way hash tables and other software cache structures are commonly used for many different computational workloads, including networking workloads, operating systems, and data centers. Certain caching systems use a least recently used (LRU) cache replacement policy, in which the least recently used item is evicted from the cache and replaced with a newer item. However, implementing a true LRU policy may be costly in hardware and/or software overhead. Certain hardware and/or software caches may instead implement a pseudo LRU policy or even a random replacement policy.
The concepts described herein are illustrated by way of example and not by way of limitation in the accompanying figures. For simplicity and clarity of illustration, elements illustrated in the figures are not necessarily drawn to scale. Where considered appropriate, reference labels have been repeated among the figures to indicate corresponding or analogous elements.
While the concepts of the present disclosure are susceptible to various modifications and alternative forms, specific embodiments thereof have been shown by way of example in the drawings and will be described herein in detail. It should be understood, however, that there is no intent to limit the concepts of the present disclosure to the particular forms disclosed, but on the contrary, the intention is to cover all modifications, equivalents, and alternatives consistent with the present disclosure and the appended claims.
References in the specification to “one embodiment,” “an embodiment,” “an illustrative embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may or may not necessarily include that particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to effect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described. Additionally, it should be appreciated that items included in a list in the form of “at least one of A, B, and C” can mean (A); (B); (C); (A and B); (A and C); (B and C); or (A, B, and C). Similarly, items listed in the form of “at least one of A, B, or C” can mean (A); (B); (C); (A and B); (A and C); (B and C); or (A, B, and C).
The disclosed embodiments may be implemented, in some cases, in hardware, firmware, software, or any combination thereof. The disclosed embodiments may also be implemented as instructions carried by or stored on one or more transitory or non-transitory machine-readable (e.g., computer-readable) storage media, which may be read and executed by one or more processors. A machine-readable storage medium may be embodied as any storage device, mechanism, or other physical structure for storing or transmitting information in a form readable by a machine (e.g., a volatile or non-volatile memory, a media disc, or other media device).
In the drawings, some structural or method features may be shown in specific arrangements and/or orderings. However, it should be appreciated that such specific arrangements and/or orderings may not be required. Rather, in some embodiments, such features may be arranged in a different manner and/or order than shown in the illustrative figures. Additionally, the inclusion of a structural or method feature in a particular figure is not meant to imply that such feature is required in all embodiments and, in some embodiments, may not be included or may be combined with other features.
Referring now to
Referring now to
Referring back to
The processor 120 may be embodied as any type of processor capable of performing the functions described herein. The processor 120 may be embodied as a single or multi-core processor(s), digital signal processor, microcontroller, or other processor or processing/controlling circuit. As described above, the processor 120 includes vector instruction support 122, which may be embodied as execution resources, instruction set support, and other hardware, firmware, and/or microcode resources for single-instruction multiple data (SIMD) operations. In particular, the vector instruction support 122 may include one or more processor instructions to perform permutation of multiple data items within a vector register or other data location. The vector instruction support 122 is illustratively embodied as Intel AVX2. In other embodiments, the vector instruction support 122 may be embodied as the NEON implementation of the Advanced SIMD extension for various ARM processor architectures provided by Arm Limited.
The memory 126 may be embodied as any type of volatile or non-volatile memory or data storage capable of performing the functions described herein. In operation, the memory 126 may store various data and software used during operation of the computing device 100, such as operating systems, applications, programs, libraries, and drivers. The memory 126 is communicatively coupled to the processor 120 via the I/O subsystem 124, which may be embodied as circuitry and/or components to facilitate input/output operations with the processor 120, the memory 126, and other components of the computing device 100. For example, the I/O subsystem 124 may be embodied as, or otherwise include, memory controller hubs, input/output control hubs, platform controller hubs, integrated control circuitry, firmware devices, communication links (e.g., point-to-point links, bus links, wires, cables, light guides, printed circuit board traces, etc.) and/or other components and subsystems to facilitate the input/output operations. In some embodiments, the I/O subsystem 124 may form a portion of a system-on-a-chip (SoC) and be incorporated, along with the processor 120, the memory 126, and other components of the computing device 100, on a single integrated circuit chip.
The data storage device 128 may be embodied as any type of device or devices configured for short-term or long-term storage of data such as, for example, memory devices and circuits, memory cards, hard disk drives, solid-state drives, or other data storage devices. The communication subsystem 130 of the computing device 100 may be embodied as any network interface controller or other communication circuit, device, or collection thereof, capable of enabling communications between the computing device 100 and other remote devices over a network. The communication subsystem 130 may be configured to use any one or more communication technology (e.g., wired or wireless communications) and associated protocols (e.g., Ethernet, InfiniBand®, Bluetooth®, Wi-Fi®, WiMAX, etc.) to effect such communication.
As shown, the computing device 100 may also include one or more peripheral devices 132. The peripheral devices 132 may include any number of additional input/output devices, interface devices, and/or other peripheral devices. For example, in some embodiments, the peripheral devices 132 may include a display, touch screen, graphics circuitry, keyboard, mouse, speaker system, microphone, network interface, and/or other input/output devices, interface devices, and/or peripheral devices.
Referring now to
The associative cache manager 206 is configured to generate a hash value as a function of a data item and retrieve an associative cache bucket 210 of an associative cache from the memory 126 as a function of the hash value. Each bucket 210 includes multiple entries arranged in an order from front to back. Each entry is sized to store a data item. In some embodiments, the bucket 210 may be embodied as a 256-bit array of eight entries, which each entry embodied as a 32-bit value. In some embodiments, retrieving the bucket 210 as a function of the hash value includes indexing a hash table in the memory 126 with the hash value. The associative cache manager 206 is further configured to store the bucket 210 in the memory 126 in response to moving an entry of the bucket 210 to the front of the bucket 210, as described further below. Additionally or alternatively, although illustrated as including a single associative cache, it should be understood that the techniques disclosed herein may be used in any level or levels of a multi-level cache hierarchy.
The lookup manager 202 is configured to identify a matching entry that includes a data item at a particular position within the bucket 210. The lookup manager 202 may be further configured to return a data value 214 associated with the matching item in response to identifying the matching entry of the bucket 210. In some embodiments, the data item may include a key for an external data item 214. In some embodiments, the data item may include a signature of an external key 216 of an external data item 214 and a signature mapping index, and returning the data item may include retrieving the external key 216 from the memory 126 using the signature mapping index.
The insert manager 204 is configured to store an inserted item at an entry of the bucket 210 located at the back of the bucket 210. In some embodiments, the entries of the bucket 210 may be partitioned into multiple regions, and the inserted item may be stored at an entry located at the back of a particular region of the bucket 210 associated with the inserted item. The insert manager 204 may be further configured to determine the region associated with the inserted item as a function of a priority level associated with the inserted item. As described above, in some embodiments, the inserted item may include a key for an external data item 214. In some embodiments, the inserted item may include a signature of an external key 216 and a signature mapping index.
The vector manager 208 is configured to execute a vector permutation processor instruction in response to identifying the matching entry and/or storing the inserted item. The vector permutation processor instruction may include an AVX2 instruction. The vector manager 208 is further configured to move, by the processor 120 (e.g., using the vector instruction support 122), the matching entry and/or the inserted entry of the bucket 210 to the front of the bucket 210 in response executing the vector permutation processor instruction. Moving the matching entry and/or the inserted entry includes preserving the order of other entries of the bucket 210. The vector permutation processor instruction may be executed with the bucket 210 and a predetermined permutation pattern 212. The vector manager 208 may be further configured to select the predetermined permutation pattern 212 from a plurality of predetermined permutation patterns 212 as a function of the position of the matching item and/or the inserted item in the bucket 210. In some embodiments, the entries of the bucket 210 may be partitioned into multiple regions, and the matching entry and/or the inserted entry may be moved to the front of a region of the bucket 210 that includes the matching entry and/or the inserted entry.
Referring now to
In block 308, the computing device 100 searches the cache for an item matching the item (e.g., the key or the signature of the key) that is being looked up. The computing device 100 may use any appropriate search technique. In block 310, the computing device 100 may generate a hash for the item. The hash may be generated using any appropriate hash function.
For example, the hash may be generated using a cryptographic hash function. As another example, the hash may be generated by extracting certain most-significant bits from the data item or its associated key (similar to selecting a cache line in a hardware cache). In block 312, the computing device 100 retrieves a bucket 210 for the hash value from the cache. For example, the computing device 100 may index a hash table or other in-memory data structure with the hash value and load the bucket 210 from that location. The bucket 210 may be embodied as an array, vector register, or other data structure that includes entries for multiple data items. The entries are arranged from front (e.g., index 0 of an array) to back (e.g., index n-1 of an n-element array). In some embodiments, the bucket 210 may be embodied as a 256-bit array that includes eight 32-bit entries. In block 314, the computing device 100 searches the bucket 210 for a matching item. For example, the computing device 100 may sequentially search each entry of the bucket 210 and determine whether that entry matches the item being looked up. As another example, the computing device 100 may search the bucket 210 in parallel using one or more SIMD instructions. If a matching item is found, the computing device 100 determines the location of the matching entry within the bucket 210, for example, the index of the matching 32-bit entry within a 256-bit array of eight 32-bit entries.
In block 316, the computing device 100 determines whether a match for the item was found in the cache. If not, the method 300 loops back to block 302, in which the computing device 100 may perform additional lookups. The computing device 100 may indicate that no match was found, for example by returning a null value or other indicator. If a matching item was found, the method 300 advances to block 318.
In some embodiments, in block 318, the computing device 100 may check an external key 216 using a signature mapping index of the matching item. As described above, in some embodiments the item that is looked up may be embodied as a signature of a larger key 216 that is stored externally from the cache. For example, the data item may be a 28-bit or 29-bit signature of an eight-byte pointer, a network packet header, or other external key 216. In those embodiments, part of each data item in the bucket 210 (e.g., three bits, two bits, or another part) is a signature mapping index. The signature mapping index may be used to identify the particular external key 216 that is associated with an entry in the bucket 210. The signature mapping index is permuted with the other parts of the item and thus may be used to track the external key 216 even when the data item has moved to a different position in the bucket 210. After locating the external key 216, the computing device 100 checks that the external key 216 matches the original lookup. If the external key 216 does not match (for example, due to a hash collision while generating the signature of the key 216), the computing device 100 may indicate that no match was found, for example by returning a null value or other indicator. If the external key 216 matches (or if no external keys 216 are in use), the method 300 advances to block 320.
In block 320, the computing device 100 permutes the bucket 210 using one or more vector instructions to move matching item to the front of the bucket 210. The relative order of the other items in the bucket 210 is preserved. The computing device 100 uses the vector instruction support 122 of the processor 120 to permute the bucket 210, which may provide improved performance and/or power efficiency. In block 322, the computing device 100 may select a permutation pattern 212 based on the entry position of the matching item. The selected permutation pattern 212 indicates that the entry containing the matching item is moved to the front of the bucket 210 and the relative order of the other entries is unchanged. The permutation pattern 212 may be selected from multiple, predetermined permutation patterns 212. For example, if the bucket 210 includes eight 32-bit entries, the permutation pattern 212 may be selected by indexing a predetermined array of eight patterns with the index of the matching item. Table 1, below, illustrates one potential embodiment of an array of predetermined permutation patterns that may be used for a bucket 210 with eight entries, indexed from one.
In some embodiments, in block 324 the bucket 210 may be partitioned into multiple regions, and the computing device 100 may permute only the region including the matching item. In those embodiments, the matching item may be moved to the front of the region, which may not be the front of the bucket 210. Partitioning the bucket 210 may be useful, for example, to reduce interference between multiple network flows. For example, a partitioned bucket 210 may be used to provide guaranteed quality-of-service (QoS) for certain traffic classes (e.g., VoIP traffic, gaming traffic, etc.) or other network flows.
In block 326, the computing device 100 causes the processor 120 to execute a vector instruction with the permutation pattern 212. The processor 120 moves the entry of the matching item to the front of the bucket 210 (and/or the front of a particular region of the bucket 210) while preserving the relative order of the other entries of the bucket 210. As described above, the vector instruction may be embodied as an AVX2 permutation instruction.
After permuting the bucket 210, in block 328 the computing device 100 stores the permuted bucket 210 back to the cache in the memory 126. Thus, after being stored, the matching item (e.g., the matching key or matching signature of the key) has been moved to the front of the bucket 210 (or region of the bucket 210) and the other items have been moved closer to the back of the bucket 210, with their relative ordering preserved. Thus, as described further below, the cache may support a least recently used (LRU) replacement policy.
In block 330, the computing device 100 returns a data value 214 associated with the matching item from the cache. As described above, the computing device 100 may return a cached network flow, which may be used for data plane processing. For example, the cached network flow may be associated with an action such as forward, drop, encapsulate, de-encapsulate, or other data plane processing action. As another example, the computing device 100 may return a cached web resource, file, or other data object. After returning the item, the method 300 loops back to block 302 to perform additional lookups.
Referring now to
In block 408, the computing device 100 finds a bucket 210 in the associative cache in which to store the inserted data item (e.g., the inserted key or signature of the key). The computing device 100 may use any appropriate search or hashing algorithm to find the bucket 210. In block 410, the computing device 100 may generate a hash for the inserted item. The hash may be generated using any appropriate hashing algorithm. For example, as described above, the hash may be generated using a cryptographic hash algorithm As another example, the hash may be generated by extracting certain most-significant bits from the data item or its associated key (similar to selecting a cache line in a hardware cache). In block 412, the computing device 100 retrieves a bucket 210 for the hash value from the cache. For example, the computing device 100 may index a hash table or other in-memory data structure with the hash value and load the bucket 210 from that location. As described above, the bucket 210 may be embodied as an array or other data structure that includes entries for multiple data items. The entries are arranged from front (e.g., index 0 of an array) to back (e.g., index n-1 of an n-element array). In some embodiments, the bucket 210 may be embodied as a 256-bit array that includes eight 32-bit entries.
In block 414, the computing device 100 replaces the entry at the back of the bucket 210 with the inserted item (e.g., the inserted key or signature of the key). For example, the computing device 100 may write the inserted item to the index n-1 of an n-element array. As described above in connection with
In some embodiments, in block 418, the computing device 100 may update an external data storage 214 and/or external key storage 216 based on in the inserted item. For example, the computing device 100 may update the external data storage 214 with the data value associated with the inserted item, such as the cached network flow, cached web resource, file, or other object. As another example, when the signature of a key has been inserted at the back of the bucket 210, the computing device 100 may update the external key storage 216 with the key 216 associated with that signature. The computing device 100 may ensure that the key mapping index stored in the bucket 210 is associated with the correct external key 216.
In block 420, the computing device permutes the bucket 210 using one or more vector instructions to move matching item to the front of the bucket 210. The relative order of the other items in the bucket 210 is preserved. The computing device 100 uses the vector instruction support 122 of the processor 120 to permute the bucket 210, which may provide improved performance and/or power efficiency. In block 422, the computing device 100 may select a permutation pattern 212. The permutation pattern 212 may be a predetermined pattern that moves the entry at the back of the bucket 210 to the front of the bucket 210 and preserves the order of the other entries. For example, for a bucket 210 with eight entries, the permutation pattern 212 may be a vector with values {8, 1, 2, 3, 4, 5, 6, 7}. In some embodiments, in block 424 the bucket 210 may be partitioned into multiple regions, and the computing device 100 may permute only the region associated with the inserted item. In those embodiments, the inserted item may be moved to the front of the associated region, and not the front of the bucket 210. As described above, the region may be selected based on a priority of the inserted item. For example, a high-priority traffic flow (e.g., VoIP traffic, gaming traffic, etc.) may be associated with the entire bucket 210 and thus moved to the front of the bucket 210, while a lower-priority traffic flow (e.g., large file data transfer) may be associated with a region of the bucket 210 and moved to the front of that region (and not the front of the bucket 210).
In block 426, the computing device 100 causes the processor 120 to execute a vector instruction with the permutation pattern 212. The processor 120 moves the entry of the matching item to the front of the bucket 210 (and/or the front of a particular region of the bucket 210) while preserving the relative order of the other entries of the bucket 210. As described above, the vector instruction may be embodied as an AVX2 permutation instruction.
After permuting the bucket 210, in block 428 the computing device 100 stores the permuted bucket 210 back to the cache in the memory 126. Thus, after being stored, the inserted item has been moved to the front of the bucket 210 (or region of the bucket 210) and the other items have been moved closer to the back of the bucket 210, with their relative ordering preserved. As described above in connection with
Referring now to
Referring now to
Referring now to
Referring now to
Referring now to
Referring now to
It should be appreciated that, in some embodiments, the methods 300 and/or 400 may be embodied as various instructions stored on a computer-readable media, which may be executed by the processor 120, the I/O subsystem 124, and/or other components of the computing device 100 to cause the computing device 100 to perform the respective method 300 and/or 400. The computer-readable media may be embodied as any type of media capable of being read by the computing device 100 including, but not limited to, the memory 126, the data storage device 128, firmware devices, and/or other media.
Illustrative examples of the technologies disclosed herein are provided below. An embodiment of the technologies may include any one or more, and any combination of, the examples described below.
Example 1 includes a computing device for least recently used cache replacement, the computing device comprising: a processor; a memory; an associative cache manager to (i) generate a hash value as a function of a first item and (ii) retrieve a bucket of an associative cache from the memory as a function of the hash value, wherein the bucket includes a plurality of entries arranged in an order from a front to a back, and wherein each entry is sized to store an item; a lookup manager to identify a first entry of the bucket that includes the first item, wherein the first entry is at a position in the bucket; and a vector manager to (i) execute a vector permutation processor instruction in response to identification of the first entry, and (ii) move, by the processor, the first entry of the bucket to the front of the bucket in response to execution of the vector permutation processor instruction, wherein to move the first entry comprises to preserve the order of other entries of the bucket; wherein the associative cache manager is further to store the bucket in the memory of the computing device in response to movement of the first entry of the bucket to the front of the bucket.
Example 2 includes the subject matter of Example 1, and wherein: the bucket comprises a 256-bit array of eight entries, wherein each entry comprises a 32-bit value; and the vector permutation processor instruction comprises an AVX2 instruction.
Example 3 includes the subject matter of any of Examples 1 and 2, and wherein to execute the vector permutation processor instruction comprises to execute the vector permutation processor instruction with the bucket and a predetermined permutation pattern.
Example 4 includes the subject matter of any of Examples 1-3, and wherein the vector manager is further to select the predetermined permutation pattern from a plurality of predetermined permutation patterns as a function of the position of the first item in the bucket.
Example 5 includes the subject matter of any of Examples 1-4, and wherein: the entries of the bucket are partitioned into a plurality of regions; and to move the first entry of the bucket to the front of the bucket comprises to move the first entry to a front of a first region of the bucket, wherein the first region includes the first entry.
Example 6 includes the subject matter of any of Examples 1-5, and wherein the lookup manager is further to return a first data value associated with the first item in response to identification of the first entry of the bucket.
Example 7 includes the subject matter of any of Examples 1-6, and wherein: the first item comprises a signature of an external key and a signature mapping index; the first data value is associated with the external key; and to return the first data value comprises to retrieve the external key from the memory with the signature mapping index of the first item and to return the first data value.
Example 8 includes the subject matter of any of Examples 1-7, and wherein to retrieve the bucket of the associative cache from the memory as a function of the hash value comprises to index a hash table with the hash value.
Example 9 includes a method for least recently used cache replacement, the method comprising: generating, by a computing device a hash value as a function of a first item; retrieving, by the computing device, a bucket of an associative cache from a memory of the computing device as a function of the hash value, wherein the bucket includes a plurality of entries, and wherein each entry is sized to store an item; identifying, by the computing device, a first entry of the bucket that includes the first item, wherein the first entry is at a position in the bucket; executing, by the computing device, a vector permutation processor instruction in response to identifying the first entry; move, by a processor of the computing device, the first entry of the bucket to the front of the bucket in response to executing the vector permutation processor instruction, wherein moving the first entry comprises preserving an order of other entries of the bucket; and storing, by the computing device, the bucket in the memory of the computing device in response to moving the first entry of the bucket to the front of the bucket.
Example 10 includes the subject matter of Example 9, and wherein: the bucket comprises a 256-bit array of eight entries, wherein each entry comprises a 32-bit value; and the vector permutation processor instruction comprises an AVX2 instruction.
Example 11 includes the subject matter of any of Examples 9 and 10, and wherein executing the vector permutation processor instruction comprises executing the vector permutation processor instruction with the bucket and a predetermined permutation pattern.
Example 12 includes the subject matter of any of Examples 9-11, and further comprising selecting, by the computing device, the predetermined permutation pattern from a plurality of predetermined permutation patterns as a function of the position of the first item in the bucket.
Example 13 includes the subject matter of any of Examples 9-12, and wherein: the entries of the bucket are partitioned into a plurality of regions; and moving the first entry of the bucket to the front of the bucket comprises moving the first entry to a front of a first region of the bucket, wherein the first region includes the first entry.
Example 14 includes the subject matter of any of Examples 9-13, and further comprising returning, by the computing device, a first data value associated with the first item in response to identifying the first entry of the bucket.
Example 15 includes the subject matter of any of Examples 9-14, and wherein: the first item comprises a signature of an external key and a signature mapping index; the first data value is associated with the external key; and returning the first data value comprises retrieving the external key from the memory with the signature mapping index of the first item and returning the first data value.
Example 16 includes the subject matter of any of Examples 9-15, and wherein retrieving the bucket of the associative cache from the memory as a function of the hash value comprises indexing a hash table with the hash value.
Example 17 includes one or more computer-readable storage media comprising a plurality of instructions stored thereon that, in response to being executed, cause a computing device to: generate a hash value as a function of a first item; retrieve a bucket of an associative cache from a memory of the computing device as a function of the hash value, wherein the bucket includes a plurality of entries, and wherein each entry is sized to store an item; identify a first entry of the bucket that includes the first item, wherein the first entry is at a position in the bucket; execute a vector permutation processor instruction in response to identifying the first entry; move, by a processor of the computing device, the first entry of the bucket to the front of the bucket in response to executing the vector permutation processor instruction, wherein to move the first entry comprises to preserve an order of other entries of the bucket; and store the bucket in the memory of the computing device in response to moving the first entry of the bucket to the front of the bucket.
Example 18 includes the subject matter of Example 17, and wherein: the bucket comprises a 256-bit array of eight entries, wherein each entry comprises a 32-bit value; and the vector permutation processor instruction comprises an AVX2 instruction.
Example 19 includes the subject matter of any of Examples 17 and 18, and wherein to execute the vector permutation processor instruction comprises to execute the vector permutation processor instruction with the bucket and a predetermined permutation pattern.
Example 20 includes the subject matter of any of Examples 17-19, and further comprising a plurality of instructions stored thereon that, in response to being executed, cause the computing device to select the predetermined permutation pattern from a plurality of predetermined permutation patterns as a function of the position of the first item in the bucket.
Example 21 includes the subject matter of any of Examples 17-20, and wherein: the entries of the bucket are partitioned into a plurality of regions; and to move the first entry of the bucket to the front of the bucket comprises to move the first entry to a front of a first region of the bucket, wherein the first region includes the first entry.
Example 22 includes the subject matter of any of Examples 17-21, and further comprising a plurality of instructions stored thereon that, in response to being executed, cause the computing device to return a first data value associated with the first item in response to identifying the first entry of the bucket.
Example 23 includes the subject matter of any of Examples 17-22, and wherein: the first item comprises a signature of an external key and a signature mapping index; the first data value is associated with the external key; and to return the first data value comprises to retrieve the external key from the memory with the signature mapping index of the first item and to return the first data value.
Example 24 includes the subject matter of any of Examples 17-23, and wherein to retrieve the bucket of the associative cache from the memory as a function of the hash value comprises to index a hash table with the hash value.
Example 25 includes a computing device for least recently used cache replacement, the computing device comprising: a processor; a memory; an associative cache manager to (i) generate a hash value as a function of a first item and (ii) retrieve a bucket of an associative cache from the memory as a function of the hash value, wherein the bucket includes a plurality of entries arranged in an order from a front to a back, and wherein each entry is sized to store an item; an insert manager to store the first item at a first entry of the bucket, wherein the first entry is at the back of the bucket; and a vector manager to (i) execute a vector permutation processor instruction in response to storage of the first item and (ii) move, by the processor, the first entry of the bucket to the front of the bucket in response to execution of the vector permutation processor instruction, wherein to move the first entry comprises to preserve the order of other entries of the bucket; and wherein the associative cache manager is further to store the bucket in the memory of the computing device in response to movement of the first entry of the bucket to the front of the bucket.
Example 26 includes the subject matter of Example 25, and wherein: the bucket comprises a 256-bit array of eight entries, wherein each entry comprises a 32-bit value; and the vector permutation processor instruction comprises an AVX2 instruction.
Example 27 includes the subject matter of any of Examples 25 and 26, and wherein to execute the vector permutation processor instruction comprises to execute the vector permutation processor instruction with the bucket and a predetermined permutation pattern.
Example 28 includes the subject matter of any of Examples 25-27, and wherein: the entries of the bucket are partitioned into a plurality of regions; and to move the first entry of the bucket to the front of the bucket comprises to move the first entry to a front of a first region associated with the first item.
Example 29 includes the subject matter of any of Examples 25-28, and wherein to store the first item at the first entry of the bucket comprises to store the first item at the first entry, wherein the first entry is at a back of the first region of the bucket.
Example 30 includes the subject matter of any of Examples 25-29, and wherein the insert manager is further to determine the first region associated with the first item as a function of a priority level associated with the first item.
Example 31 includes the subject matter of any of Examples 25-30, and wherein the first item comprises a signature of an external key and a signature mapping index.
Example 32 includes the subject matter of any of Examples 25-31, and wherein to retrieve the bucket of the associative cache from the memory as a function of the hash value comprises to index a hash table with the hash value.
Example 33 includes a method for least recently used cache replacement, the method comprising: generating, by a computing device, a hash value as a function of a first item; retrieving, by the computing device, a bucket of an associative cache from a memory of the computing device as a function of the hash value, wherein the bucket includes a plurality of entries arranged in an order from a front to a back, and wherein each entry is sized to store an item; storing, by the computing device, the first item at a first entry of the bucket, wherein the first entry is at the back of the bucket; executing, by the computing device, a vector permutation processor instruction in response to storing the first item; moving, by a processor of the computing device, the first entry of the bucket to the front of the bucket in response to executing the vector permutation processor instruction, wherein to move the first entry comprises to preserve the order of other entries of the bucket; and storing, by the computing device, the bucket in the memory of the computing device in response to moving the first entry of the bucket to the front of the bucket.
Example 34 includes the subject matter of Example 33, and wherein: the bucket comprises a 256-bit array of eight entries, wherein each entry comprises a 32-bit value; and the vector permutation processor instruction comprises an AVX2 instruction.
Example 35 includes the subject matter of any of Examples 33 and 34, and wherein executing the vector permutation processor instruction comprises executing the vector permutation processor instruction with the bucket and a predetermined permutation pattern.
Example 36 includes the subject matter of any of Examples 33-35, and wherein: the entries of the bucket are partitioned into a plurality of regions; and moving the first entry of the bucket to the front of the bucket comprises moving the first entry to a front of a first region associated with the first item.
Example 37 includes the subject matter of any of Examples 33-36, and wherein storing the first item at the first entry of the bucket comprises storing the first item at the first entry, wherein the first entry is at a back of the first region of the bucket.
Example 38 includes the subject matter of any of Examples 33-37, and further comprising determining, by the computing device, the first region associated with the first item as a function of a priority level associated with the first item.
Example 39 includes the subject matter of any of Examples 33-38, and wherein the first item comprises a signature of an external key and a signature mapping index.
Example 40 includes the subject matter of any of Examples 33-39, and wherein retrieving the bucket of the associative cache from the memory as a function of the hash value comprises indexing a hash table with the hash value.
Example 41 includes one or more computer-readable storage media comprising a plurality of instructions stored thereon that, in response to being executed, cause a computing device to: generate a hash value as a function of a first item; retrieve a bucket of an associative cache from a memory of the computing device as a function of the hash value, wherein the bucket includes a plurality of entries arranged in an order from a front to a back, and wherein each entry is sized to store an item; store the first item at a first entry of the bucket, wherein the first entry is at the back of the bucket; execute a vector permutation processor instruction in response to storing the first item; move, by a processor of the computing device, the first entry of the bucket to the front of the bucket in response to executing the vector permutation processor instruction, wherein to move the first entry comprises to preserve the order of other entries of the bucket; and store, by the computing device, the bucket in the memory of the computing device in response to moving the first entry of the bucket to the front of the bucket.
Example 42 includes the subject matter of Example 41, and wherein: the bucket comprises a 256-bit array of eight entries, wherein each entry comprises a 32-bit value; and the vector permutation processor instruction comprises an AVX2 instruction.
Example 43 includes the subject matter of any of Examples 41 and 42, wherein to execute the vector permutation processor instruction comprises to execute the vector permutation processor instruction with the bucket and a predetermined permutation pattern.
Example 44 includes the subject matter of any of Examples 41-43, and wherein: the entries of the bucket are partitioned into a plurality of regions; and to move the first entry of the bucket to the front of the bucket comprises to move the first entry to a front of a first region associated with the first item.
Example 45 includes the subject matter of any of Examples 41-44, and wherein to store the first item at the first entry of the bucket comprises to store the first item at the first entry, wherein the first entry is at a back of the first region of the bucket.
Example 46 includes the subject matter of any of Examples 41-45, and further comprising a plurality of instructions stored thereon that, in response to being executed, cause the computing device to determine the first region associated with the first item as a function of a priority level associated with the first item.
Example 47 includes the subject matter of any of Examples 41-46, and wherein the first item comprises a signature of an external key and a signature mapping index.
Example 48 includes the subject matter of any of Examples 41-47, and wherein to retrieve the bucket of the associative cache from the memory as a function of the hash value comprises to index a hash table with the hash value.