# UDON: A case for offloading to general purpose compute on CXL memory

Jon Hermes, Josh Minor Arm Texas, USA Minjun Wu Arm Texas, USA Adarsh Patil Arm Cambridge, UK Eric Van Hensbergen Arm Texas, USA

## ABSTRACT

Upcoming CXL-based disaggregated memory devices feature special purpose units to offload compute to near-memory. In this paper, we explore opportunities for offloading compute to general purpose cores on CXL memory devices, thereby enabling a greater utility and diversity of offload.

We study two classes of popular memory intensive applications: ML inference and vector database as candidates for computational offload. The study uses Arm AArch64-based dual-socket NUMA systems to emulate CXL type-2 devices.

Our study shows promising results. With our ML inference model partitioning strategy for compute offload, we can place up to 90% data in remote memory with just 20% performance trade-off. Offloading Hierarchical Navigable Small World (HNSW) kernels in vector databases can provide up to 6.87× performance improvement with under 10% offload overhead.

## **KEYWORDS**

Disaggregated Memory, CXL, Near-memory computational offload

## **1** INTRODUCTION

System disaggregation has been a major trend in datacenters, motivated by reasons of cost, capacity, power, and performance. Steadily over the last few years, there has been a marked migration from homogeneous systems toward dedicated compute, memory, storage, and network nodes. A recurring pattern in this disaggregation is the placement of compute away from one centralized cluster of cores and onto more disparate devices like Computational Storage Devices, SmartNICs, Data Processing Units.

We observe a new kind of device being created for memory disaggregation using the Compute eXpress Link (CXL) [1]. CXL is a standardized memory interconnect protocol for communicating between the host and a disaggregated memory device. CXL devices provide cache-coherent memory expansion, acting as a drop-in solution to continue to meet memory demand. The decoupling of memory with this architecture provides independent and flexible scaling of memory resources. It also avoids "memory stranding" from individual machines [2]. Compute capacity is now being placed on these CXL memory devices [3, 4] to offload functions to near-memory. These novel devices are the focus of this work.

The trade-off of CXL memory. CXL memory provides high capacity with independent memory controllers and busses to DDR/HBM memory modules. Several modern applications with large memory footprints greatly benefit from such devices. Being able to operate on larger datasets stored in memory enables new applications.

The adverse effect of CXL memory is the imposition of memory latency and bandwidth penalty for accessing "far" memory. CXL memory provides lower memory bandwidth than host attached local memory. In addition, traversing the CXL interconnect introduces latency for memory access. The compute cores must wait for the data to be fetched from the memory device to operate on it.

For some applications, this trade-off is acceptable, but others are overly harmed by this trade-off. We expect applications with pointer chasing functions, parallel operations, or sparse memory to incur performance penalties. However, the exact affected functions may not be known a priori. How to intelligently offload functions/operations harmed by far CXL memory needs to be addressed. **The ubiquity of Arm cores in CXL memory.** Current CXL memory expander (type-3) devices have compute units on both data and control planes. Data plane controllers comprise memory controllers, queues, flit (un)packing [5], and can also include specialized units for specific functions like load balancing, multiply and accumulate [4], and persistence operations [6]. Control plane compute units provide management/metadata operations like protocol negotiation, system metrics, and allocation requests. These are typically run in software over general-purpose Arm based SoCs [7].

This control plane compute is invisible to the applications that use the CXL memory devices. This work envisages that these control plane general-purpose cores can be used to offload memory sensitive operations of a workload. Performance is improved by virtue of co-locating these operations with their data, "near-memory". By employing compute on device for application offload, we upgrade an elementary CXL type-3 device to an intelligent type-2 device. Benefits of general purpose offload. Using general purpose cores for offloading lowers TCO, compared to designing special purpose accelerators. Architectures like the Arm Cortex-A and Neoverse family of cores provide power-efficient operation and can be adapted for compute offloading on CXL memory. It offers a stable architecture and a mature compiler/software tool chain. This strategy provides an easier path to computational CXL-memory and allows the recovery of lost performance when deploying applications on systems with disaggregated memory.

**Goals:** This work is not attempting to define new kinds of CXL memory devices. Instead, we are trying to gauge the extent and limits of existing hardware to accelerate functions on the CXL device. Secondly, we aim to understand how software is moved across disaggregated system designs. We believe this analysis is a critical first-step to understanding future CXL system requirements.

## **Contributions:**

- We motivate a novel strategy to accelerate workloads by offloading to general-purpose cores in CXL memory devices.
- We characterize two important datacenter workloads and identify functions within them that are good candidates for offload to computational cores in CXL-memory.

