[go: up one dir, main page]
More Web Proxy on the site http://driver.im/ skip to main content
research-article
Open access

Asynchronous Memory Access Unit: Exploiting Massive Parallelism for Far Memory Access

Published: 14 September 2024 Publication History

Abstract

The growing memory demands of modern applications have driven the adoption of far memory technologies in data centers to provide cost-effective, high-capacity memory solutions. However, far memory presents new performance challenges because its access latencies are significantly longer and more variable than local DRAM. For applications to achieve acceptable performance on far memory, a high degree of memory-level parallelism (MLP) is needed to tolerate the long access latency.
While modern out-of-order processors are capable of exploiting a certain degree of MLP, they are constrained by resource limitations and hardware complexity. The key obstacle is the synchronous memory access semantics of traditional load/store instructions, which occupy critical hardware resources for a long time. The longer far memory latencies exacerbate this limitation.
This article proposes a set of Asynchronous Memory Access Instructions (AMI) and its supporting function unit, Asynchronous Memory Access Unit (AMU), inside contemporary Out-of-Order Core. AMI separates memory request issuing from response handling to reduce resource occupation. Additionally, AMU architecture supports up to several hundreds of asynchronous memory requests through re-purposing a portion of L2 Cache as scratchpad memory (SPM) to provide sufficient temporal storage. Together with a coroutine-based programming framework, this scheme can achieve significantly higher MLP for hiding far memory latencies.
Evaluation with a cycle-accurate simulation shows AMI achieves 2.42× speedup on average for memory-bound benchmarks with 1μs additional far memory latency. Over 130 outstanding requests are supported with 26.86× speedup for GUPS (random access) with 5 μs latency. These demonstrate how the techniques tackle far memory performance impacts through explicit MLP expression and latency adaptation.

1 Introduction

In recent years, the demand for memory has grown rapidly due to the prevalence of big data applications, such as in-memory databases and graph processing [36]. However, the slowdown of DRAM device scaling [38] has constrained the capacity of local memory. As a result, various far memory techniques such as CXL-based memory expansion, disaggregated memory, and Non-Volatile Main Memory (NVMM) have emerged to help address the rising demand for larger and cost-effective memory capacities. In this article, far memory refers to all alternative memory technologies that provide higher capacity while maintaining standard direct load/store access semantics used by applications. This allows memory-hungry workloads to extend the size of the working set easily.
While providing high capacity at low cost, far memory also introduces latencies that are significantly longer and more variable than local DRAM. In a system with heterogeneous far memory devices (Figure 1), the latencies may range from 200 ns to over 5μs. It will bring considerable challenges to performance optimization, as applications and modern processors have been highly optimized based on the assumption of DRAM latency.
Fig. 1.
Fig. 1. Far memory in emerging data center servers.
Traditional techniques for tolerating latency include caching, bulk data transfer, and memory access overlapping. Due to the poor temporal and spatial locality of many big data workloads, the first two methods are inadequate normally. On the other hand, big data programs often exhibit a large number of independent memory operations. Therefore, by overlapping more memory requests, achieving a high degree of memory-level parallelism (MLP) is the primary solution to effectively hide the latency of far memory.
Some domain-specific accelerators or many-core processors are capable of exploiting high MLP by providing a large number of lightweight hardware threads. However, these solutions are typically designed for specific applications and unsuitable for workloads with complex control flow. Meanwhile, general-purpose out-of-order (OoO) processors remain the mainstream in data centers due to their balanced cost and performance. With far memory adoption on the rise, the achievable MLP of OoO processors takes on increasing importance for overall performance.
However, the MLP that modern OoO processors can achieve is limited by their restricted instruction window, which is insufficient to hide the latency of far memory. OoO cores use complex hardware structures and logic like the reorder buffer (ROB), load/store queue (LSQ), and miss status holding registers (MSHRs) to extract potential MLP and track outstanding memory requests. Hence, instruction windows are highly constrained by hardware. Meanwhile, cache-missed memory operations can hold certain hardware resources for a long time, easily leading to resource exhaustion and pipeline stall.
The even longer latencies of far memory exacerbate this issue. Memory-bound workloads operating on far memory experience significant performance degradation compared to utilizing local DRAM. As Figure 2 shows, typical memory-bound workloads experience 3-4x slowdowns when far memory latency increases to 1 μs, which is state-of-the-art network latency [1].
Fig. 2.
Fig. 2. Benchmark slowdown under different far memory latencies. The Y-axis shows the normalized performance slowdown relative to the performance under 100 ns far memory access latency.
While increasing hardware resources such as the ROB and MSHRs can improve MLP, the scalability of these resources is limited by their complex hardware logic [9]. Over the past few decades, extensive efforts have been made to overcome these scalability issues [11, 44, 51, 61, 64]. However, the instruction windows of current state-of-the-art commercial processors are still limited to the order of several hundred. Achieving sufficient MLP for hiding the far memory latency still requires several times of that scale. Thus, focusing solely on increasing hardware resources is inadequate.
The key factor contributing to this problem is that the synchronous semantics of load/store instructions cause them to occupy critical hardware resources for a longer time when facing long latencies. This prevents other independent memory operations in programs from being issued, restricting the MLP that can be achieved.
Addressing this challenge requires asynchronous memory access techniques that separate memory request issuing from memory response. Instructions that invoke an asynchronous memory request can be retired right after issuing the request, leading to the immediate release of associated hardware resources rather than occupying resources for a full access period, as with traditional synchronous load/store instructions.
Prefetching and external memory access engines are two typical asynchronous mechanisms in modern processors. However, existing asynchronous memory access techniques still have limitations for far memory scenarios. While prefetching enables asynchronous memory request invoking, it lacks support for tracking request completion and managing returned data. This limits its effectiveness for complex scenarios with highly varying far memory latencies. Meanwhile, offloading to external memory engines incurs high startup and notification overhead, hindering its applicability to fine-grained and irregular memory accesses common in big data applications such as graph computing and in-memory databases. In a word, there lacks a better asynchronous mechanism inside OoO core to achieve high MLP when facing the issues of long and variable far memory latencies.
This article proposes a set of novel Asynchronous Memory Access Instructions (AMI) and an Asynchronous Memory Access Unit (AMU) inside a modern OoO CPU core. The AMI provides mechanisms for initiating asynchronous memory accesses and notifying completion, aiming to reduce critical resource occupancy during accesses and achieve full software management flexibility. The AMU provides efficient support for the AMI as well as management for massive outstanding requests in a cost-efficient manner.
The AMU achieves low-cost hardware resources and efficient execution of AMI through its tight integration within the processor core. It dynamically reserves a portion of the L2 cache as Scratchpad Memory (SPM). The SPM serves two critical functions. First, it provides program-managed data storage to address the register pressure issues. Second, the SPM offers sufficient state storage to track outstanding requests without costly content-addressable memory (CAM)-based queues.
AMI introduces aload and astore instructions for invoking asynchronous memory access requests and getfin for polling asynchronous responses. All instructions of AMI do not hold any general registers to avoid pipeline stalls. In fact, AMIs only move data between SPM and far memory, leaving the normal synchronous load and store to move data between registers and SPM.
While using L2-SPM instead of various registers enables scaling up easily, it introduces three new performance issues that must be solved: The first is that metadata access latency increases from register level to L2 level. The second is that when pipeline roll-back occurs due to failed speculation, state consistency in L2-SPM must also be maintained. The third is how to support memory disambiguation for massive outstanding memory operations without CAM-based hardware support. In this article, we also present our corresponding solutions as metadata caching, AMU speculation, and software disambiguation.
To address the programming complexity introduced by AMI, we also develop a coroutine-based framework implemented in C++. This framework abstracts away the low-level details of instruction scheduling and SPM management, providing a simplified programming model.
Overall, we present a hardware-software cooperative solution to achieve high MLP for OoO cores, allowing for efficient utilization of unlimited far memory resources. Our contribution can be concluded as follows:1
A set of novel AMI that models memory requests and responses as separate instructions. This reduces critical resource occupation and exposes more opportunities for software to exploit MLP.
A novel AMU architecture that efficiently executes AMI. AMU repurposes cache as metadata storage and program-managed data storage to support massive outstanding AMI requests.
An optimized micro-architecture design for AMU, including metadata caching and AMU speculation mechanism, and so on.
An efficient and software-only memory disambiguation mechanism to substitute the non-scalable CAM hardware.
A coroutine-based C++ framework to address programming complexity from AMI. The framework encapsulates low-level scheduling and SPM management.
A cycle-accurate model of AMU is built based on the Gem5 simulator. The evaluation results show that for memory-bound benchmarks, AMU achieves an average speedup of 2.42× when the additional latency introduced by far memory is 1 μs. In the case of the random access benchmark from HPCC, our technique can offer a speedup of 26.86 × when the far memory latency is 5 μs, with the average number of in-flight memory requests of single-core exceeding 130.

2 Background and Motivation

2.1 Far Memory and MLP

Far memory refers to a variety of memory technologies that offer higher capacity compared with DRAM, including device memory/remote memory based on Non-Volatile Main Memory (NVMM) [46], cache-coherent interconnect-based memory/devices (e.g., CXL [60]), and Disaggregated Memory. While offering much larger memory capacities, far memory presents challenges because of its long and highly variable latency.
Non-volatile Main Memory (NVMM) provides higher storage density and persistence by using new materials [6, 35, 58]. When used as main memory, NVMM has a higher access latency than conventional DRAM. One example is the Intel Optane DC Persistent Memory Module, which exhibits an access latency that ranges from 200 to 300 nanoseconds [46]. Another example is ultra-low latency flash (ULL-Flash) based devices [33], which achieve a typical read latency of 3μs and write latency of 100μs. To date, NVMM has seen limited commercial adoption while various researches are still underway.
Cache-Coherent Interconnect Based Memory/Devices enables CPUs to directly access memory and storage devices without the overhead of extra software mechanisms like page swapping. The typical emerging coherent interconnects includes Compute Express Link (CXL) [60], Open Coherent Accelerator Processor Interface (OpenCAPI) [3] and Gen-Z [4]. The latency of Direct attached CXL-enabled memory is approximately 200ns [60], which is still three times larger than that of conventional local DRAM. For memory-semantic SSD, the access latency can be 35–738% slower than local DRAM, depending on the contention of SSD [34]. CXL-enabled memory extensions have gotten more attention in recent years. Anyway, local extension within a node still has its capacity limitations.
Disaggregated Memory allows programs to directly leverage memory resources on remote nodes based on high speed interconnects. Both academia [40] and industry [5] have developed remote memory prototypes and products based on emerging interconnects. For coming CXL-enabled disaggregated memory systems, the latency depends on propagation delays, including the latency of switches and ports, which will reach more than 300 ns [40]. For network-attached remote memory across multiple switches, the latency can reach 1μs–2μs, which is the state-of-the-art record [1]. Furthermore, the newly released CXL 3.0 specification introduces support for Global Fabric Attached Memory (GFAM), enabling the construction of memory pools that across multiple nodes.
Besides different types of far memory technologies, highly variable latencies also come from other factors. Due to queueing latency and contention, accessing the same level of the memory hierarchy can exhibit noticeable latency variations [19]. The potentially complex hierarchical structures inside far memory devices can also cause significant differences in memory access latencies.
Long and highly variable latencies further widen the gap between processor and memory. This exacerbates the traditional memory wall problem. Therefore, applications that want to get the benefit from the large capacity of far memory have to seek ways for latency tolerance first.
Traditional techniques for tolerating latency include caching, which reduces the average access latency by keeping hot data locally, and bulk data transfers, which move large contiguous blocks to minimize transaction count. However, both methods require memory locality. Big data applications often have extremely large working sets that are not cache-friendly. Some big data applications, such as graph computing and in-memory databases, exhibit fine-grained random patterns with poor temporal and spatial locality. Consequently, adjacent memory locations may not be related, making direct large block data transfers inefficient [7].
Fortunately, these workloads often comprise numerous memory operations with weak dependencies, which provides potential opportunities for MLP extraction. However, in order to fully exploit the potential MLP, further mechanisms are required.

