## Tarsonis: Dynamic Page Sizing for Disaggregated Memory in Datacenters

Cheng-Hung He *UC San Diego* 

Jefferson Chien UC San Diego Heidi Cheng UC San Diego

## **Abstract**

Your Abstract Text Goes Here. Just a few facts. Whet our appetites.

## 1 Introduction

We are able to trace implementation of segments and pages to the earliest days of operating systems. Operating system developers and hardware designers worked together to increase the efficiency of virtual memory. In the past decades, researchers have urged for larger page sizes for its spatial locality, smaller page table, easier virtual memory translation, etc...[?] However, some recent research has indicated that larger page size might not be the most suitable solution in all use cases.[?]. Taking a step forward, we are inspired by many datacenter specific system designs that optimize system implementations for datacenter's special workload and requirements. Also, the rising awareness of microsecond scale latecy and optimization and increasing demands for customizability and flexibility motivated us to design a system that maintains the convenience brought by operating system abstraction for virtual memory while providing effcient memory mapping specifically for disaggregated memory in the datacenters.

Current mainstream operating systems support certain range of page sizes. This is, however, very limited by the underlying hardware architecture as well.[?]. In past research works, we have found some attempts to resolve this issue. Systems such as Kona uses dedicated hardware (FPGAs) to efficiently fetch cacheline size memory from disaggregated memory.[?] Within the Kona paper, Calciu et al. also argued that the standard 4KB page size introduced issues such as dirty data amplification, and proposed a new model to access data in a cache line granularity manner. We however, do not fully agree with this approach, and wish to find a

software mechanism that can resolve the dynamically changing page size address translation issue. Further inspired by the thriving centralized managed datacenter architectures[?][?], we came up with an interesting question, if systems like Shenango and ghOSt can leverage centralized management for low tail latency while maintaining sufficient throughput, can do we the same for virtual memory management?

In this paper, we want to explore possibilities for implementing Tarsonis, a userspace dynamic page sizing delegation system for disaggregated memory in datacenters. We have three goals: (1) Argue that varying page sizes is a MUST for modern datacenter workload (2) Explore the possibilities of software mechanism for varying page sizes (3) Design a standardize and intuitive application programming interface for flexible and customizable page sizes for userspace applications (4) Propose an automatic page resizing alorithm that can detect changing page sizing needs and complete necessary modifications with low overheads (5) Resolve virtual memory - physical memory mapping issues to offer compatibility to existing software. We are aware that these goals may not be feasible to complete in the duration of six weeks. Therefore, we want to separate tasks into stages shown in Table 1, so we can trace our progress and make adjustments in necessary.

| Date      | Task                            | Description                                                                                                                                                                                                    |
|-----------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Week<br>5 | Workload verifying              | Find real workloads (or synthetic ones if not found) to demonstrate how different different applications have different optimized page                                                                         |
| Week<br>7 | Software approach investigation | sizes Investigate whether it is possible to achieve varying page sizes with software approach, and if not, propose ways to emulate this experiment to urge hardware designers for such feature in the hardware |
| Week<br>9 | Implement page addressing       | Find ways to implement tra-<br>ditional virtual memory -<br>physical memory mapping.                                                                                                                           |

Table 1: Milestones