• We evaluate the *potential of performance improvement by offload* on cloud native Arm architecture server platforms.

## 2 BACKGROUND AND MOTIVATION

**Standardized disaggregation phenomenon.** The industry has realized the need for a standardized method of memory disaggregation, which has now come in the form of the CXL consortium. CXL lays the foundation for this by defining a common interconnect protocol to attach processors (hosts) to memory devices. CXL runs over PCIe PHY and provides three protocols serving different purposes (CXL.cache, CXL.io, and CXL.mem) [8]. In particular, CXL.mem protocol is specialized for memory expansion, called CXL type-3 devices. Several such devices employing various DRAM technologies (DRAM/HBM) are slowly becoming available [9, 10]. Major CPU vendors are also supporting CXL in their next generation products [11–14].

**Upcoming CXL memory devices with data plane compute.** CXL also opens the possibility of processing data near the memory. These value added memory devices with compute (called CXL type-2 devices) improve performance by virtue of (a) proximity to data (higher bandwidth, lower latency access to memory) (b) independence from host processor constraints (c) efficient compute/caching. Memory manufacturers have already prototyped CXL memory with specialized compute to accelerate specific functions [4, 6]. However, these designs have limited potential for general purpose offload.

## 2.1 Machine learning inference

A large body of work exists on machine learning algorithms, but there are only a few dominant software frameworks used to train and execute ML models, including TensorFlow[15] and PyTorch[16]. The frameworks use various libraries to run the tensor operations (layers) which comprise a model, each with their own unique performance characteristics on a given set of hardware.

ML workloads are generally presented in the form of a Directed Acyclic Graph (DAG), where each node in the graph represents an operation (layer) and edges represent the data dependencies between operations in the form of tensors. Each operation computes a result based on the input tensor(s) and weights, and writes the result to an output buffer, consumed by the next operation.

> **Offload opportunity:** Firstly, given the DAG structure, ML acts as a good vehicle for function offload analysis. Secondly, the sequential function execution behavior and its predictable/repeatable performance for a fixed input size, implies that the end-to-end performance remains relatively consistent for profiling analysis.

### 2.2 Vector databases

Vector databases store and maintain high-dimensional vectors from structured and unstructured data (i.e. text, images), generated by applying a transformation or embedding function. These high dimensional vectors serve as the data's numerical representation that capture the original data object's semantic meaning. Embedding functions take many forms including ML models, word embeddings, and feature extraction algorithms.

Given a large embedding vector dataset, vector databases also provide fast and accurate similarity search. The distance of two embedded vectors implies their semantic similarity. As traditional distance calculation is expensive, vector databases use vector indexing to pre-calculate these distances to enable faster retrieval at query time. Vector databases find utility across different applications including natural language processing (NLP), computer vision, recommendation systems, and more recently, in Large Language Models (LLM) and Generative AI (GenAI) [17].

> Offload opportunity: The kernels that we explore for offloading are (a) Indexing, to pre-compute vector distances, and (b) Query, to return all elements that are within a given radius of a vector point. Various algorithms have been proposed for efficient vector distance calculation and similarity search. We uses the popular Hierarchical Navigable Small World graphs (HNSW) [18] and Navigating Spreading-out Graph [19] algorithms for the above operations.

## 3 EVALUATION METHODOLOGY

**Evaluation system.** With most CXL devices still being in development or otherwise unavailable, our evaluation strategy is based on emulation of CXL attached systems using remote NUMA memory accesses (similar to prior work [2, 20, 21]). Uniquely, our evaluation uses Arm Aarch64 dual-socket cloud native servers, namely, Platform A (56 cores, 256GB mem) and Platform B (160 cores, 512GB mem). We drop the frequency of the remote socket in some experiments to emulate lower capability remote cores as in CXL devices. Both systems run Ubuntu 22.04 server, Linux kernel 5.15.

Table 1 shows the maximum profiled memory bandwidth and latency characteristics of the servers. Upcoming CXL memory expansion modules are reported to offer bandwidths of 30-40 GB/s [9] making these NUMA systems representative of the memory access characteristics of a true CXL memory device.

| Bandwidth (GB/s)        | Platform A |        | Platform B |        |
|-------------------------|------------|--------|------------|--------|
| Benchmark               | Local      | Remote | Local      | Remote |
| СОРҮ                    | 103        | 32     | 161        | 28     |
| SCALE                   | 109        | 32     | 165        | 29     |
| ADD                     | 96         | 32     | 167        | 27     |
| TRIAD                   | 104        | 32     | 168        | 27     |
| Single random read (ns) | 70.4       | 127.8  | 73.0       | 403.5  |