2.2 The Limitation of Out-of-Order CPU for MLP

The traditional approach to extracting MLP from workloads relies on aggressive OoO execution of CPU cores. By providing a wider instruction window and leveraging aggressive OoO execution, cores can issue more in-flight load/store instructions for higher MLP.
The limitation of OoO execution is that it relies on complex hardware logic to track in-flight instructions and memory requests. This results in poor scalability. For instance, structures like the LSQ and MSHRs are typically built using CAM, and increasing CAM capacity raises power consumption and latency rapidly. Although there has been a significant amount of work [11, 44, 51, 61, 64] addressing these scalability issues in the past, simply scaling hardware is not a cost-effective solution. The MLP achievable with OoO execution is still constrained by certain critical hardware resources.
To overcome these constraints, previous research explores some approaches to utilize existing resources better to improve OoO aggressiveness, such as Runahead Execution [27, 50, 51, 52, 53] and CLEAR [31]. Runahead Execution allows processors to enter a “Runahead” mode when the ROB is exhausted, speculatively executing subsequent instructions to prefetch future memory accesses. CLEAR speculatively retires long-latency loads early to free up resources for other instructions. However, these kinds of techniques only address the issue of individual resource shortages like the ROB, but cannot handle the exhaustion of other resources such as MSHRs. As a result, they introduce more complex hardware logic without fundamentally solving the scalability issue for far memory.
The MLP demand for far memory has significantly exceeded the potential of contemporary OoO CPU. Assuming a far memory access latency of 1μs and a processor main frequency of 2 GHz, the access latency of a single far memory equates to 2,000 cycles. As memory operations comprise 30% of instructions [43], avoiding all stalls would require thousands of ROB entries and hundreds of MSHRs. This is impractical for current technology. State-of-the-art processor cores only have several hundreds of ROB entries and several tens of MSHRs.
The key reason here is, in fact, the synchronous semantics of traditional load/store instructions. A synchronous operation occupies critical pipeline resources until it finishes. Due to the significantly longer latencies of far memory, processor resources are exhausted more rapidly, leading to more frequent pipeline stalls and preventing further memory operations from being dispatched.

2.3 Asynchronous Memory Access Techniques

To address the resource occupation issue, asynchronous memory accesses that separate memory request issuing from memory response processing are needed. Asynchronous memory accesses allow corresponding instructions to be committed once the memory request is issued, instead of blocking for the response. Thus, resources like ROB entries and physical registers can be freed earlier rather than occupying them for the full latency duration. Additionally, asynchronous memory access also enables software to be further involved in exposing more opportunities for MLP extraction.
Prefetching is a typical and widely used asynchronous memory access technique [13, 14, 16, 20, 30, 32, 63, 71], which can be considered as a form of asynchronous load. Prefetch instructions do not hold ROB resources after the load request is issued. But prefetch loads still occupy MSHRs until data are returned later and put in cache for best effort. As an asynchronous mechanism, prefetching commonly faces timeliness issues [37]. The prefetched data can either be evicted from caches before use (i.e., early prefetches) or arrive after the demand loads have occurred (i.e., late prefetches). Thus, the benefits of prefetching are limited without sophisticated optimization.
Figure 3 demonstrates this weakness, comparing the performance of a GUPS benchmark using GP [16]-based prefetching to a baseline. GUPS involves random memory updates. The GP-based GUPS variant prefetches all addresses to be updated in a group before executing each update. As shown in Figure 3, the effectiveness of GP heavily depends on the group size. Different group sizes can cause the GP-based GUPS to outperform or underperform the baseline on the same hardware configuration and latency conditions. Moreover, the group size yielding the best performance varies greatly with hardware configurations. This example shows that prefetching would struggle to adapt to unpredictable latencies.
Fig. 3.
Fig. 3. The performance of GUPS as hardware resources are increased. The CXL Ideal configuration is described in Section 6. The hardware resources (i.e., IQ, LSQ, ROB, MSHRs, and physical registers) of x2 and x4 are two times and four times those of CXL Ideal configuration, respectively. The lines show the performance of Group Prefetching [16] based GUPS under different group (or batch) sizes. The bar plot represents the performance of the baseline GUPS benchmark.
The limitation of prefetching is caused mainly by a lack of support for tracking responses and managing returned data. Software cannot obtain information about request completion, making it difficult to ensure that the prefetched data is available when needed. As a result, prefetching is not well-suited for scenarios with far memories that have highly variable latencies.
External memory engines also provide asynchronous memory access via offloading expensive memory operations to external engines for asynchronous execution. With an I/O-like interface, it provides response notification and explicit management of data storage. Typical techniques include Intel I/O Acceleration Technology (I/OAT), and Intel Data Streaming Accelerator.
However, these engines face high startup overhead. They generally require setting up and en-queuing descriptors for the engine to initiate memory requests. Although advanced engines allow directly converting writes into remote memory requests (e.g., Cray FMA), this still requires several-tens cycles as the engines are attached to NoC or I/O bus. Therefore, this approach is typically only suitable for applications that involve transferring large, contiguous blocks of data, but not applications with fine-grained and random accesses.
To reduce overhead, some works [49, 54] have proposed aggregating many small messages issued by user-level threads into a larger packet to lower the average overhead. However, the software-based aggregation increases the latency of individual memory operations, necessitating applications to have inherently high MLP to fully hide the increased latencies.
Additionally, Some works [17, 55] have proposed programmable memory engines. These engines are also located on the NoC, allowing complex memory access patterns through compiler or manual programming. However, these engines typically adopt a produce/consume model for interaction with the host core. The host core will send a non-speculative notification signal to the memory engine after consuming the data. These synchronous operations eliminate the advantages of OoO cores with aggressive speculative execution. Consequently, such works are more suitable for processors with simple cores such as in-order cores, VLIW, or many-core processors with many small cores rather than high-performance OoO designs.
Integrating external memory access engines inside the core is not straightforward. The engines would need to be redesigned to support the cancellation of requests for handling mis-speculation. Relying on the existing accelerator interfaces like Rocket Chip Coprocessor (RoCC) [10] is also not possible. Because they lack speculative execution support, which makes them unsuitable for implementing tightly coupled coprocessors [56]. Therefore, directly integrating external memory engines into an OoO pipeline presents difficulties.
In summary, existing asynchronous techniques still have limitations in far memory scenarios. Prefetching lacks a notification mechanism, making it difficult to apply to far memories with highly variable latencies. Offloading to external memory access engines incurs high startup overhead, making it challenging to apply to big data applications involving word-sized random memory access patterns, such as graph computing workloads.

2.4 Motivation

In this article, we want to design a built-in asynchronous memory access mechanism for an OoO core to meet the MLP demand of far memory without sacrificing the performance of local operations. Based on the previous discussions, an asynchronous memory access technique targeted far memory scenarios should support asynchronous request issuing, response notifications, and explicit storage management.
Our first design choice is where to put the storage. To meet the typical demand of far memory, up to several hundreds of simultaneous memory operations should be supported for a single OoO core. The data and metadata needed for it require tens of KBs of space. It exceeds the existing scope of register files even L1 cache. So, we choose to dynamically partition a portion of the L2 cache as SPM for massive far memory operations. While L2 partitioning incurs some impact, this is acceptable versus the performance gains of AMU. The dynamically software-adjustable SPM size avoids affecting non-AMU applications. Additionally, big data applications typically underutilize L2 caches [39, 72]. Occupying part of the L2 cache as SPM thus has a limited negative impact on performance.
Secondly, we propose a set of new asynchronous instructions for accessing far memory, both for request initiation and response notification. The key design rule is that an asynchronous instruction should not hold any registers for long. Once a memory request is sent out, the initiation instruction should be retired at once. The later response check instruction should not be in a block-and-wait mode either. Between the two instructions, data and metadata for a pending memory operation are stored in the SPM rather than the hardware registers. As register allocation is done by modern compilers, we do not use hardware instructions for SPM data allocation and leave it for software. The new asynchronous instructions are only in charge of moving data between SPM and far memory. Moving data between GPR and SPM is done by normal synchronous load/store instruction. These operations then will have short and fixed latency since no cache-miss will occur anymore. Asynchronous and synchronous instructions work cooperatively for the high MLP.
Thirdly, we propose adding a special function unit for the new asynchronous instructions. The new asynchronous instructions can share the same fetching, decoding, and dispatching stage as normal instructions in an OoO pipeline. However, since asynchronous instructions have rather different requirements for resource scheduling and interact heavily with SPM, we propose to add a new function unit for their execution phase. To some extent, it is like a vector unit for vector instructions and vector registers.
Fourth, we choose to handle in-thread data consistency through software instead of non-scalable hardware. There are two possible sources of data conflicts and inconsistencies for instruction sequences. One is between asynchronous memory accesses and traditional load/store instructions. The other is conflicts among asynchronous instructions themselves. For consistency between load/store and asynchronous instructions, we choose to use dynamic partition to avoid hardware complexity. By partitioning, we could assume that asynchronous instructions and load/store would not access the same memory region simultaneously. Necessary cache flush operations are needed for region transition.
For consistency among asynchronous instructions themselves, it means disambiguation for these new memory access operations. Hardware handling disambiguation would have too high costs due to the large number of outstanding asynchronous memory requests. On the other side, big data programs often employ data parallelism or have large datasets, so the probability of data conflicts is low. Therefore, we choose to do conflict detection through software when necessary. For efficiency, data structures for disambiguation can be held either in SPM or local cache with flexibility.
We name the new asynchronous instructions and the supporting functional unit as AMI and AMU. Together with AMI and AMU, software can get full explicit control over massive memory requests to exploit enough MLP for far memory accesses.

3 Overview of AMI and AMU

Figure 4 shows the overall architecture of AMU as well as an example to illustrate the programming model of AMI. The design is based on our previous studies [65, 66], which only provided a preliminary discussion of AMI and an in-order core AMU prototype without investigation into the challenges of OoO-based design.
Fig. 4.
Fig. 4. AMU architecture.

3.1 Asynchronous Memory Access Instruction and the Programming Model

AMI contains three basic instructions (listed in Table 1). aload/astore instructions are designed to invoke asynchronous data movement requests between SPM and memory. The getfin instruction, inspired by I/O multiplexing, returns the ID of a completed request to serve as a notification mechanism. Conventional hardware mechanisms for notification are interrupt-based or polling-based, but these are unsuitable in this case. Interrupt-driven notifications incur too much overhead for memory requests, while polling-based schemes waste cycles repeatedly checking the status of each request. In contrast, the getfin enables software-based out-of-order scheduling of instruction streams or tasks. The scheduling is dependent on memory access completions.
Table 1.
Instructiondescription
aload Rd, Rs1, Rs2 astore Rd, Rs1, Rs2Initiate an asynchronous memory access request to read the data from Rs2 (Memory Address) to Rs1 (SPM Address) or write the data from Rs1 (SPM Address) to Rs2 (Memory Address). The returned request ID is placed in Rd. If the ID allocation fails, Rd is set to 0.
getfin RdGet a completed ID of request. If there is no finished request, the instruction returns a failure code.
cfgrr rd, CFGREGRead the specified configuration register CFGREG to the general-purpose register Rd.
cfgrw rs1, CFGREGWrites the value of the general-purpose register Rs1 to the configuration register CFGREG.
Registersdescription
granularityConfiguring the granularity of memory access requests
queue_baseConfiguration of the SPM metadata area start address
queue_lengthConfiguration of the length of the SPM metadata area
Table 1. Basic Asynchronous Instructions and Configuration Registors
From the software perspective, the SPM acts as a special type of register. The AMI provides the ability to load/store contents of far memory to/from the SPM. After software initiates an asynchronous memory access, the AMU copies data between far memory and the SPM. Subsequently, software operates the data in SPM through standard load/store instructions.
The configuration registers supported by AMI are listed in Table 1. These registers are configured by executing cfgrr/cfgrw instructions. Applications can configure the start location (i.e., queue_base) and the range of metadata area in SPM. The maximum number of outstanding memory requests it requires is controlled by queue_length. AMU will initialize the specified number of metadata table entries to be used as metadata area. Then, the SPM metadata area is managed by AMU only. Other areas of SPM are used as data storage visible to instructions.
A brief usage example of AMI is shown in Figure 4. The example assumes the software employs lightweight threads for dynamic instruction stream scheduling. ① A user task initiates an asynchronous memory request using the aload instruction, which returns an identifier representing the request. ② The user task suspends and notifies the runtime system of the request ID it is waiting on. ③ The runtime system executes a getfin instruction in an event loop to obtain the ID of a completed request. ④ The runtime system then awakens the user task waiting on that ID. ⑤ The user task accesses the retrieved data in the SPM using a standard load instruction.
Additionally, the proposed AMI supports variable granularity access (through configuring the granularity of memory access requests), which naturally reduces the algorithm design overhead in several domains (e.g., graph processing [72]). The software does not need to use multiple instructions to combine or split data to match register or cache line size. A single aload can access large data blocks up to KBs.
For address translation, the virtual addresses in aload/astore are translated to physical addresses via the traditional TLB. Address translation in distributed memory systems is an active research area [26] but orthogonal to this work. Therefore, we do not consider address translation impacts and assume a conventional address translation. Also, the SPM uses a fixed mapping and does not require address translation.
However, the asynchronous programming model of AMI increases program complexity versus conventional synchronous models. Approaches are required to reduce this complexity and lower the programming effort for developers. Section 5.2 discusses programming frameworks as an approach to tackle programming complexity.

3.2 Asynchronous Memory Access Unit

AMU is a memory access accelerator integrated within processor cores. When software issues requests, the AMU is responsible for converting them to native memory requests and tracking their status. These requests are sent to the remote memory controller (MC) through the local bus. The remote MC communicates with the far MC through a high-speed network or I/O bus. This article will not discuss the details of remote MC and far MC.
The AMU (Figure 4) consists of two main components: the Asynchronous Load/Store Unit (ALSU) integrated into the pipeline and the Asynchronous Scratchpad Memory Controller (ASMC) integrated with the L2 cache controller. The ALSU is specifically responsible for executing AMI instructions to generate the corresponding asynchronous memory requests. These requests are sent to the ASMC via the standard ports of the cache. The ASMC is responsible for managing the SPM and converting ALSU requests into far memory requests. It is integrated with the L2 cache controller.
The procedure of managing asynchronous requests is shown in Figure 4. ① When a user executes an aload/astore instruction, the AMU allocates a free ID from the free list for the current asynchronous memory request. The ID is returned to the user program. ② Then, AMU maintains the corresponding list entry and metadata in the SPM, using the ID as the index for the metadata table. After that, AMU schedules an un-core memory access to remote MC. The aload/astore instructions can be retired at this point. Meanwhile, the corresponding LSQ and ROB resources are released. ③ When the request is completed, AMU places the ID into the finished list. ④ Applications retrieve completed IDs using the getfin instruction. getfin returns the ID and puts it back into the free list for subsequent requests. The maximum number of in-flight memory accesses depends on the size of the SPM meta-data area, making even hundreds-level MLPs supported easily.
The AMU repurposes on-core L2 cache resources as SPM to provide both data storage and a request metadata store. This avoids the register pressure [63] and MSHRs constraints faced by memory-intensive applications [72] when following asynchronous memory access paradigms. This enables efficient tracking of several hundreds of outstanding requests and helps scale the AMU design with modest hardware overhead.
Additionally, AMU takes advantage of SPM to enable variable granularity memory access. AMU can support large granularity memory access through instructions rather than traditional I/O interfaces. In contrast, designs relying solely on registers are limited by register size and can only load data at the granularity of individual registers. This makes it difficult to support asynchronous access to a large block of data in a single instruction. SPM allows data to be loaded in chunks of varying sizes, from the smallest units up to very large blocks without restriction by register size. This approach provides opportunities to optimize performance, as programs can efficiently load and process data with granularities best suited to the computational problems. Furthermore, when programs require loading a large block of data, this avoids the latency and overhead of loading smaller chunks individually through separate memory accesses.
However, the AMU presents three challenges that must be addressed.
First, while using an SPM to replace physical register files and MSHRs provides greater capacity, SPM accesses are significantly slower. Therefore, mechanisms are needed to mitigate this performance gap. Section 4.2 investigates micro-architectural optimizations to overcome the speed disadvantage of accessing data stored in the SPM.
Second, supporting speculative OoO execution requires designing rollback mechanisms for AMU. Although speculative execution of traditional load instructions affects cache state, there are no program-visible side effects. In contrast, AMI instructions have program-visible side effects as they modify the state and data stored in the SPM. The SPM-based design of AMU therefore complicates the rollback process since it involves restoring SPM contents when misspeculation occurs. This poses additional challenges compared to conventional cache-based designs in undoing misspeculation effects. Section 4.3 details the speculative execution support of AMU.
Third, SPM lacks the associative lookup abilities needed to perform memory disambiguation transparently in hardware, as typically done using CAM-based structures. For instance, OoO cores rely on CAM-based LSQ to implement memory disambiguation. However, CAM structures are expensive to scale. To avoid these limitations, AMU requires a CAM-free approach for memory disambiguation. Section 5.1 examines techniques to address consistency issues through software-based memory disambiguation.

4 Micro-architecture Design

4.1 Implementation of the Basic Functionalities

Figure 5 presents the structure of ALSU as well as an execution example. The aload/astore instructions are first decoded into two micro-ops (details in Section 4.2). The first micro-op is used for ID allocation, while the second generates the actual asynchronous memory request. The micro-ops are executed in the ALSU. For ID allocation, the execution unit first checks for available IDs. If a free ID exists, it performs allocation locally. Otherwise, it requests free IDs from the ASMC. After ID allocation, the micro-op for issuing the asynchronous request is executed. The ALSU constructs the asynchronous memory request and passes it to the ASMC. This request is handled similarly to a store request to the cache. The request is buffered in the store buffer before the instruction commit. At this point, the instruction has been completed and can wait in the ROB for retirement.
Fig. 5.
Fig. 5. Architecture of ALSU.
The ALSU concentrates on the instruction execution and the mis-speculation handling (details in Section 4.3). Therefore, the ASMC does not need to consider the intricacies introduced by speculative execution. Communication overhead between the ALSU and ASMC is also reduced through batching of ID transfers (details in Section 4.2). This lowers the overall design complexity by dividing different concerns between the two units.
Figure 6 illustrates the design of ASMC. Several modifications are made to the cache controller. First, the control logic is added to repurpose a portion of the cache area as SPM. This implementation is straightforward and is supported by several commercial processors. Second, several new memory commands are defined to support ID-related requests and asynchronous memory access requests. These extensions to the cache controller allow it to serve its original caching functionality while also managing metadata and coordinating memory operations for asynchronous memory access requests. Third, the protocol between L1 cache and L2 cache is expanded to support the newly defined commands. Supporting these new commands is straightforward as they do not interfere with maintaining cache consistency.
Fig. 6.
Fig. 6. Overview of the ASMC.
The ASMC utilizes three key data structures stored in the SPM metadata area to support the new memory commands: a finished list, a free list, and an Asynchronous Memory Access Request Table (AMART). For each asynchronous memory request, the ASMC indexes the AMART using a request ID to access the corresponding entry. Each entry contains metadata like the SPM address, memory address, request status, and other implementation-specific information. The request is then converted to a standard memory request sent to the MC. Upon response from memory, the ASMC re-indexes the AMART using the request ID to update the status. Once an asynchronous request is completed, its ID is written to the finished list by the ASMC. To reduce SPM accesses and improve performance, the ASMC caches a subset of IDs from the finished and free lists in on-chip registers.
The ASMC enables the transfer of large contiguous data blocks by dividing large requests into cache-line-sized sub-requests. The ASMC relies on a dedicated state machine to split large granularity memory requests. The states of memory requests are also tracked in the metadata region of the SPM.

4.2 Metadata Batching