Table 1: Memory bandwidth and latency characterization.Latency - tinymembench [22], bandwidth - STREAM [23]

**Workload analysis methodology.** We employ two levels of analysis to characterize workloads and identify offload candidates. > *Coarse-grain analysis:* We use the *numactl* tool for quick, coarse profiling of the memory sensitivity of the workload. This analysis modifies placement of memory on local or remote NUMA memory,

without modifying program source. > *Fine-grain analysis:* To gather more information and ascertain regions of code that would be good candidates for offload, we instrument applications using the PAPI framework [24]. PAPI allows us to time regions of code, understand memory performance and more, all with little overhead. Once a suitable function is identified, we then insert custom logic to evaluate the function offload performance on the CXL device. For this, we either migrate threads programmatically ahead of executing a function (for ML inference), or leverage two separate processes running on each socket (for VectorDB).

## 4 EVALUATION RESULTS

#### 4.1 Machine learning characterization

We explore PyTorch and TensorFlow Lite (TFLite) with varying levels of rigor to evaluate offload performance opportunity.

### 4.1.1 PyTorch framework.

> Coarse-grain: We evaluate the memory sensitivity of the models in PyTorch benchmark repository [25] compiled with support for the Arm Compute Library (ACL) through OneDNN. We compare average inference latency of approximately 50 models using 3 available runtimes (Eager, TorchScript, TorchDynamo) with default batch sizes and all program data allocated either local or remote.



Relative Inference Latency Slowdown of Data Remote vs Local

### Figure 1: PyTorch inference latency slowdown histogram.

As shown in Figure 1, platform A has marginal degradation of inference performance across all runtimes, ranging up to 1.5x. However, on platform B, with nearly approaching the available DRAM memory bandwidth and double the cross socket memory latency between local and remote to platform A, we see intolerable slowdowns, ranging from 2-6X (up-to 9X for eager runtime) for the same workloads. This highlights the performance left on the table which may be recaptured through intelligent compute offload mechanisms.

#### 4.1.2 TFLite framework.

> Coarse-grain: In addition to all local and all remote data, for TFLite's runtime, we introduce two additional memory placement policies, RESULT\_REMOTE and WEIGHT\_REMOTE. TFLite has two primary types of tensors in its runtime: (1) kTfLiteMmapRo (Weights) (2) kTfLiteArenaRw (Intermediate results). We aim determine the relative importance of placement for these data structures for each model. We can place weights and intermediate tensors on appropriate NUMA nodes using libnuma and hence create the more granular memory placement policies. In RESULT\_REMOTE, the entire heap and stack of the process is placed in far memory, and the weights are explicitly moved back to the local memory.

We evaluated 27 TFLite models, sampling from a variety of model architectures, including transformers, convolutional neural networks (CNNs), and recurrent neural networks (RNNs). Each model is run using both 8 and 16 threads atop three TFLite runtimes the default (with RUY), and the CPU accelerated ArmNN and XN-NPACK.

Figure 2 shows significant 2-8X slowdown on platform B. We note a larger proportion of greater slowdowns for accelerated runtimes ArmNN and XNNPACK due to improvement in computational efficiency, thereby creating a larger memory bottleneck. With our additional placement policies, we see that the primary slowdown for these TFLite models comes from the placement of intermediate result tensors, highlighting the importance of intelligent placement of memory in the correct tier of DRAM. Notably, there is a lack of sensitivity to the weight placement of almost all models.



Figure 2: Platform B TFLite inference latency slowdown histogram comparing NUMA memory policies and runtimes.

> *Fine-grain:* Given the sensitivity to the placement of intermediate results across TFLite models, we propose a model partitioning scheme. The design seeks to intelligently distribute the model's compute and memory across a host and CXL device, given an objective function. We consider a multi-objective cost function balancing both minimizing placement of data on expensive host DRAM and model inference latency, represented with a weighted sum cost function. In this work we slow the clock for the far cores from 3GHz to 2GHz to simulate having lesser compute available on the remote side. Intuitively, we expect that although the far-cores run at a lower frequency, for memory-bound kernels, co-location with their data on the far side will recover losses in latency induced by memory stalls.

For a given model, the partitioner selects (local or remote) the placement of weights, and for every operation, the placement of the intermediate buffers. To evaluate the compute offload effectiveness to lesser cores on the far-memory side, the partitioner may also select whether each operation runs on the host or device (far) side.