To reduce overhead from frequent ALSU-ASMC communication, we develop a metadata batching approach.
The key idea involves using vector registers as buffers to aggregate metadata accesses. The major interaction between ALSU and ASMC involves pulling and pushing request IDs from/to the finished and free lists managed by the ASMC. “List vector registers” are thus introduced, holding portions of the IDs in these lists. As shown in Figure 5, each register contains a pointer to the next unused ID entry as well as multiple stored 16-bit IDs. The width of the List Vector Register matches the width of the physical vector registers (512 bits in this article). Thus, the ALSU can request a batch of IDs from the ASMC to store in the list vector register each time, or write back all the IDs in the register with a single request to the ASMC.
To minimize software complexity, the list vector registers are not directly accessible to software. Instead, they are accessed through internally-generated micro-ops. Each asynchronous memory access instruction is decoded into two micro-ops: one for performing conditional fetching/writing of IDs between vector registers and ASMC; the other handles the actual functionality of the instruction. Figure 5 shows a detailed example. The ID allocation micro-op first checks the list vector register for an available ID. If there are no IDs, it issues a request to the ASMC to fetch a batch of free IDs. Upon receiving the IDs from the ASMC, the allocation continues.
Figure 5 shows the detailed architecture for executing the micro-ops within the ALSU. The process contains two stages: execution and commit.
Execution The micro-ops are sent to the LSQ and dispatched to the corresponding execution unit. Two additional execution units are added to support asynchronous memory access. One unit handles aload/astore requests sent to the ASMC, while the other handles ID management micro-operations. The aload/astore request is similar to a conventional memory write request with command, data, and address, but with different semantics. The command field specifies aload/astore, the data field carries the request identifier and SPM data address encoded in the original instruction, and the address field contains the memory address also from the instruction.
Commit The asynchronous memory request is sent to the ASMC when the instruction reaches the head of the ROB, resembling atomic instructions or non-speculative instructions. However, ID management micro-ops can be speculatively executed for higher performance. Their requests may be forwarded to the ASMC prior to the older asynchronous memory access micro-ops.

4.3 Speculative Execution Support

The primary challenge of supporting speculative execution for AMU is managing the effects of micro-operations that modify metadata, such as finished/free lists in the SPM. For example, if a micro-op is speculatively executed but is later squashed, the speculatively fetched IDs could be lost prematurely. There are three cases of how AMI-decoded micro-ops can support out-of-order execution:
The first case is micro-ops responsible for initiating aload/astore requests (e.g., the ALoadExec micro-op shown in Figure 5). These micro-ops read register data to construct asynchronous memory requests passed to the ASMC. Because asynchronous memory requests can be regarded as a special type of store request, they are handled similarly by buffering in the store buffer before the instruction commit, just like the store instruction.
The second case involves ID management micro-ops like retrieving completed IDs or allocating free IDs. When the list vector register still contains IDs, these micro-ops simply move an ID into a general-purpose register without issuing a batch ID fetch request to the ASMC. This allows it to behave like a regular register-to-register instruction, which can thus be handled via the traditional register renaming mechanism.
The third case involves the ID management micro-ops when the list vector register is empty. In this case, these micro-ops will issue a batch ID fetch request to the ASMC, changing the state of the queues in SPM. To address this problem, ALSU uses an “uncommitted ID register” to isolate ID updates from the ASMC. From the perspective of ASMC, the IDs taken by ALSU can be safely removed from the queue in SPM without considering rollback. As shown in Figure 5, the uncommitted ID register keeps the value of the list vector register corresponding to the micro-op that issued the batch ID fetch request. The value in the uncommitted ID register can be regarded as a checkpoint for this request. When a mis-prediction occurs, the register continues holding the IDs retrieved by the canceled instruction. Subsequent micro-ops that issue batch ID fetch requests will obtain IDs from the uncommitted ID register rather than the ASMC. This effectively restores the previous obtained IDs to the list vector register. Therefore, IDs fetched from the ASMC are not lost on mispredictions. The uncommitted ID register only being cleared on instruction commit. So, it can only store the result of one batch ID fetch request, requiring a second ID fetch to stall until the previous one is committed. However, this stall is infrequent, as the list vector register can hold 31 IDs before needing refills.

5 Software Support

5.1 Software-Based Memory Disambiguation

For OoO pipeline, solving memory ambiguity is crucial to ensure program correctness. Specifically, consistency must be maintained when two outstanding instructions access the same memory address. Traditionally, memory ambiguities are detected and handled by CAM-based hardware structures. However, AMU relies on large SPM instead of CAM-based hardware structures to enable high MLP. As a result, memory disambiguation has to be done through software. This section details our software solutions for handling data consistency among AMIs, while handling potential data conflicts between AMIs and load/store instructions is discussed in Section 5.3.2.
We found that software-based memory disambiguation can be sufficient for two reasons. First, a study has shown that on average 43% of memory operations do not cause any violations [29]. For big data workloads that enjoy far memory, this percentage can be higher as they typically employ data parallelism. Therefore, software memory disambiguation only needs to be applied for a small portion of memory operations. Second, only a small fraction of memory locations are active at any given time [73]. As a result, there is no need for the software to track the status of all memory locations that could cause violations. The software simply needs to maintain a record of the active locations at present.
Based on these observations, we contend that a small cacheable hash set in local DRAM, capable of tracking the addresses of in-flight asynchronous memory requests, can tackle memory aliasing problems. The hash table design used in this work is based on cuckoo hashing but with a slight variation from typical implementations. Specifically, each hash function maps to its separate table rather than alternating between shared tables. During insertion, the primary hash function is used first to determine a slot in the first table. If a collision is encountered, the secondary hash function is used to insert into the second table instead. This process continues with subsequent hash functions targeting additional tables in case of persisting collisions. Due to the relatively low collision rates encountered for big data workloads, only a small number of tables are required.
Listing 1 demonstrates an example code, which is based on the proposed coroutine-based framework (details in Section 5.2) for simplification. Before initiating asynchronous memory requests that could violate ordering, the program calls the corresponding function to check for conflicts with outstanding requests (line 28). The function queries the target address in the hash table (line 8). If no entry exists, the to-be-accessed address is inserted into the hash table (line 15). Otherwise, the current coroutine is suspended and its handle is appended to the hash table entry (lines 10–13). When other requests to the same address are completed, the suspended coroutine is awakened to resume (lines 20–22). In the future, advancements in compiler technology will potentially automate the insertion of such conflict-handling code, further reducing the burden on programmers. The hash table is located at the local DRAM. In fact most of it will be held in cache since the table is small and accessed frequently for memory extensive applications.
Listing 1.
Listing 1. Pseudo Code of Software-based Memory Disambiguation.

5.2 Programming Framework

While enabling much higher MLP and performance, AMI introduces two challenges about programming complexity. First, the asynchronous semantics are inherently less intuitive for programmers compared to synchronous programming. Programmers must manually check for completion of memory operations and handle callbacks. This event-driven style adds significant complexity. Second, rewriting existing code to extract sufficient MLP is difficult. Identifying independent memory operations and scheduling/synchronizing between them requires expertise. Overcoming these difficulties is essential to achieve the potential speedup of AMU. Thus, we propose a set of coding approaches as well as preliminary work on the compiler.
First, we exploit the async/await mechanism (i.e., coroutine) introduced in C++20 to preserve a synchronous-style programming model. By wrapping aload/astore in awaitable objects, our framework allows programmers to simply co_await the corresponding awaitable objects when asynchronous memory access is needed, as shown in Listing 2 lines 48 and 50. Programmers no longer need to manually handle the asynchronous semantics introduced by asynchronous memory loads and stores. This significantly reduces programming effort compared with directly using the AMI without higher-level abstraction. As shown in Listing 2 lines 44–57, the code that employs the proposed framework is significantly simpler than manually using AMIs (Listing 2 lines 12–40), similar to the code in the “multi-thread version”. Developers can continue writing code in an intuitive synchronous style while the underlying runtime transparently manages the asynchronous memory operations. While the programming framework is currently implemented in C++, porting it to other languages is feasible. Many languages nowadays such as Rust and Go also support coroutines.
Listing 2.
Listing 2. Exploiting MLP with Asynchronous ISA.
Second, we argue that the common paradigm to exploit AMU is converting available loop-level parallelism (LLP) or request-level parallelism (RLP) into MLP. The opportunity of LLP generally appears in loops that have loop-independence. On the other hand, RLP is usually present in Internet servers that receive a large number of concurrent user requests. For programs that exhibit LLP or RLP, synchronous load/store to far memory can be replaced with AMIs. Then, the threads can be interleaved effectively to hide the access latency. Lightweight coroutines executed with our framework incur lower overhead than OS threads for this purpose.
Listing 2 presents a demonstration of how to convert a serial code to an AMI version. Initially, the sequential code (lines 1–3) is transformed into a multi-thread version (lines 4–11) by exploiting LLP/RLP. Subsequently, we generate an equivalent coroutine code (lines 12–43). The load/store instructions to far memory are replaced with aload/astore and getfin. The transformation between the multi-thread version and the coroutine-based code can be simplified by using the proposed framework (lines 44–57).
To further reduce porting overhead, we are developing an LLVM Pass that can automatically leverage aload/astore instructions to accelerate memory accesses for specified data-independent loops. The pass operates based on annotations provided by programmers in their source code. Specifically, programmers mark data as far memory and loops as data-independent using annotations. The pass then identifies these annotations and applies the approach of converting LLP to MLP described above to boost performance.

5.3 System-Level Issues

5.3.1 Context Switch.

The design of AMU assumes that user applications maintain exclusive access to AMU, as the process switching overhead is significant. In a multi-process environment, the operating system (OS) manages SPM similarly to vector registers. Thus, context switching requires saving the full SPM as well as several micro-architecture states. Additionally, when AMU-based programs and conventional programs are executed together on the same core, cache contention can occur. Thus, to ensure performance, AMU should be used exclusively as much as possible, and the OS should avoid co-scheduling cache-hungry programs with AMU-based programs on the same core while ensuring CPU affinity for AMU-based programs.

5.3.2 Working with Synchronous Memory Access Code.

Cooperating with existing synchronous memory access codes is another important consideration for AMU. Large applications typically contain code segments with different memory access characteristics, and legacy code that cannot be easily modified. While load and store instructions remain suitable for code with good data locality, other memory-intensive codes could benefit significantly from offloading memory operations to an AMU due to their poor data locality.
To facilitate cooperative execution, the programmer or compiler must analyze the phases and data structures of programs to determine the division of labor between synchronous and asynchronous approaches. Some programs can exhibit different access patterns in different phases - one with good locality and another with poor locality. This requires dynamically switching between synchronous and asynchronous memory access, with necessary cache flush instructions to maintain data consistency. Additionally, while some programs may not have clear-cut phases, the memory access patterns of different data structures within can vary greatly. Structures with good locality are better suited to use load/store and caches, while some structures could benefit from asynchronous memory accessing via AMU. This requires allocating these data structures into different memory regions.

6 Evaluation

6.1 Evaluation Methodology

The proposed AMU is implemented by modifying the RISC-V OoO CPU model within the GEM5 simulator [47]. The simulated system architecture, as depicted in Figure 7, includes a remote memory node connected to the CPU via CXL as a far memory. Since this work is only concerned with memory access latency, CXL is modeled using the serial link model of gem5. It models the packet delay, which is dependent on the size of the packet, as well as the bandwidth limitation of the interconnect. Internal details of CXL such as coherence protocols are not simulated. We integrate McPAT [42] to estimate power consumption. Additionally, an RTL model was developed using Chisel HDL to evaluate the logic resources overhead.
Fig. 7.
Fig. 7. The simulated systems with far memory.
Evaluation is conducted under four configurations. The Baseline configuration, mimicking an Intel Golden Cove processor, is shown in Table 2. Moreover, we set up a configuration called CXL Ideal (with BOP) which is an “ideal” configuration with an L2 best-offset hardware prefetcher [48]. In this configuration, the maximum number of in-flight memory requests is significantly increased by setting the entries of MSHR to 256 at each cache level. This configuration provides a useful target for comparison, approximating prior works that boosted hardware resources or pure hardware designs to increase OoO execution potential. Although impractical by current technology, it establishes an upper bound on attainable performance through conventional means. The AMU configuration refers to the proposed AMU architecture. In the evaluations, the size of the SPM is fixed at 64 KB. The AMU (DMA-mode) is a limited AMU configuration, simulating the performance of external memory access engines. This configuration limits the number of IDs that the list vector registers can buffer to 1, forbidding the micro-ops to be executed speculatively.
Table 2.
Configuration
Processors3 GHz, 6-wide OoO, 512-entry ROB, 512 physical registers, 192-entry LSQ
CacheL1D/L1I: private, 32 KB, 16-way, 48-entry MSHR, delay = 4 cycles. L2: private, 256 KB, 8-way, 48-entry MSHR, delay = 10 cycles
MemoryDDR4_2400_8x8, 2 rank, 8 bank group, 32 bank
Table 2. Gem5 Configuration
Due to simulation time constraints, some simplifications are made. However, this does not change the general conclusion of our articl. First, cache and dataset sizes are decreased to ensure a reasonable data loading time. Despite reduced cache capacity, it still reflects the fact that applications enjoying far memory tend to have a significantly large working set, making it challenging for the cache to cover completely. Second, the evaluation uses single-core configurations, focusing on the ability of AMU to enable high outstanding memory requests.

6.2 Benchmarks

Multiple memory-bound benchmarks from various suites were chosen. The selected benchmarks include random access (GUPS), STREAM, binary search (BS), hash join (HJ) [15], hash tables (HT) [18], link list (LL) [28] and skip lists (SL) [18], BFS, Integer Sort (IS), Redis and HPCG.
The benchmarks were modified with AMI to exploit the MLP, following the programming paradigm described in Section 5.2. The details of the benchmarks are shown in Table 3. Besides Redis and GUPS which are handwritten, other benchmarks are ported by using the proposed coroutine framework to reduce programming complexity. BS, HT, LL, SL, and Redis exploit RLP by launching multiple coroutines (256 for most, 128 for SL) to execute an independent key/value lookup task. Each coroutine sequentially generates random keys. The data structures being looked up are allocated in far memory. When accessing data structures in far memory, these workloads use AMI to initiate asynchronous memory access requests. The coroutines are interleave executed by the framework to hide far memory latencies. On the other hand, GUPS, HJ, HPCG, IS, and STREAM exploit LLP, as they contain iterations that are independent of each other. Each coroutine executes a portion of the iterations. Most benchmarks have small (less than 64B) access granularity, except STREAM, IS, and HPCG which were evaluated for the benefits of large granularity. As these three benchmarks involve accessing contiguous memory, performance is improved by loading 512B or more of contiguous data into the SPM with each aload/astore.
Table 3.
NameDescriptions
Breadth First Search (BFS)This implementation is from Graph500. The workload contains 16384 vertexes and 262144 edges.
Binary Search (BS)This program launches 256 coroutines to search random keys from a shared array. Each element is a 8B integer.
Random Access (GUPS)Single node version of HPCC Random Access. The table been updated is located in far memory.
Hashjoin (HJ)This implementation is from Ref. [15]. The hash table contains 16000 buckets. Each node of the list is 48 Byte.
Hash Table (HT)The chained hash table implementation is from ASYCLIB [18]. Each node is same as the node of LL.
HPCGThe OpenMP implementation of HPCG was selected. The matrices are allocated in far memory.
Integer Sort (IS)Integer Sort is a memory-bound random access benchmark from NAS Parallel Benchmark [12].
Hand-over-hand Linked List (LL)This program lookup a number of keys from a hand-over-hand linked list [28]. Each node contains 8 Byte key, 8 Byte value and a pointer to the next node.
RedisYCSB is used to benchmark the modified Redis. The Redis’ single thread execution model is modified to support servicing concurrent requests. The buckets of the chained hash table are allocated in local memory, while the collision lists are allocated in far memory.
Skip-list Lookup (SL)The concurrent skip-list implementation is from ASYCLIB [18]. Each node contains 32 Byte payload (including key, value and other metadata required by Skip-list) and 15 pointers.
STREAMThe major arrays are allocated in far memory.
Table 3. Description of Benchmarks

6.3 Performance and Power Evaluation

Figure 8 shows the normalized execution time of the benchmarks (the lower, the better). The far memory latency is adjusted to various values to simulate different far memory devices. For most cases, AMU maintains relatively constant performance as latency increases, demonstrating its ability to mitigate latency impacts.
Fig. 8.
Fig. 8. Normalized execution time of benchmarks. The x-axis represents the access latency introduced by far memory. The y-axis shows the normalized execution time. The execution time is normalized to the baseline configuration under 0.1μs far memory latency.
AMU exhibits performance advantages in most benchmarks when the additional latency caused by far memory exceeds 500 ns. For BS, BFS, GUPS, HT, and LL, AMU performs well when additional latency is only 0.2 μs. These workloads primarily involve random memory access, preventing them from benefitting from caches. Their performance is limited by the random access capability of hardware. Additionally, irregular access patterns diminish hardware prefetcher effectiveness, hurting performance. As AMU enables issuing huge numbers of outstanding requests, it alleviates these bottlenecks of workloads. For IS, which accesses memory sequentially more often, AMU only outperforms other configurations when additional latency is over 1 μs.
The AMU demonstrates significant advantages over traditional external memory access engines simulated as AMU (DMA-mode). As engines located outside the core cannot leverage out-of-order execution and have higher latency and overhead, AMU avoids these disadvantages through specialized microarchitectural design within the processor. By supporting out-of-order execution and the proposed batching mechanisms within the core, the AMU is able to significantly reduce overhead, making fine-grained asynchronous memory access practical.
Figure 9 shows the average number of in-flight memory requests (MLP), which directly demonstrates a key benefit of the AMU. As latency increases, AMU-based workloads exhibit a corresponding rise in average MLP, as asynchronous memory access instructions enable applications to schedule more overlapping independent instruction streams for execution. With higher latency, more coroutines can be interleaved due to the ability to asynchronously initiate additional memory requests. The improvement in MLP effectively mitigates the impact of increased latency. In contrast, the performance of original codes relies heavily on short latency due to the limitations of hardware resources and synchronous semantics. Their MLP lacks scalability and does not improve as far memory latency rises.
Fig. 9.
Fig. 9. MLP of benchmarks. The x-axis represents the access latency introduced by far memory. The y-axis shows the MLP.
Figure 10 shows the IPC of the benchmarks. It can be seen that adopting AMI significantly improves IPC. This demonstrates that the AMI, unlike traditional load/store instructions, does not stall for a long time in the ROB. Instead, they are committed very rapidly. This confirms that the proposed design is effective at reducing the consumption of critical hardware resources.
Fig. 10.
Fig. 10. IPC of benchmarks. The x-axis represents the access latency introduced by far memory. The y-axis shows the IPC.
Figure 11 shows a breakdown of the power consumption. The additional power consumption of AMU is primarily due to the maintenance of metadata in the SPM and the increased instruction execution overhead caused by software-based instruction scheduling. Meanwhile, the performance enhancement offered by the AMU reduces the overall execution time, leading to a decrease in static power consumption and the counts of accessing power-consuming hardware resources such as ROB/IQ. This results in significant power consumption benefits. When the far memory latency is 500 ns, the geometric mean of the power consumption of AMU relative to the baseline is 1.3, indicating that the power consumption benefits brought by performance improvement do not entirely cover this additional overhead. However, when the latency reaches 1 μs, the geometric mean of power consumption of AMU compared to the baseline reduces to 0.9, and the extra power consumption overhead is effectively compensated by the power consumption benefits achieved through performance improvement.
Fig. 11.
Fig. 11. Normalized power consumption of benchmarks. The y-axis shows the power consumption which is normalized to the baseline configuration under 0.1 μs far memory latency. The top (brighter) part represents static energy, while the bottom part represents dynamic energy.
Table 4 compares the performance of a software prefetching scheme versus AMU. The software prefetching scheme utilizes a compiler-based software prefetching [62]. The data shows that software prefetching requires careful tuning of prefetch aggressiveness due to the lack of feedback from hardware on the availability of prefetched data. This makes it difficult for software prefetching to adapt effectively to scenarios with highly variable memory access latencies like far memory.
Table 4.
Latency (μs)GUPSHJSTREAM
CXLPFAMULLVMCXLPFAMULLVMCXLAMULLVM
bestconfigbestconfig
0.11.004.522-1280.960.691.000.86128-1282.691.841.001.6413.02
0.21.386.3932-1280.960.691.411.19128-1282.671.841.281.6715.28
0.52.5412.988-00.970.702.612.21128-322.681.852.281.7422.44
1.04.4023.0132-640.980.694.593.86128-1282.711.874.001.8735.08
2.08.2143.7316-41.000.708.617.24128-322.792.137.632.1864.14
5.019.83106.7716-41.030.7120.7017.44128-323.082.1318.663.33149.83
Table 4. Normalized Execution Time of Baseline (CXL), Compiler-Based Software Prefetch (PF), AMU, and LLVM-Based AMU (AMU)
The config list specifies the prefetch aggressiveness (x-y), where x indicates batching the memory accesses of x iterations and y indicates the depth of prefetching indirect memory access.
Additionally, Table 4 is a preliminary evaluation of the AMU LLVM pass. The evaluation indicates the compiler-directed optimizations outperformed manually ported versions significantly (e.g., GUPS and HJ). On the other hand, for the compiler-based STREAM, performance was notably lower compared to the hand-optimized version using large-granularity asynchronous memory accesses. This is because the current compiler only supports 8B granularity asynchronous memory accesses. This demonstrates that with continued advancement in compiler techniques, AMU still has the potential for higher performance gains.
Table 5 gives the overhead of memory disambiguation for two typical workloads. For HJ, the cost of memory disambiguation remains fairly stable at around 5%. For HT, the percentage of time spent on memory disambiguation is higher when the remote latency is low. However, as latency increases, this portion rapidly declines. Additionally, while there is a noticeable cost for memory disambiguation, the benefits from asynchronous memory access outweigh these overheads. Therefore, this overhead is acceptable. In future work, hardware-assisted techniques [73] could be explored to further reduce the cost and unlock more of the potential of AMU.
Table 5.
Latency (μs)0.10.20.51.02.05.0
HJ5.06%5.04%5.07%5.07%5.00%4.95%
HT32.47%29.04%20.17%13.89%9.14%3.95%
Table 5. Execution Time Spent on Software-Based Memory Disambiguation