An offline, linear-runtime, partitioning algorithm is devised in this work. First, a profiling step to generate a performance lookup table which gives for every operation and its placement of weights, intermediate buffers, and compute, a corresponding latency value. With the lookup table generated, given a weighting of preference for minimizing latency or host-data placement, we select the configuration for each operation which minimizes our cost function. Because the tensor dependencies between successive operations in the DAG, this may result in conflicting selections of local or remote. In a conflict resolution step, for each conflicting tensor, we consider the cost of placing the tensor local or remote, by summing the cost of all nodes which depend on the tensor of interest, and converge on the placement which minimizes this local neighborhood cost.

Figure 3 shows for the models in our test set with over 1GB combined memory footprint (weights and intermediate tensors), the relative latency to running entirely locally on the host device. We see that for the majority of the models, the partitioner is able to offload the vast majority of the models data to remote memory, while only sacrificing 20% degradation of latency.



Figure 3: Mem offload to latency slowdown on platform B.

**Overall Summary:** Our study notes significant slowdowns for ML inference runtimes across all models, on both platforms<sup>1</sup>. We observe that some of this performance can be recovered via precise memory placement combined with function-level compute offload.

#### 4.2 Vector database characterization

We use the Facebook AI Similarity Search (FAISS) [26] library to explore and prototype offloading opportunities. FAISS provides algorithms for efficient similarity search and clustering of dense vectors and has been integrated into many commercial vector database products like Milvus [27].

> Coarse-grain: Figure 4 compares the relative execution time of indexing and query operations on remote vs local memory. We find that both indexing and query kernels see slowdowns when data is located in far-mem (more significant on Platform B due to the difference in local vs remote memory latency/bandwidth). Notably, HNSW and NSG are particularly sensitive to memory characteristics. We find most query operations are memory sensitive as they feature irregular accesses and bandwidth pressure with parallel requests.

> Fine-grain: As a proof-of-concept, we implement HNSW indexing and query kernel offloading using a two processes model with different address spaces to emulate host and device. For each kernel, we identify utilized variables, allocate them with Linux shared memory, and wrap the kernel functions with an offloading request with some additional helper functions.

Figure 5 compares the execution time of our offload relative to local memory. For offloaded HNSW, we find huge performance



Figure 4: Mem sensitivity of indexing (dataset sift1M [28]).



Figure 5: Offload HNSW kernels on two platforms.

| Platform A           | Indexing          | Query 10          | Query 500          |
|----------------------|-------------------|-------------------|--------------------|
| Saving               | 1.74x             | 1.67x             | 1.62x              |
| Overhead             | 1.61%             | 1.31%             | 2.93%              |
|                      |                   |                   |                    |
|                      |                   |                   |                    |
| Platform B           | Indexing          | Query 10          | Query 500          |
| Platform B<br>Saving | Indexing<br>6.87x | Query 10<br>7.04x | Query 500<br>6.75x |

Table 2: Offload performance saving and overhead.

saving over full remote memory execution, saving 6.87x latency. Platform B sees the largest performance benefit of offload due to the difference in local vs remote memory characteristics.

Further, the offloading overhead is quite minor. The main bottleneck is enabling data visibility on the device side core (allocate, copy and reconstruct), and it's less than 8%. This can be further reduced by a more transparent offloading mechanism.

**Overall Summary:** For specific kernels that are memory sensitive, the VectorDB offload proof-of-concept demonstrates the huge potential benefits of near memory computation (up to 7x saving).

## 5 CONCLUSION

We presented two application case studies showing promising performance benefits when offloaded to general purpose compute on CXL memory devices. We believe this makes a compelling case for the use of such compute added to CXL devices in the datacenter. The challenge is in evolving the software ecosystem (compilers/runtimes) to enable automatic or programmatic offload mechanisms for a wider range of applications for CXL offload architecture.

<sup>&</sup>lt;sup>1</sup>Similar analysis for the ONNX framework and fine-grain analysis for PyTorch was also performed. The results largely show a similar trend.

### REFERENCES