6.4 Hardware Overhead

The on-chip storage overhead introduced by AMU is relatively low, as AMU reuses existing hardware resources. First, the list vector registers can employ the existing register renaming mechanism and use the general-purpose physical vector registers. Second, the metadata maintained by ASMC are stored in SPM, which is a part of the existing cache. Thus, no additional storage overhead is required for metadata.
The additional storage overhead of AMU is mainly internal state registers and relatively short queues. First, each state machine of AMU requires a 32-entry pending queue and several internal state registers. Second, ASMC prepares two list-vector-register-length buffers as a cache of the corresponding list. Third, there are two Uncommitted ID Registers in the ALSU. Therefore, the total overhead is only approximately a few KB and does not vary when the required MLP increases.
We implemented the AMU on NanHu-G, which is the second-generation of the open-source high-performance OoO RISC-V processor XiangShan [70]. NanHu-G is a 4-issue OoO core with speculation execution and 96 ROB entries. The AMU design was evaluated on an FPGA platform to analyze its hardware cost. Furthermore, the area overhead of integrating the AMU is evaluated using Synopsys Design Compiler under the TSMC 28 nm HPC+ process technology. Table 6 shows the resource utilization compared to NanHu-G. The results indicate that the AMU can be efficiently implemented on modern processor cores with modest resource overheads.
Table 6.
FPGALUT (as Logic)LUT (as Memory)FFBRAMURAMASICArea
+6.9%+8.5%+4.5%+0%+0%+6.67%
Table 6. Resource Utilization Compared with NanHu-G

7 Related Work

7.1 Multi-Threading/Many-Core Architectures

Significant prior work attempted to provide massive hardware threads that can be used to hide memory access latency. For instance, Cray MTA [2]/XMT [24] provides a large number of hardware threads. They offer hardware-based context-switch when the thread faces memory stalls. Typical many-core processors such as Sunway [25] and SmarCo [21] also provide a massive number of hardware threads which is sufficient for hiding long memory access latency. Intel PIUMA [8] proposed the multi-threaded core which offers multiple hardware threads by round-robin executing them. However, supporting massive light-weight hardware threading comes at a higher cost, and mainstream general-purpose processors typically only support a small number of threads per core. To address this, Feliu et al. proposed VMT [23], which offers multiple virtual hardware threads by interleaving executing them on two hardware threads. However, the total number of the hardware threads remains limited. The key difference of AMU is that it aims to provide similar multithreaded high concurrency memory access capabilities as prior domain-specific designs within the general-purpose OoO core at a lower hardware and compatibility cost. AMU is an independent unit within the processor. It does not impact programs that do not use AMU, while enabling high MLP for programs that can utilize the provided mechanisms.

7.2 Hybrid Memory/NUMA

Optimizing far memory accesses shares similarities with prior work on optimizing access in hybrid memory and non-uniform memory access (NUMA) systems. Hybrid memory systems commonly contain both faster DRAM and slower NVM. Likewise, NUMA architectures typically incur significant latency variations between local and remote node memory access. Many prior works explored memory allocation, data migration, and prefetching techniques to mitigate the impact of disparate access latencies in these systems. Memory allocation optimizations [45] aim at improving performance by placing frequently accessed objects in the faster memory. Data migration optimizations [59, 67, 68, 69] monitor access patterns and migrate hot data to the faster memory. Prefetching techniques [22, 41, 57] predict and prefetch data from the slower memory. These methods are orthogonal and complementary to AMU. They typically focus on page-granularity memory management and solve the problem from a more system-oriented perspective. The performance of synchronous load/store can be optimized by these techniques. In contrast, AMU focuses on providing tolerance for longer latencies through microarchitectural design. The major design goal of AMU is addressing the higher far memory access latency.

8 Conclusion and Future Work

This article introduces an ISA extension for asynchronous memory access along with the supporting hardware unit called AMU. Addressing the MLP limitation of modern OoO processors, the novel design adds support for full asynchronous mechanism with a small amount of hardware overhead. The design enables applications to exploit massive MLP to hide the latency of far memory. The evaluation reveals that memory-bound applications can exploit the full potential of far memory by utilizing the asynchronous programming paradigm.
This article only provides fundamental instructions and structures to enable asynchronous memory access. Additional research are required in the areas of OSs and compilers. In the future, more instructions can be added to further improve performance or provide more advanced memory access functions. For example, it is possible to add instructions to initiate a request with a group of memory operations together. As another example, instructions can be added to assist the software in scheduling the execution of other instructions after issuing an asynchronous access request (e.g., instructions to assist the scheduling of coroutines).
Furthermore, the proposed asynchronous design can be easily extended to support more functional memory extensions, including complex access patterns and Processing-In-Memory (PIM) mechanism. This extendibility is contingent upon the far memory subsystem supporting broader memory semantics [74].

Footnote

1
This article is an original work based on our previous work [65, 66] which proposes the basic concept of AMU as well as an implementation on an in-order core. This article provides a novel design and implementation of the AMU on an OoO processor core, an in-depth discussion and software solution for handling data conflicts introduced by the AMU, details of the programming framework and compiler support for using AMU, and a more thorough evaluation characterizing performance, power consumption, software overhead, and hardware resource utilization.

References

[2]
2017. Cray MTA-2 System. (2017). Retrieved from ttp://www.cray.com/products/programs/mta_2/[Online].
[3]
2017. openCAPI Specification. (2017). Retrieved from http://opencapi.org[Online; accessed: Febrary 2022].
[4]
2018. Gen-Z Specification. (2018). Retrieved from https://genzconsortium.org/specifications[Online; accessed: Febrary 2022].
[5]
2020. IBM Reveals Next-Generation IBM POWER10 Processor. (2020). Retrieved from https://newsroom.ibm.com/2020-08-17-IBM-Reveals-Next-Generation-IBM-POWER10-Processor[Online; accessed: Febrary 2022].
[6]
2022. Intel Optane Persistent Memory. (2022). Retrieved from https://www.intel.com/content/www/us/en/architecture-and-technology/optane-dc-persistent-memory.html[Online; accessed: Febrary 2022].
[7]
Sriram Aananthakrishnan, Shamsul Abedin, Vincent Cavé, Fabio Checconi, Kristof Du Bois, Stijn Eyerman, Joshua B. Fryman, Wim Heirman, Jason Howard, Ibrahim Hur, Samkit Jain, Marek M. Landowski, Kevin Ma, Jarrod A. Nelson, Robert Pawlowski, Fabrizio Petrini, Sebastian Szkoda, Sanjaya Tayal, Jesmin Jahan Tithi, and Yves Vandriessche. 2023. The intel programmable and integrated unified memory architecture graph analytics processor. IEEE Micro 43, 5 (2023), 78–87. DOI:
[8]
Sriram Aananthakrishnan, Shamsul Abedin, Vincent Cavé, Fabio Checconi, Kristof Du Bois, Stijn Eyerman, Joshua B. Fryman, Wim Heirman, Jason Howard, Ibrahim Hur, Samkit Jain, Marek M. Landowski, Kevin Ma, Jarrod A. Nelson, Robert Pawlowski, Fabrizio Petrini, Sebastian Szkoda, Sanjaya Tayal, Jesmin Jahan Tithi, and Yves Vandriessche. 2023. The intel programmable and integrated unified memory architecture graph analytics processor. IEEE Micro 43, 5 (Sept.2023), 78–87. DOI:Conference Name: IEEE Micro.
[9]
Mehdi Alipour, Rakesh Kumar, Stefanos Kaxiras, and David Black-Schaffer. 2019. FIFOrder MicroArchitecture: Ready-aware instruction scheduling for OoO processors. In 2019 Design, Automation & Test in Europe Conference & Exhibition (DATE’19). 716–721. DOI:
[10]
Krste Asanović, Rimas Avizienis, Jonathan Bachrach, Scott Beamer, David Biancolin, Christopher Celio, Henry Cook, Daniel Dabbelt, John Hauser, Adam Izraelevitz, Sagar Karandikar, Ben Keller, Donggyu Kim, John Koenig, Yunsup Lee, Eric Love, Martin Maas, Albert Magyar, Howard Mao, Miquel Moreto, Albert Ou, David A. Patterson, Brian Richards, Colin Schmidt, Stephen Twigg, Huy Vo, and Andrew Waterman. 2016. The Rocket Chip Generator. Technical Report UCB/EECS-2016-17. EECS Department, University of California, Berkeley. Retrieved from http://www2.eecs.berkeley.edu/Pubs/TechRpts/2016/EECS-2016-17.html
[11]
Mikhail Asiatici and Paolo Ienne. 2019. Stop crying over your cache miss rate: Handling efficiently thousands of outstanding misses in fpgas. In Proceedings of the 2019 ACM/SIGDA International Symposium on Field-Programmable Gate Arrays. 310–319.
[12]
David H. Bailey, Eric Barszcz, John T. Barton, David S. Browning, Robert L. Carter, Leonardo Dagum, Rod A. Fatoohi, Paul O. Frederickson, Thomas A. Lasinski, Rob S. Schreiber, et al. 1991. The NAS parallel benchmarks summary and preliminary results. In Supercomputing’91: Proceedings of the 1991 ACM/IEEE Conference on Supercomputing. IEEE, 158–165.
[13]
M. Bakhshalipour, P. Lotfi-Kamran, and H. Sarbazi-Azad. 2018. Domino temporal data prefetcher. In 2018 IEEE International Symposium on High Performance Computer Architecture (HPCA’18). 131–142. DOI:
[14]
M. Bakhshalipour, M. Shakerinava, P. Lotfi-Kamran, and H. Sarbazi-Azad. 2019. Bingo spatial data prefetcher. In 2019 IEEE International Symposium on High Performance Computer Architecture (HPCA’19). 399–411. DOI:
[15]
Cagri Balkesen, Jens Teubner, Gustavo Alonso, and M. Tamer Özsu. 2013. Main-memory hash joins on multi-core CPUs: Tuning to the underlying hardware. In 2013 IEEE 29th International Conference on Data Engineering (ICDE’13). IEEE, 362–373.
[16]
Shimin Chen, Anastassia Ailamaki, Phillip B. Gibbons, and Todd C. Mowry. 2007. Improving hash join performance through prefetching. ACM Transactions on Database Systems (TODS) 32, 3 (2007), 17–es.
[17]
J. Corbal, R. Espasa, and M. Valero. 1998. Command vector memory systems: High performance at low cost. In Proceedings. 1998 International Conference on Parallel Architectures and Compilation Techniques. 68–77. DOI:
[18]
Tudor David, Rachid Guerraoui, and Vasileios Trigonakis. 2015. Asynchronized concurrency: The secret to scaling concurrent search data structures. In Proceedings of the Twentieth International Conference on Architectural Support for Programming Languages and Operating Systems (ASPLOS’15). Association for Computing Machinery, New York, NY, 631–644. DOI:
[19]
Andreas Diavastos and Trevor E. Carlson. 2022. Efficient instruction scheduling using real-time load delay tracking. ACM Transactions on Computer Systems 40, 1-4 (Nov.2022), 1:1–1:21. DOI:
[20]
Babak Falsafi and Thomas F. Wenisch. 2014. A primer on hardware prefetching. Synthesis Lectures on Computer Architecture 9, 1 (May2014), 1–67. DOI:Publisher: Morgan & Claypool Publishers.
[21]
Dongrui Fan, Wenming Li, Xiaochun Ye, Da Wang, Hao Zhang, Zhimin Tang, and Ninghui Sun. 2018. Smarco: An efficient many-core processor for high-throughput applications in datacenters. In 2018 IEEE International Symposium on High Performance Computer Architecture (HPCA’18). IEEE, 596–607.
[22]
Viacheslav Fedorov, Jinchun Kim, Mian Qin, Paul V. Gratz, and A. L. Narasimha Reddy. 2017. Speculative paging for future NVM storage. In Proceedings of the International Symposium on Memory Systems (MEMSYS’17). Association for Computing Machinery, New York, NY, USA, 399–410. DOI:
[23]
Josué Feliu, Ajeya Naithani, Julio Sahuquillo, Salvador Petit, Moinuddin Qureshi, and Lieven Eeckhout. 2022. VMT: Virtualized multi-threading for accelerating graph workloads on commodity processors. IEEE Trans. Comput. 71, 6 (June2022), 1386–1398. DOI:Conference Name: IEEE Transactions on Computers.
[24]
John Feo, David Harper, Simon Kahan, and Petr Konecny. 2005. ELDORADO. In Proceedings of the 2nd Conference on Computing Frontiers (CF’05). Association for Computing Machinery, New York, NY, 28–34. DOI:
[25]
Haohuan Fu, Junfeng Liao, Jinzhe Yang, Lanning Wang, Zhenya Song, Xiaomeng Huang, Chao Yang, Wei Xue, Fangfang Liu, Fangli Qiao, Wei Zhao, Xunqiang Yin, Chaofeng Hou, Chenglong Zhang, Wei Ge, Jian Zhang, Yangang Wang, Chunbo Zhou, and Yang Guangwen. 2016. The Sunway TaihuLight supercomputer: system and applications. Science China Information Sciences 59, 7 (2016), 1–16.
[26]
N. Hajinazar, P. Patel, M. Patel, K. Kanellopoulos, S. Ghose, R. Ausavarungnirun, G. F. Oliveira, J. Appavoo, V. Seshadri, and O. Mutlu. 2020. The virtual block interface: A flexible alternative to the conventional virtual memory framework. In 2020 ACM/IEEE 47th Annual International Symposium on Computer Architecture (ISCA’20). 1050–1063. DOI:
[27]
Milad Hashemi and Yale N. Patt. 2015. Filtered runahead execution with a runahead buffer. In 2015 48th Annual IEEE/ACM International Symposium on Microarchitecture (MICRO’15). 358–369. DOI:
[28]
Maurice Herlihy and Nir Shavit. 2012. The Art of Multiprocessor Programming, Revised First Edition. Morgan Kaufmann.
[29]
R. Huang, A. Garg, and M. Huang. 2006. Software-hardware cooperative memory disambiguation. In The Twelfth International Symposium on High-Performance Computer Architecture, 2006.244–253. DOI:ISSN: 2378-203X.
[30]
Yasuo Ishii, Mary Inaba, and Kei Hiraki. 2009. Access map pattern matching for data cache prefetch. In Proceedings of the 23rd International Conference on Supercomputing (ICS’09). ACM, New York, NY, 499–500. DOI:
[31]
N. Kirman, M. Kirman, M. Chaudhuri, and J. F. Martinez. 2005. Checkpointed early load retirement. In 11th International Symposium on High-Performance Computer Architecture. 16–27. showISSN2378-203X DOI:
[32]
Onur Kocberber, Babak Falsafi, and Boris Grot. 2015. Asynchronous memory access chaining. Proceedings of the VLDB Endowment 9, 4 (2015), 252–263.
[33]
S. Koh, C. Lee, M. Kwon, and M. Jung. 2018. Exploring system challenges of ultra-low latency solid state drives. In USENIX Annual Technical Conference.
[34]
Miryeong Kwon, Sangwon Lee, and Myoungsoo Jung. 2023. Cache in hand: Expander-driven CXL prefetcher for next generation CXL-SSD. In Proceedings of the 15th ACM Workshop on Hot Topics in Storage and File Systems (HotStorage’23). Association for Computing Machinery, New York, NY, 24–30. DOI:
[35]
Emre Kültürsay, Mahmut Kandemir, Anand Sivasubramaniam, and Onur Mutlu. 2013. Evaluating STT-RAM as an energy-efficient main memory alternative. In 2013 IEEE International Symposium on Performance Analysis of Systems and Software (ISPASS’13). 256–267. DOI:
[36]
Andres Lagar-Cavilla, Junwhan Ahn, Suleiman Souhlal, Neha Agarwal, Radoslaw Burny, Shakeel Butt, Jichuan Chang, Ashwin Chaugule, Nan Deng, Junaid Shahid, Greg Thelen, Kamil Adam Yurtsever, Yu Zhao, and Parthasarathy Ranganathan. 2019. Software-defined far memory in warehouse-scale computers. In Proceedings of the Twenty-Fourth International Conference on Architectural Support for Programming Languages and Operating Systems (Providence, RI, USA) (ASPLOS’19). Association for Computing Machinery, New York, NY, USA, 317–330.
[37]
Jaekyu Lee, Hyesoon Kim, and Richard Vuduc. 2012. When prefetching works, when it doesn’T, and why. ACM Trans. Archit. Code Optim. 9, 1 (March2012), 2:1–2:29. DOI:
[38]
Seok-Hee Lee. 2016. Technology scaling challenges and opportunities of memory devices. In 2016 IEEE International Electron Devices Meeting (IEDM’16). 1.1.1–1.1.8. DOI:
[39]
Yejin Lee, Seong Hoon Seo, Hyunji Choi, Hyoung Uk Sul, Soosung Kim, Jae W. Lee, and Tae Jun Ham. 2021. MERCI: Efficient embedding reduction on commodity hardware via sub-query memoization. In Proceedings of the 26th ACM International Conference on Architectural Support for Programming Languages and Operating Systems (ASPLOS’21). Association for Computing Machinery, New York, NY, 302–313. DOI:
[40]
Huaicheng Li, Daniel S. Berger, Stanko Novakovic, Lisa Hsu, Dan Ernst, Pantea Zardoshti, Monish Shah, Samir Rajadnya, Scott Lee, Ishwar Agarwal, Mark D. Hill, Marcus Fontoura, and Ricardo Bianchini. 2022. Pond: CXL-Based Memory Pooling Systems for Cloud Platforms. (Oct.2022). DOI:arXiv:2203.00241 [cs].
[41]
Haifeng Li, Ke Liu, Ting Liang, Zuojun Li, Tianyue Lu, Hui Yuan, Yinben Xia, Yungang Bao, Mingyu Chen, and Yizhou Shan. 2023. HoPP: Hardware-software co-designed page prefetching for disaggregated memory. In 2023 IEEE International Symposium on High-Performance Computer Architecture (HPCA’23). 1168–1181. DOI:
[42]
Sheng Li, Jung Ho Ahn, Richard D. Strong, Jay B. Brockman, Dean M. Tullsen, and Norman P. Jouppi. 2009. McPAT: An integrated power, area, and timing modeling framework for multicore and manycore architectures. In 2009 42nd Annual IEEE/ACM International Symposium on Microarchitecture (MICRO). 469–480.
[43]
Ankur Limaye and Tosiron Adegbija. 2018. A workload characterization of the SPEC CPU2017 benchmark suite. In 2018 IEEE International Symposium on Performance Analysis of Systems and Software (ISPASS’18). 149–158. DOI:
[44]
Heiner Litz, Grant Ayers, and Parthasarathy Ranganathan. 2022. CRISP: Critical slice prefetching. In Proceedings of the 27th ACM International Conference on Architectural Support for Programming Languages and Operating Systems (ASPLOS’22). Association for Computing Machinery, New York, NY, 300–313. DOI:
[45]
Haikun Liu, Renshan Liu, Xiaofei Liao, Hai Jin, Bingsheng He, and Yu Zhang. 2020. Object-level memory allocation and migration in hybrid memory systems. IEEE Trans. Comput. 69, 9 (2020), 1401–1413. DOI:
[46]
Hai-Kun Liu, Di Chen, Hai Jin, Xiao-Fei Liao, Binsheng He, Kan Hu, and Yu Zhang. 2021. A survey of non-volatile main memory technologies: State-of-the-arts, practices, and future directions. Journal of Computer Science and Technology 36, 1 (Jan.2021), 4–32. DOI:
[47]
Jason Lowe-Power, Abdul Mutaal Ahmad, Ayaz Akram, Mohammad Alian, Rico Amslinger, Matteo Andreozzi, Adrià Armejach, Nils Asmussen, Brad Beckmann, Srikant Bharadwaj, Gabe Black, Gedare Bloom, Bobby R. Bruce, Daniel Rodrigues Carvalho, Jeronimo Castrillon, Lizhong Chen, Nicolas Derumigny, Stephan Diestelhorst, Wendy Elsasser, Carlos Escuin, Marjan Fariborz, Amin Farmahini-Farahani, Pouya Fotouhi, Ryan Gambord, Jayneel Gandhi, Dibakar Gope, Thomas Grass, Anthony Gutierrez, Bagus Hanindhito, Andreas Hansson, Swapnil Haria, Austin Harris, Timothy Hayes, Adrian Herrera, Matthew Horsnell, Syed Ali Raza Jafri, Radhika Jagtap, Hanhwi Jang, Reiley Jeyapaul, Timothy M. Jones, Matthias Jung, Subash Kannoth, Hamidreza Khaleghzadeh, Yuetsu Kodama, Tushar Krishna, Tommaso Marinelli, Christian Menard, Andrea Mondelli, Miquel Moreto, Tiago Mück, Omar Naji, Krishnendra Nathella, Hoa Nguyen, Nikos Nikoleris, Lena E. Olson, Marc Orr, Binh Pham, Pablo Prieto, Trivikram Reddy, Alec Roelke, Mahyar Samani, Andreas Sandberg, Javier Setoain, Boris Shingarov, Matthew D. Sinclair, Tuan Ta, Rahul Thakur, Giacomo Travaglini, Michael Upton, Nilay Vaish, Ilias Vougioukas, William Wang, Zhengrong Wang, Norbert Wehn, Christian Weis, David A. Wood, Hongil Yoon, and Éder F. Zulian. 2020. The gem5 Simulator: Version 20.0+. arXiv:2007.0315.
[48]
P. Michaud. 2016. Best-offset hardware prefetching. In 2016 IEEE International Symposium on High Performance Computer Architecture (HPCA’16). 469–480. DOI:
[49]
Alessandro Morari, Antonino Tumeo, Daniel Chavarría-Miranda, Oreste Villa, and Mateo Valero. 2014. Scaling irregular applications through data aggregation and software multithreading. In 2014 IEEE 28th International Parallel and Distributed Processing Symposium. 1126–1135. DOI:ISSN: 1530-2075.
[50]
O. Mutlu, J. Stark, C. Wilkerson, and Y. N. Patt. 2003. Runahead execution: An effective alternative to large instruction windows. IEEE Micro 23, 6 (2003), 20–25. DOI:
[51]
Ajeya Naithani, Sam Ainsworth, Timothy M. Jones, and Lieven Eeckhout. 2021. Vector runahead. In 2021 ACM/IEEE 48th Annual International Symposium on Computer Architecture (ISCA’21). 195–208. DOI:
[52]
Ajeya Naithani, Josué Feliu, Almutaz Adileh, and Lieven Eeckhout. 2020. Precise runahead execution. In 2020 IEEE International Symposium on High Performance Computer Architecture (HPCA’20). 397–410. DOI:
[53]
Ajeya Naithani, Jaime Roelandts, Sam Ainsworth, Timothy M. Jones, and Lieven Eeckhout. 2023. Decoupled vector runahead. In 2023 56rd Annual IEEE/ACM International Symposium on Microarchitecture (MICRO’23).
[54]
Jacob Nelson, Brandon Holt, Brandon Myers, Preston Briggs, Luis Ceze, Simon Kahan, and Mark Oskin. 2015. {Latency-Tolerant} software distributed shared memory. 291–305. Retrieved fromhttps://www.usenix.org/conference/atc15/technical-session/presentation/nelson
[55]
Marcelo Orenes-Vera, Aninda Manocha, Jonathan Balkind, Fei Gao, Juan L. Aragón, David Wentzlaff, and Margaret Martonosi. 2022. Tiny but mighty: Designing and realizing scalable latency tolerance for manycore SoCs. In Proceedings of the 49th Annual International Symposium on Computer Architecture (ISCA’22). Association for Computing Machinery, New York, NY, 817–830. DOI:
[56]
Davide Pala. 2016-2017. Design and programming of a coprocessor for a RISC-V architecture. Master’s Thesis. POLITECNICO DI TORINO.
[57]
Haiyang Pan, Yuhang Liu, Tianyue Lu, and Mingyu Chen. 2021. LSP: Collective cross-page prefetching for NVM. In 2021 Design, Automation & Test in Europe Conference & Exhibition (DATE’21). 501–506. DOI:
[58]
Moinuddin K. Qureshi, Vijayalakshmi Srinivasan, and Jude A. Rivers. 2009. Scalable high performance main memory system using phase-change memory technology. SIGARCH Comput. Archit. News 37, 3 (jun2009), 24–33. DOI:
[59]
Reza Salkhordeh and Hossein Asadi. 2016. An operating system level data migration scheme in hybrid DRAM-NVM memory architecture. In 2016 Design, Automation & Test in Europe Conference & Exhibition (DATE’16). 936–941.
[60]
Debendra Das Sharma. 2022. Compute express link®: An open industry-standard interconnect enabling heterogeneous data-centric computing. In 2022 IEEE Symposium on High-Performance Interconnects (HOTI’22). 5–12. DOI:
[61]
Srikanth T. Srinivasan, Ravi Rajwar, Haitham Akkary, Amit Gandhi, and Michael Upton. 2004. Continual flow pipelines: Achieving resource-efficient latency tolerance. IEEE Micro 24, 6 (2004), 62–73.
[62]
Kim-Anh Tran, Trevor E. Carlson, Konstantinos Koukos, Magnus Själander, Vasileios Spiliopoulos, Stefanos Kaxiras, and Alexandra Jimborean. 2017. Clairvoyance: Look-ahead compile-time scheduling. In 2017 IEEE/ACM International Symposium on Code Generation and Optimization (CGO’17). 171–184. DOI:
[63]
Kim-Anh Tran, Alexandra Jimborean, Trevor E. Carlson, Konstantinos Koukos, Magnus Själander, and Stefanos Kaxiras. 2018. SWOOP: Software-hardware co-design for non-speculative, execute-ahead, in-order cores. In Proceedings of the 39th ACM SIGPLAN Conference on Programming Language Design and Implementation (PLDI’18). Association for Computing Machinery, New York, NY, 328–343. DOI:
[64]
James Tuck, Luis Ceze, and Josep Torrellas. 2006. Scalable cache miss handling for high memory-level parallelism. In 2006 39th Annual IEEE/ACM International Symposium on Microarchitecture (MICRO’06). IEEE, 409–422.
[65]
Luming Wang, Xu Zhang, Tianyue Lu, and Mingyu Chen. 2022. Asynchronous memory access unit for general purpose processors. BenchCouncil Transactions on Benchmarks, Standards and Evaluations 2, 2 (2022), 100061. DOI:
[66]
Songyue Wang, Luming Wang, Tianyue Lu, and Mingyu Chen. 2022. Architecture and RISC-V ISA extension supporting asynchronous and flexible parallel far memory access. In Sixth Workshop on Computer Architecture Research with RISC-V (CARRV’22).
[67]
Fei Wen, Mian Qin, Paul Gratz, and Narasimha Reddy. 2021. OpenMem: Hardware/software cooperative management for mobile memory system. In 2021 58th ACM/IEEE Design Automation Conference (DAC’21). 109–114. DOI:
[68]
Fei Wen, Mian Qin, Paul Gratz, and Narasimha Reddy. 2022. Software hint-driven data management for hybrid memory in mobile systems. ACM Trans. Embed. Comput. Syst. 21, 1, Article 8 (jan 2022), 18 pages. DOI:
[69]
Fei Wen, Mian Qin, Paul V. Gratz, and A. L. Narasimha Reddy. 2020. Hardware memory management for future mobile hybrid memory systems. IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems 39, 11 (2020), 3627–3637. DOI:
[70]
Yinan Xu, Zihao Yu, Dan Tang, Guokai Chen, Lu Chen, Lingrui Gou, Yue Jin, Qianruo Li, Xin Li, Zuojun Li, Jiawei Lin, Tong Liu, Zhigang Liu, Jiazhan Tan, Huaqiang Wang, Huizhe Wang, Kaifan Wang, Chuanqi Zhang, Fawang Zhang, Linjuan Zhang, Zifei Zhang, Yangyang Zhao, Yaoyang Zhou, Yike Zhou, Jiangrui Zou, Ye Cai, Dandan Huan, Zusong Li, Jiye Zhao, Zihao Chen, Wei He, Qiyuan Quan, Xingwu Liu, Sa Wang, Kan Shi, Ninghui Sun, and Yungang Bao. 2022. Towards developing high performance RISC-V processors using agile methodology. In 2022 55th IEEE/ACM International Symposium on Microarchitecture (MICRO’22). 1178–1199. DOI:
[71]
Xiangyao Yu, Christopher J. Hughes, Nadathur Satish, and Srinivas Devadas. 2015. IMP: Indirect memory prefetcher. In Proceedings of the 48th International Symposium on Microarchitecture (MICRO-48). ACM, New York, NY, 178–190.
[72]
Yunming Zhang, Vladimir Kiriansky, Charith Mendis, Saman Amarasinghe, and Matei Zaharia. 2017. Making caches work for graph analytics. In 2017 IEEE International Conference on Big Data (Big Data). 293–302. DOI:
[73]
Weirong Zhu, Vugranam C. Sreedhar, Ziang Hu, and Guang R. Gao. 2007. Synchronization state buffer: Supporting efficient fine-grain synchronization on many-core architectures. In Proceedings of the 34th Annual International Symposium on Computer Architecture (ISCA’07). Association for Computing Machinery, New York, NY, 35–45. DOI:
[74]
Li-Cheng Chen, Ming-Yu Chen, Yuan Ruan, Yong-Bing Huang, Ze-Han Cui, Tian-Yue Lu, and Yun-Gang Bao. 2014. MIMS: Towards a message interface based memory system. Journal of Computer Science and Technology 29, 2 (March 2014), 255–272.