- [1] "CXL Consortium," https://www.computeexpresslink.org/.
- [2] H. Li et al., "Pond: CXL-Based Memory Pooling Systems for Cloud Platforms," in Proceedings of the 28th ACM International Conference on Architectural Support for Programming Languages and Operating Systems (ASPLOS), Vancouver, BC Canada, March 2023.
- [3] J. H. Kim et al., "Samsung pim/pnm for transfmer based ai : Energy efficiency on pim/pnm cluster," in 2023 IEEE Hot Chips 35 Symposium (HCS), 2023, pp. 1–31.
- [4] J. Sim et al., "Computational cxl-memory solution for accelerating memoryintensive applications," IEEE Computer Architecture Letters, vol. 22, no. 1, pp. 5–8, 2023.
- [5] D. D. Sharma, "Novel composable and scaleout architectures using compute express link," *IEEE Micro*, vol. 43, no. 2, pp. 9–19, 2023.
- [6] M. Ahn et al., "Enabling cxl memory expansion for in-memory database management systems," in Proceedings of the 18th International Workshop on Data Management on New Hardware, ser. DaMoN '22. New York, NY, USA: Association for Computing Machinery, 2022. Available: https: //doi.org/10.1145/3533737.3535090
- [7] Y. Kwon et al., "Memory-centric computing with sk hynix's domain-specific memory," in 2023 IEEE Hot Chips 35 Symposium (HCS), 2023, pp. 1–26.
- [8] D. D. Sharma, R. Blankenship, and D. S. Berger, "An introduction to the compute express link (cxl) interconnect," arXiv preprint arXiv:2306.11227, 2023.
- [9] "Samsung's CXL Memory Expander," https://semiconductor.samsung.com/newsevents/news/samsung-develops-industrys-first-cxl-dram-supporting-cxl-2-0/.
- [10] "Micron memory expansion module," https://www.micron.com/solutions/server/ cxl.
- "Amd epyc 4th gen processors with cxl 1.1," https://www.amd.com/en/pressreleases/2022-11-10-offering-unmatched-performance-leadership-energyefficiency- and-next.
- [12] "Intel 4th gen xeon scalable processors with cxl 1.1," https://www.intel.com/ content/www/us/en/newsroom/news/4th-gen-xeon-scalable-processors-maxseries-cpus-gpus.html.

- "Enabling cxl within the data center with arm solutions," https://drive.google. com/file/d/17Y1PumNyvIMLL04Ak3Pt5up217btTbcj/view.
- [14] "2022 OCP Global Summit Key Takeaways CXL's Implications for Server Architecture," https://www.opencompute.org/blog/2022-ocp-global-summit-keytakeaways-cxls-implications-for-server-architecture.
- [15] M. Abadi et al., "TensorFlow: Large-scale machine learning on heterogeneous systems," 2015, software available from tensorflow.org. Available: https: //www.tensorflow.org/
- [16] A. Paszke et al., "Pytorch: An imperative style, high-performance deep learning library," 2019.
- [17] "FAISS case study," https://github.com/facebookresearch/faiss/wiki/Case-studies.
- [18] Y. A. Malkov and D. A. Yashunin, "Efficient and robust approximate nearest neighbor search using hierarchical navigable small world graphs," *IEEE Transactions on Pattern Analysis and Machine Intelligence*, vol. 42, no. 4, pp. 824–836, 2020.
- [19] C. Fu, C. Xiang, C. Wang, and D. Cai, "Fast approximate nearest neighbor search with the navigating spreading-out graph," *Proc. VLDB Endow.*, vol. 12, no. 5, p. 461–474, jan 2019. Available: https://doi.org/10.14778/3303753.3303754
  [20] D. Gouk, S. Lee, M. Kwon, and M. Jung, "Direct access, {High-Performance}
- [20] D. Gouk, S. Lee, M. Kwon, and M. Jung, "Direct access, {High-Performance} memory disaggregation with {DirectCXL}," in 2022 USENIX Annual Technical Conference (USENIX ATC 22), 2022, pp. 287–294.
- [21] Y. Yang, P. Safayenikoo, J. Ma, T. A. Khan, and A. Quinn, "Cxlmemsim: A pure software simulated cxl. mem for performance characterization," arXiv preprint arXiv:2303.06153, 2023.
- [22] "tinymembench: a simple benchmark for memory throughput and latency," https://github.com/ssvb/tinymembench.
- [23] J. D. McCalpin et al., "Memory bandwidth and machine balance in current high performance computers," *IEEE computer society technical committee on computer* architecture (TCCA) newsletter, vol. 2, no. 19-25, 1995.
- [24] Papi. Available: http://icl.cs.utk.edu/papi/
- [25] Pytorch benchmark. Available: https://github.com/pytorch/benchmark
- [26] M. Douze et al., "The faiss library," arXiv, 2024.
- [27] "Milvus Vector database built for scalable similarity search," https://milvus.io/.
- [28] "sift1M dataset," https://www.tensorflow.org/datasets/catalog/sift1m.