Cited By

View all
  • (2024)Yggdrasil: Reducing Network I/O Tax with (CXL-Based) Distributed Shared MemoryProceedings of the 53rd International Conference on Parallel Processing10.1145/3673038.3673138(597-606)Online publication date: 12-Aug-2024
  • (2024)Scythe: A Low-latency RDMA-enabled Distributed Transaction System for Disaggregated MemoryACM Transactions on Architecture and Code Optimization10.1145/366600421:3(1-26)Online publication date: 27-May-2024

Index Terms

  1. Asynchronous Memory Access Unit: Exploiting Massive Parallelism for Far Memory Access

      Recommendations

      Comments

      Please enable JavaScript to view thecomments powered by Disqus.

      Information & Contributors

      Information

      Published In

      cover image ACM Transactions on Architecture and Code Optimization
      ACM Transactions on Architecture and Code Optimization  Volume 21, Issue 3
      September 2024
      592 pages
      EISSN:1544-3973
      DOI:10.1145/3613629
      Issue’s Table of Contents

      Publisher

      Association for Computing Machinery

      New York, NY, United States

      Publication History

      Published: 14 September 2024
      Online AM: 09 May 2024
      Accepted: 15 April 2024
      Revised: 11 April 2024
      Received: 04 December 2023
      Published in TACO Volume 21, Issue 3

      Check for updates

      Author Tags

      1. Asynchronous memory access
      2. memory-level parallelism
      3. far memory

      Qualifiers

      • Research-article

      Funding Sources

      • National Key Research and Development Program of China NKRDPC

      Contributors

      Other Metrics

      Bibliometrics & Citations

      Bibliometrics

      Article Metrics

      • Downloads (Last 12 months)1,039
      • Downloads (Last 6 weeks)389
      Reflects downloads up to 12 Dec 2024

      Other Metrics

      Citations

      Cited By

      View all
      • (2024)Yggdrasil: Reducing Network I/O Tax with (CXL-Based) Distributed Shared MemoryProceedings of the 53rd International Conference on Parallel Processing10.1145/3673038.3673138(597-606)Online publication date: 12-Aug-2024
      • (2024)Scythe: A Low-latency RDMA-enabled Distributed Transaction System for Disaggregated MemoryACM Transactions on Architecture and Code Optimization10.1145/366600421:3(1-26)Online publication date: 27-May-2024

      View Options

      View options

      PDF

      View or Download as a PDF file.

      PDF

      eReader

      View online with eReader.

      eReader

      Login options

      Full Access

      Media

      Figures

      Other

      Tables

      Share

      Share

      Share this Publication link

      Share on social media