# ECLIP: Energy-efficient and Practical Co-Location of ML Inference on Spatially Partitioned GPUs

Ryan Quach\*, Yidi Wang<sup>†</sup>, Ali Jahanshahi\*, Daniel Wong\*, Hyoseung Kim\*

\*University of California, Riverside

{rquac004, ajaha004, danwong, hyoseung}@ucr.edu

<sup>†</sup>Santa Clara University

ywang49@scu.edu

Abstract—As AI inference becomes mainstream, research has begun to focus on improving the energy consumption of inference servers. Inference kernels commonly underutilize a GPU's compute resources and waste power from idling components. To improve utilization and energy efficiency, multiple models can co-locate and share the GPU. However, typical GPU spatial partitioning techniques often experience significant overheads when reconfiguring spatial partitions, which can waste additional energy through repartitioning overheads or non-optimal partition configurations. In this paper, we present ECLIP, a framework to enable low-overhead energy-efficient kernel-wise resource partitioning between co-located inference kernels. ECLIP minimizes repartitioning overheads by pre-allocating pools of CU masked streams and assigns optimal CU assignments to groups of kernels through our resource allocation optimizer. Overall, ECLIP achieves an average of 13% improvement to throughput and 25% improvement to energy efficiency.

#### I. INTRODUCTION

Inference servers have emerged as a critical component as ML/AI becomes increasingly prevalent in IoT applications from smartphones to self-driving vehicles. While these systems rely heavily on GPUs to execute inference computations of ML models, individual inference requests often do not utilize all GPU compute resources, e.g., Compute Units (CU) in an AMD GPU [1] and Streaming Multiprocessors (SM) in an Nvidia GPU [2], [3]. Therefore, underutilized GPUs waste energy by having many idling CUs or SMs that cannot be power-gated due to architectural constraints [4]–[8]. This offers an opportunity for significant energy and performance optimizations by sharing a GPU among concurrent ML models.

The effectiveness of an inference server is primarily assessed by its ability to meet Quality of Service (QoS), such as throughput and tail latency. When multiple requests are scheduled concurrently on a GPU for throughput, tail latency may increase significantly due to interference of shared compute and memory resources. To improve QoS of co-locating models, spatial partitioning allocates distinct portions of GPU internal compute resources to kernels within a request, lessening contention. However, even the state-of-the-art inference servers employing spatial partitioning [3], [9]–[12] still suffer from the following key limitations.

Prior works trade-off the granularity of spatial partitions with the overheads of partition reconfiguration. Due to high overheads of Nvidia's MPS and MIG spatial partitioning, many prior works partition at the coarse granularity of entire models [2], [13], [14]. However, this approach leaves significant GPU under-utilization since compute resource requirements vary kernel-by-kernel within an inference request. To address this, kernel-grain spatial partitioning was proposed with architectural extensions to avoid overhead of repartitioning at every kernel [12]. However, it requires hardware

979-8-3315-2710-5/25/\$31.00 ©2025 IEEE

modifications that are impractical in real GPUs, leading to significant energy and performance overheads.

**Our Contribution.** This paper introduces ECLIP, a framework for *energy-efficient* and *practical* co-location of ML inference on spatially partitioned GPUs. ECLIP introduces both *scheduling* and *resource allocation* approaches to achieve effective kernel-wise spatial partitioning with minimal spatial repartitioning overheads on real-world GPUs.

We first characterize the overheads of CU masking and model co-location through carefully designed experiments on an AMD GPU. Based on these observations, we propose a lightweight runtime scheduler that achieves kernel-grain partitioning without substantial overhead, by creating pools of pre-allocated CU mask streams. To guide scheduling decisions, we formulate a resource allocation model that determines energy-cognizant CU allocation for *groups of kernels* within an inference request while accounting for co-located ML model scenarios and their associated slowdowns. By limiting repartitioning events and making allocation decisions at kernel group granularity, we achieve the benefits of per-kernel repartitioning with minimal energy waste on real GPU systems.

Experimental results demonstrate that ECLIP can achieve up to 21% increase in throughput and on average a 25% improvement in energy efficiency, while maintaining tail latency in an acceptable range. ECLIP is integrated into the AMD ROCm runtime, remaining transparent to PyTorch and other ML inference backends, enabling energy and performance benefits without any model or PyTorch modifications.

# II. BACKGROUND

#### A. AMD GPU Hardware

AMD GPUs consist of multiple Compute Units (CUs) [15], which are equivalent to Streaming Multiprocessors (SMs) in Nvidia terminology. Multiple CUs are organized into Shader Engines (SEs), typically in clusters of 15 CUs for the MI50 architecture. Unlike Nvidia's MPS or MIG, which applies spatial partitions at the process level, AMD's CU Masking feature within the ROCm runtime enables spatial partitioning at a finer granularity of streams by specifying which CUs to execute kernels on. This provides more flexible resource allocations for inference servers.

Additional architectural details on AMD GPUs can be found in technical whitepapers [16]–[18] and academic papers [19]. AMD's ROCm documentation [20] and the HSA Foundation's Programmer Manual [21] provide essential information about AMD's runtime backend.

#### B. GPU Energy-efficiency Techniques

GPUs can save power through DVFS and resource scaling techniques. While DVFS can scale frequency and voltage to save dynamic power, its impact is limited by underutilization of idle resources which typically suffer from leakage power. Resource scaling, such as limiting workload to a subset of CUs, can in theory save power by allowing unused resources to be power-gated to save leakage power. However, power gating techniques in production GPUs are limited to clock-gating or gating of the entire GPU [4], [6], [8], [22], [23]. Hence, CU masking alone does not lead to significant energy-efficiency gains. To address under-utilization, it is favorable to co-locate and increase the utilization of the GPU to improve energy efficiency.

# C. Limitations of GPU Partitioning for ML Inference

ML inference tends to underutilize GPUs [2], [3], [6], [12]–[14], [24], [25]. To improve utilization, spatial co-location of ML models allow concurrent ML inference requests to compute on different GPU resources. However, there are two challenges. First, ML models must be right-sized in order to use the minimal amount of resources while maintaining performance. Second, GPU spatial partitioning mechanisms can incur high overhead.

- 1) Model-grain Right-Sizing: ML models are typically sized to use minimal resources while meeting a certain quality-of-service target, typically 3x the tail latency when running in isolation [2], [14]. The amount of resources dedicated to an ML model is generally identified at the "knee" of the resource vs. latency curve. Since GPU spatial partitioning incurs high overhead, many prior works perform right-sizing ML models at the granularity of the entire model. However, individual kernels within an inference request require different amounts of resources, resulting in idling CUs that waste energy. Prior works like PARIS+ELSA [14], GPUlet [2], and GSlice [13] all rely on model-grain right-sizing for GPU partitions through MPS or MIG on Nvidia GPUs. These approaches create shadow partitions in the background and hot-swap the ML inference once it completes loading.
- 2) Kernel-grain Right-Sizing: At finer granularities, ML models can be right-sized at the kernel level [3], [12], requiring per-kernel spatial repartitioning. However, with ML inference kernels often lasting as little as microseconds, the spatial repartitioning overhead can exceed the kernel's actual runtime. Furthermore, while AMD GPUs contain a mechanism for CU masking, applying CU masks every kernel requires code modifications to Pytorch. To get around this, ElasticRoom [3] employs compiler code-generation of an array of GEMM kernels with varying resource requirements. Then at runtime, a scheduler selects appropriately sized kernels to run. However, this approach is limited to only GEMM kernels and requires significant runtime modifications that are not compatible with ML frameworks like PyTorch. KRISP [12] proposes microarchitectural extensions to support kernel-level CU masking with low-overheads. This enables kernel-wise right-sizing of kernels without any code modification of ML frameworks. However, such mechanisms cannot be used for existing GPU hardware due to the lack of microarchitectural extensions, as seen from their evaluation in an emulation environment.

A recent work proposed libsmctrl [26], a library that enables SM Masking on Nvidia GPUs using undocumented CUDA debugging callback API to modify hardware resource mask associated with each kernel. libsmctrl is able to enforce a SM Mask globally, for specific streams, or for individual kernels. This would incur a libsmctrl API call before every kernel launch and would require modifications to





(a) Latency of 8 longest albert (b) Number of CU-masked Streams kernels. vs. Inference Latency.

Figure 1: CU masking timing characteristics.

existing ML frameworks to support this, which again is not very practical.

# D. Challenges towards practical kernel-level spatial partitioning of ML inference

Existing GPU spatial partitioning support for ML inference servers are currently limited by the overheads of spatial partitioning or by the impracticalities of program changes to ML frameworks and custom microarchitectural changes. Therefore, a key to providing *practical* spatial partitioning for co-located ML inference servers is to carefully manage the overheads of spatial partitioning. In order to do so, we need to deeply understand the intricacies between workload latency, co-location and hardware CU masking overheads.

In this work, we build off AMD CU masking mechanism to provide a practical spatially partitioned ML inference server, called ECLIP. Our insight is that while partitioning on a per-kernel basis is extremely costly, we aim to limit the amount of spatial partitioning overhead by partitioning at *groups of kernels*. To achieve this, we characterize CU masking properties in AMD GPUs to build analytical models (for inference latency and overheads) and resource allocation optimization to achieve practical kernel-wise co-location of ML inference on real GPUs.

## III. ANALYZING HARDWARE CHARACTERISTICS

Our analysis is based on an AMD Radeon Instinct MI50 GPU, containing 60 CUs, organized as 4 SEs of 15 CUs each. We investigate AMD CU masking due to enforcing partitions at the granularity of streams and unlocks repartitioning *within* model inference. Our experiments aim to investigate overheads of resource partitioning, which can lead to subpar performance and energy efficiency.

The first experiment is to examine the CU mask API overhead. This is done by instrumenting ROCm [20], which is AMD's runtime stack equivalent to Nvidia's CUDA, binding the user space kernel code with the device driver. Within ROCm, a runtime API sets the hardware queue's CU mask through an IOCTL system call. Specifically, this IOCTL call accounts for the majority of CU masking repartitioning overhead and leads to wasteful GPU idling time. To examine this overhead, we update the CU mask of every single kernel within an inference pass for the albert model [27].

**Observation 1.** CU masking IOCTL calls have high and unpredictable timing overheads.

We observed a significant slowdown from calling the CU mask IOCTL call every kernel. In Figure 1a, we show the 8 longest running kernels averaged over 100 inference requests, and compare their latency with or without per-kernel CU masking. In the worst scenario,



Figure 2: ECLIP Overview. Additions to ROCm in blue.

the CU IOCTL overhead is 55.4  $\mu s$ , over 2x the kernel execution time of 19.8  $\mu s$ .

The next experiment explores whether the number of CU masked streams introduce additional overheads. This is important since model co-location requires multiple concurrent streams, each with unique CU masks. We create an increasing number of CU masked streams (each with 3 unique CUs) and distribute inference kernels across these streams in a round-robin fashion. HSA barrier packets in ROCm are used to ensure that kernels execute in correct sequence to maintain their data dependencies (see Sec. IV-A for details).

**Observation 2.** The GPU can accommodate a finite number of CU masked streams before experiencing slowdown due to queue oversubscription.

As shown in Figure 1b, with up to 7 CU masked streams, there is relatively stable performance. However, latency significantly and unpredictably rises with each subsequent CU masked stream.

This likely stems from the GPU's limited number of hardware queues. Whenever a CU masked stream is created, there is a corresponding command queue created within the software runtime, i.e., HSA queues in ROCm. While these queues help the concurrency of multiple kernels, performance issues arise once the number of HSA queues exceeds the number of physical hardware queues. In such cases, the GPU must *oversubscribe* HSA queues to hardware queues, where the hardware periodically switches between all allocated HSA queues [28], resulting in longer latencies. Similar performance issues have been reported on the latest generations of GPUs, including AMD RX9700 XT.

The above experiment informs our design decision. Including a default stream in ROCm, the total number of streams we can support on our GPU is 8, matching the number of hardware queues [29], [30]. Therefore, to prevent significant oversubscription overheads, we need to limit our creation of CU masked streams to 7.

# IV. ECLIP FRAMEWORK

Based on the observations made in Section III, we propose ECLIP, a framework for *practical* and *energy-efficient* co-location of inference kernels. ECLIP aims to trade off spatial repartitioning granularity with repartitioning overheads. ECLIP achieves effective kernel-granular spatial partitioning by (i) creating pools of streams with pre-defined CU masks, (ii) a runtime scheduler that intercepts and redirects kernels to appropriate CU-masked streams while maintaining inter-kernel data dependencies, and (iii) a resource allocation optimizer that assigns optimal CU assignments for *groups of kernels* while considering co-location scenarios, and other hardware constraints. Figure 2 shows an overview of ECLIP, with require modifications to the ROCm runtime in blue boxes.

#### A. Runtime Scheduler

**Pre-allocated CU Masked Streams:** ECLIP pre-allocates *seven* CU-masked streams in the HIP (Heterogeneous-Compute Interface for Portability) backend, ROCm's user-facing layers. This approach avoids costly CU masking IOCTL calls at runtime, as previously shown in Obs. 1. The number of CU-masked streams is determined based on Obs. 2, which shows that creating more than 7 streams would introduce significant performance degradation.

ECLIP follows the common ML inference server architecture where each distinct ML model is processed by a designated worker thread that handles all inference requests for its model. For these workers, streams are created with CU increments of 15, as each Shader Engine (SE) on the GPU has exactly 15 CUs. This ensures that CUs are assigned in complete SE units, thereby minimizing interference between co-located workers. This also prevents performance loss when CUs are unevenly distributed across SEs [31]. For example, if we have 2 workers, each worker will have their own set of CU masked streams with 15, 30, and 45 CUs. Worker 1's CUs are allocated to the following SEs: 15 CU (SE 1), 30 CU (SE 1, 3), 45 CU (SE 1, 2, 3). Worker 2 will be assigned with: 15 CU (SE 4), 30 CU (SE 2, 4), 45 CU (SE 2, 3, 4). In both workers, the 60 CU allocation is the default stream, which keeps us below the hardware queue limit. For 3 co-located workers, each worker has their own set of 30 and 45 CU masked streams, with a default shared stream of 60 CUs.

Redirecting Kernel Dispatch to Pre-allocated CU Masked Streams: As shown in Figure 2, ECLIP modifies the HIP backend's kernel dispatch process (2). It intercepts kernels and uses a lookup table to determine which CU-masked stream each kernel should use. The incoming kernel (1) is then removed from its original stream and redirected to the selected CU-masked stream. This lookup table is generated by our resource allocation optimizer (Sec. IV-B), which aims to maintain exclusive streams with minimal sharing.

Enforcing Data Dependencies: By default, data dependency between kernels is enforced within a user stream since kernels are executed one-by-one in FIFO order. However, when ECLIP redirects kernels to different pre-allocated CU masked streams, we need an additional mechanism to enforce the data dependencies between kernels in different pre-allocated CU masked streams. To address this issue, ECLIP introduces a dependency enforcement mechanism in the ROCclr library's dispatch process (Figure 2 ③). Hence, we dynamically inject HSA barrier packets to enforce dependencies between kernels that originate from the same user stream but are assigned to different CU-masked streams (and therefore, dispatched to different hardware queues). A barrier packet is required when (i) the kernel has a dependency on a previous kernel from the same stream, and (ii) that previous kernel has not yet completed execution.

To implement this, our dependency enforcer maintains a two-dimensional vector tracking kernel execution status: one dimension for user streams and the other for kernel completion signals. For each incoming kernel, the enforcer checks the completion signal of the previous kernel from the same stream. If that kernel is still running, the enforcer creates and dispatches a barrier packet dependent on its completion signal, followed by the new kernel (4). Otherwise, the new kernel is dispatched immediately. In both cases, the new kernel's completion signal is logged for future reference.

<sup>&</sup>lt;sup>1</sup>In the rest of the paper, we use models and workers interchangeably.

<sup>&</sup>lt;sup>2</sup>A completion signal is the runtime's way to determine whether a kernel has finished. If it is 0, it is still running. If it is 1, the old kernel was completed. We also use this same signal for profiling.



Figure 3: CU allocations for albert by ECLIP's optimizer

Although barriers are necessary for dependency management, they can introduce significant overhead as the command processor must track dependency signals for each barrier and only release blocked kernels once these signals are satisfied. The excessive use of barriers can also lead to unpredictable slowdown. In our tests, the overhead could exceed the actual kernel execution time. We address this challenge through barrier packet budgeting in our resource allocation modeling and optimization.

#### B. Resource Allocation Optimizer

To further minimize the impact of fine-grain spatial partitioning, ECLIP assigns resources to *groups of kernels*. ECLIP introduces a resource allocation optimizer that determines *how many* CUs a group of kernels will be allocated, and *when* to switch CU partitions (which determine how kernels are grouped).

Minimum CU Threshold Profiling: We profile each kernel's *inde*pendent execution time with a single request on the GPU and identify a "threshold" per kernel that is the minimum number of CUs needed without experiencing noticeable slowdown. As shown in Figure 3 (light blue line), different kernels within a request can have widely varying minimum CU thresholds, creating opportunities for efficient resource sharing.

CU Switching Overhead: Frequent switches between CU configurations introduce significant overhead, as explained in Sec. IV-A. Each switch requires a barrier packet to maintain data dependencies, but excessive barrier packets can significantly degrade performance. Therefore, our optimizer must balance the benefits of fine-grained CU allocation against the overhead of configuration switches by considering *groups of kernels* together rather than optimizing each kernel's CU configuration independently. Figure 3 (blue boxes) shows an illustrative example of how our optimizer performs CU allocation to groups of kernels.

Fairness among Workers for Energy Efficiency: In co-located scenarios where multiple workers handle inference requests concurrently, our optimizer must ensure fairness while maximizing overall GPU utilization. This fairness is critical because disparate completion times among workers lead to idling CUs, wasting energy due to the lack of CU-level power gating as explained in Sec. II-B. To address this issue, we associate one identically weighted objective function per worker, where each objective function aims to minimize the execution time of that worker's kernels.

**Optimization Formulation:** Our optimization goal is to minimize execution time across all workers while maintaining fairness and minimizing slowdowns. For each kernel, the model must select a CU configuration from a predefined set of configurations that align with the SE organization (increment of 15 CUs. Kernel execution time is influenced by three factors: (i) the number of CUs allocated

to it, (ii) the slowdown from co-location with other workers' kernels, and (iii) the overhead of CU configuration switches.

Factor (i) is directly determined from profiling data. Factor (ii) is modeled based on CU sharing because the slowdown experienced by workers tends to be proportional to their CU overlap, e.g., higher slowdown with more shared CUs. Hence, we compute this by tracking the average number of CUs used by each worker and determining potential overlap between workers. To minimize factor (iii), we introduce *barrier packet budget* that constrains the total number of CU configuration switches allowed within each worker's request.

The mathematical formulation of our model is as follows. The model's objective function is to minimize the summation of kernel execution time for all kernels in each worker, with equal weights for all workers for fairness:

$$\forall w$$
, minimize  $\sum_{k \in w} e_k$ 

where w is a worker and  $e_k$  is the estimated execution time of a kernel k in co-located scenarios.

Let  $x_{k,c}$  be the main decision variable representing whether the CU configuration  $c \in \text{configs}$  is selected for the kernel k, where configs =  $\{15, 30, 45, 60\}$  is the set of available CU configurations.  $x_{k,c} = 1$  if k uses the configuration c, and  $x_{k,c} = 0$  otherwise. With  $x_{k,c}$ , we introduce the following constraints for configuration selection:

- ∀k ∈ w, ∑<sub>c∈configs</sub> x<sub>k,c</sub> = 1: This forces the model to assign only one configuration to each kernel.
- switchTotal $_w = \sum_{k \in w} \sum_{c \in \text{configs}} |x_{k,c} x_{k-1,c}|/2$ : This counts the total number of switches occured for a worker w. The term  $|x_{k,c} x_{k-1,c}|$  detects a switch between consecutive kernels as their x values differ when using different configurations. Division by 2 is to correct for double counting.
- switchTotal<sub>w</sub> ≤ switchMax: Barrier packet budget constraint limiting the number of switches per worker.

The execution time  $e_k$  is calculated by:

- $e_k = \beta_k * (1 + \alpha_k)$ : This is the final estimated execution time for a kernel k accounting for slowdown and CU selection.
- $\beta_k = \text{profile}[\sum_c x_{k,c} * c]$ : Base solo execution time from profiling. Since  $x_{k,c} = 1$  for only one configuration c,  $\sum_c x_{k,c} * c$  gives the selected CU count for kernel k.
- α<sub>k</sub> = CUOverlap<sub>w</sub>/(total # of CUs): Co-location slowdown factor considering CU overlaps with other workers. Previous experiments informed this approach: two identical kernels sharing the same CUs both took twice as long.

The CU overlap between workers is tracked by:

- CUAverage  $_w = \sum_{k \in w} \sum_c x_{k,c} * c/(\# \text{ of kernels in } w)$ : Average number of CUs per kernel for the worker w.
- CUOverlap $_w = \text{CUAverage}_w + \sum_{\forall w': w' \neq w} \text{CUAverage}_{w'}$ : Total number of CUs overlapping with other workers.

The above formulation is an Integer Linear Programming (ILP) problem which can be solved using ILP solvers like Gurobi. Since the solution time of ILP can be long, we solve this offline for different colocation scenarios and store the results in a lookup table. At runtime, our scheduler simply references this table to get pre-computed CU configurations and assign kernels to the corresponding CU-masked streams.

<sup>&</sup>lt;sup>3</sup>This approach is generalized, but because it is difficult to model we could not resort to a more precise approach.





Figure 4: Normalized Throughput (RPS). Each gradient within the bar represent a different worker.



Figure 5: Normalized 95th Percentile Tail Latency



Figure 6: Normalized Energy Efficiency

# V. EVALUATION

#### A. Experimental Methodology

Our server consists of two AMD EPYC 7302 16-core CPUs, 512GB memory, and an AMD MI50 GPU. The GPU consists of 60 CUs, arranged as 4 SEs of 15 CUs each. The server runs Ubuntu 20.04 with ROCm 5.2.0 and PyTorch 1.12.0a0.

We used the room-smi library to take power consumption measurements.

Inference Models. We evaluate with 7 inference models: albert [27], densenet201 [32], alexnet [33], resnet15 [34], resnext101 [35], shufflenet [36], and vgg19 [37]. To stress co-locating ML inference, we test the models at their maximum supported RPS (Requests Per Second). We study 7 co-location workload mixes as follows: Mix 1 (2 albert, 1 densenet201), Mix 2 (1 albert, 1 densenet201), Mix 3 (1 albert, 1 densenet201, 1 vgg19), Mix 4 (1 alexnet, 1 resnet15, 1 vgg19), Mix 5 (1 resnext101, 1 shufflenet), Mix 6 (2 densenet201), and Mix 7 (3 alexnet). We targeted feasible combinations with models of high CU right-sizes [12] matched with models of low CU right-sizes.

**Spatial Partitioning Scenarios** We evaluate four spatial partitioning scenarios as follows:

• Baseline: Unmodified ROCm runtime with no spatial partitioning. Co-located models send all incoming kernels to the default stream that uses all 60 CUs.

- Model-Wise: This approach implements model-wise rightsizing [2], [13], [14]. Through profiling, we find each model's minimum number of CUs that satisfies tail latency, and allocate that to each worker for the entire ML inference.
- Kernel-Wise<sup>IOCTL</sup> (KW<sup>IOCTL</sup>): This scenario uses CU masking IOCTL to switch CU allocations at every kernel, similar to KRISP [12].
- Kernel-Wise<sup>Prealloc</sup> (KW<sup>Prealloc</sup>): This scenario switch between pre-allocated CU workers (using ECLIP's mechanisms) for nearly every kernel.<sup>4</sup>
- ECLIP: Our full ECLIP implementation. This configuration accounts for overheads of barrier packets and partitioning, and uses a maximum of 14 partitioning switches per inference request. 14 was selected as it demonstrates a balance between partitioning overhead and co-location efficiency. It is difficult for the model to solve for the number of partitioning switches, so profiling was used to determine this number. 5

As shown in Table I, the number of CU configuration switches done by Kernel-Wise  $^{IOCTL}$  is very high, and results in extremely large slowdowns without the custom miroarchitectural support presented in [12]. Therefore, opted to not graph the results of Kernel-Wise  $^{IOCTL}$ .

<sup>&</sup>lt;sup>4</sup>Adjacent kernels often require similar CU counts, not resulting in a switch.
<sup>5</sup>We experienced diminishing returns with more than around 14 switches, but experienced slowdown with fewer switches.

Table I: Sum of per-request CU switches for all workers

| Workload | Workers | KW <sup>IOCTL</sup> | $KW^{Prealloc}$ | ECLIP |
|----------|---------|---------------------|-----------------|-------|
| Mix1     | 3       | 1319                | 413             | 42    |
| Mix2     | 2       | 1015                | 755             | 23    |
| Mix3     | 3       | 1077                | 538             | 28    |
| Mix4     | 3       | 613                 | 330             | 10    |
| Mix5     | 2       | 728                 | 166             | 12    |
| Mix6     | 2       | 1422                | 695             | 20    |
| Mix7     | 3       | 102                 | 72              | 30    |

#### B. Throughput Results

Figure 4 represents the normalized throughput results of the various partitioning scenarios across workload mixes. Clearly, across all scenarios, ECLIP achieves the best overall throughput, with a maximum improvement of 21% for Mix 7 and an average improvement of 13%. Kernel-Wise  $^{Prealloc}$  achieves the lowest throughput due to the overheads of CU switching, as shown in Table I.

ECLIP's fairness modeling attempts to treat each worker with fairness, by not prioritizing the speedup of any one worker. This is best shown with Mix 7 in Figure 4, where the baseline method allows some kernels to cut ahead and finish early despite the workload containing three identical models.

#### C. Latency Results

Figure 5 shows the normalized 95th percentile tail latency of requests under various spatial partitioning scenarios and workload mixes. In general, fine grain partitioning approaches result in higher tail latencies. This is most clearly shown by Kernel-Wise \*Preatloc\*'s significant increase in tail latency relative to baseline. By limiting the number of switches, our implementation ensures that the tail latency does not rise uncontrollably. On the other hand, Model-Wise's increase in tail latency occurs from overly coarse grain resource sharing. This is shown best by Mix 3, where the vgg19 worker's kernels typically require all 60 CUs before experiencing slowdown. By forcing the two other workers to constantly contend with vgg19's kernels, all kernels experience slowdown.

# D. Energy Efficiency Results

Figure 6 shows the normalized energy efficiency. Because of the significant increase in tail latency and switching overheads, Kernel-Wise Prealloc's energy efficiency fails to measurably surpass the baseline. Model-Wise's approach leads to inconsistent improvements due to varying levels of latency and throughput improvements, while ECLIP consistently is able to improve upon the baseline energy efficiency across all mixes by better utilizing the available GPU resources and minimizing switching overheads. ECLIP achieves a maximum energy efficiency improvement of 35% for Mix 7 with an average of 25% energy efficiency improvement across all workload mixes.

## VI. OTHER RELATED WORK

Previously, we discussed the most relevant work in ML inference servers in Section II. Here, we focus on generic GPU spatial partitioning approaches. Early work on GPU partitioning [9]–[11], [38] focused primarily on spatial resource allocation strategies. Later works began to consider partitioning overheads, but with limited depth. [39] acknowledged partitioning overhead without detailed analysis of performance implications. [40] models partitioning overhead by adding a static slowdown cost in their simulator, but fails to capture the complex behaviors we observed in real systems. While [41] recognized hardware context switching overhead, it did

not provide detailed analysis of performance impacts or propose solutions to mitigate these overheads. In contrast, our work provides detailed characterization of partitioning overheads on real AMD GPU hardware and presents practical solutions to manage these overheads for ML inference servers.

#### VII. CONCLUSION

This paper demonstrated the drawbacks of current GPU spatial partitioning methodologies and how overly aggressive partitioning leads to severe hardware overhead. Through the use of model-informed compute resource partitioning, our framework, ECLIP, overcomes this issue and significantly improves ML inference throughput and energy efficiency by an average of 13% and 25%, respectively, and up to 21% and 35%, respectively, while satisfying latency constraints.

#### ACKNOWLEDGMENT

This work is supported by the National Science Foundation (NSF) grants 1943265, 1955650, 2312395, 2324940, 2324941, and 2047521.

#### REFERENCES

- [1] A. Jahanshahi, M. Chow, and D. Wong, "Scaleserve: a scalable multi-gpu machine learning inference system and benchmarking suite," in *Proceedings of the 14th Workshop on General Purpose Processing Using GPU*, ser. GPGPU '22. New York, NY, USA: Association for Computing Machinery, 2022. [Online]. Available: https://doi.org/10.1145/3530390.3532735
- [2] S. Choi, S. Lee, Y. Kim, J. Park, Y. Kwon, and J. Huh, "Serving heterogeneous machine learning models on Multi-GPU servers with Spatio-Temporal sharing," in 2022 USENIX Annual Technical Conference (USENIX ATC 22). Carlsbad, CA: USENIX Association, 2022, pp. 199–216. [Online]. Available: https://www. usenix.org/conference/atc22/presentation/choi-seungbeom
- [3] L. Ma, H. Chen, E. Shao, L. Wang, Q. Chen, and G. Tan, "Elasticroom: Multi-tenant dnn inference engine via co-design with resource-constrained compilation and strong priority scheduling," in Proceedings of the 33rd International Symposium on High-Performance Parallel and Distributed Computing, ser. HPDC '24. New York, NY, USA: Association for Computing Machinery, 2024, p. 1–14. [Online]. Available: https://doi.org/10.1145/3625549.3658654
- [4] V. Kandiah, S. Peverelle, M. Khairy, J. Pan, A. Manjunath, T. G. Rogers, T. M. Aamodt, and N. Hardavellas, "Accelwattch: A power modeling framework for modern gpus," in MICRO-54: 54th Annual IEEE/ACM International symposium on microarchitecture, 2021, pp. 738–753.
- [5] Y. Wang, M. Karimi, Y. Xiang, and H. Kim, "Balancing energy efficiency and real-time performance in gpu scheduling," in 2021 IEEE Real-Time Systems Symposium (RTSS), 2021, pp. 110–122.
- [6] M. Chow and D. Wong, "Cofris: Coordinated frequency and resource scaling for gpu inference servers," in *Proceedings of the 14th International Green and Sustainable Computing Conference*, ser. IGSC '23. New York, NY, USA: Association for Computing Machinery, 2024, p. 45–51. [Online]. Available: https://doi.org/10.1145/3634769.3634808
- [7] H. Zamani, D. Tripathy, A. Jahanshahi, and D. Wong, "Icap: Designing inrush current aware power gating switch for gpgpu," in 2021 IEEE International Conference on Networking, Architecture and Storage (NAS). IEEE, 2021, pp. 1–8.
- [8] A. Jahanshahi, H. Z. Sabzi, C. Lau, and D. Wong, "Gpu-nest: Characterizing energy efficiency of multi-gpu inference servers," *IEEE Computer Architecture Letters*, vol. 19, no. 2, pp. 139–142, 2020.
- [9] X. Zhao, Z. Wang, and L. Eeckhout, "Classification-driven search for effective sm partitioning in multitasking gpus," in *Proceedings of the 2018 International Conference on Supercomputing*, ser. ICS '18. New York, NY, USA: Association for Computing Machinery, 2018, p. 65–75. [Online]. Available: https://doi.org/10.1145/3205289.3205311
- [10] Q. Xu, H. Jeon, K. Kim, W. W. Ro, and M. Annavaram, "Warped-slicer: Efficient intra-sm slicing through dynamic resource partitioning for gpu multiprogramming," in 2016 ACM/IEEE 43rd Annual International Symposium on Computer Architecture (ISCA), 2016, pp. 230–242.
- [11] J. Janzén, D. Black-Schaffer, and A. Hugo, "Partitioning gpus for improved scalability," in 2016 28th International Symposium on Computer Architecture and High Performance Computing (SBAC-PAD), 2016, pp. 42–49.

- [12] M. Chow, A. Jahanshahi, and D. Wong, "Krisp: Enabling kernel-wise right-sizing for spatial partitioned gpu inference servers," in 2023 IEEE International Symposium on High-Performance Computer Architecture (HPCA), 2023, pp. 624–637.
- [13] A. Dhakal, S. G. Kulkarni, and K. K. Ramakrishnan, "Gslice: controlled spatial sharing of gpus for a scalable inference platform," in *Proceedings of the 11th ACM Symposium on Cloud Computing*, ser. SoCC '20. New York, NY, USA: Association for Computing Machinery, 2020, p. 492–506. [Online]. Available: https://doi.org/10.1145/3419111.3421284
- [14] Y. Kim, Y. Choi, and M. Rhu, "Paris and elsa: An elastic scheduling algorithm for reconfigurable multi-gpu inference servers," 2022. [Online]. Available: https://arxiv.org/abs/2202.13481
- [15] "Amd gpu hardware basics." [Online]. Available: https://www.olcf.ornl.gov/wp-content/uploads/2019/10/ORNL\_ Application\_Readiness\_Workshop-AMD\_GPU\_Basics.pdf
- [16] AMD, "AMD Graphics Core Next (GCN) Architecture." [Online]. Available: https://web.archive.org/web/20170722063801/https://www.amd.com/Documents/GCN\_Architecture\_whitepaper.pdf
- [17] —, "Dissecting the polaris architecture." [Online].

  Available: https://web.archive.org/web/20160920143439/http:
  //radeon.wpengine.netdna-cdn.com/wp-content/uploads/2016/08/
  Polaris-Architecture-Whitepaper-Final-08042016.pdf
- [18] ——, "Introducing AMD CDNA 2 Architecture." [Online]. Available: https://www.amd.com/content/dam/amd/en/documents/instinct-business-docs/white-papers/amd-cdna2-white-paper.pdf
- [19] N. Otterness and J. H. Anderson, "AMD GPUs as an Alternative to NVIDIA for Supporting Real-Time Workloads," in 32nd Euromicro Conference on Real-Time Systems (ECRTS 2020), ser. Leibniz International Proceedings in Informatics (LIPIcs), M. Völp, Ed., vol. 165. Dagstuhl, Germany: Schloss Dagstuhl – Leibniz-Zentrum für Informatik, 2020, pp. 10:1–10:23. [Online]. Available: https://drops.dagstuhl.de/entities/document/10.4230/LIPIcs.ECRTS.2020.10
- [20] AMD, "Amd rocm documentation." [Online]. Available: https://rocm. docs.amd.com/
- [21] H. Foundation, "Heterogeneous system architecture runtime programmer's reference manual." [Online]. Available: https:// hsafoundation.com/wp-content/uploads/2021/02/HSA-Runtime-1.2.pdf
- [22] Y. Wang, M. Karimi, and H. Kim, "Towards energy-efficient real-time scheduling of heterogeneous multi-gpu systems," in 2022 IEEE Real-Time Systems Symposium (RTSS), 2022, pp. 409–421.
- [23] M. Abdel-Majeed, D. Wong, and M. Annavaram, "Warped gates: Gating aware scheduling and power gating for gpgpus," in *Proceedings of the* 46th Annual IEEE/ACM International Symposium on Microarchitecture, 2013, pp. 111–122.
- [24] A. Jahanshahi, M. Rezvani, and D. Wong, "Wattwiser: Power & resource-efficient scheduling for multi-model multi-gpu inference servers," in *Proceedings of the 14th International Green and Sustainable Computing Conference*, 2023, p. 39–44.
- [25] Y. Xiang and H. Kim, "Pipelined data-parallel cpu/gpu scheduling for multi-dnn real-time inference," in 2019 IEEE Real-Time Systems Symposium (RTSS). IEEE, 2019, pp. 392–405.
- [26] J. Bakita and J. H. Anderson, "Hardware compute partitioning on nvidia gpus," in 2023 IEEE 29th Real-Time and Embedded Technology and Applications Symposium (RTAS), 2023, pp. 54–66.
- [27] Z. Lan, M. Chen, S. Goodman, K. Gimpel, P. Sharma, and R. Soricut, "Albert: A lite bert for self-supervised learning of language representations," 2020. [Online]. Available: https://arxiv.org/abs/1909. 11942
- [28] S. Puthoor, X. Tang, J. Gross, and B. M. Beckmann, "Oversubscribed command queues in gpus," in *Proceedings of the 11th Workshop on General Purpose GPUs*, ser. GPGPU-11. New York, NY, USA: Association for Computing Machinery, 2018, p. 50–60. [Online]. Available: https://doi.org/10.1145/3180270.3180271
- [29] Y. Luo, "Issue: Performance panelty caused by separated hsa queues in hip and openmp implementations." [Online]. Available: https://github.com/ROCm/ROCm/issues/2705
- [30] AMD, "Oversubscription of hardware resources in amd instinct accelerators." [Online]. Available: https://rocm.docs.amd.com/en/latest/ conceptual/oversubscription.html
- [31] N. Otterness and J. H. Anderson, "Exploring amd gpu scheduling details by experimenting with "worst practices"," in *Proceedings* of the 29th International Conference on Real-Time Networks and Systems, ser. RTNS '21. New York, NY, USA: Association

- for Computing Machinery, 2021, p. 24–34. [Online]. Available: https://doi.org/10.1145/3453417.3453432
- [32] G. Huang, Z. Liu, L. van der Maaten, and K. Q. Weinberger, "Densely connected convolutional networks," 2018. [Online]. Available: https://arxiv.org/abs/1608.06993
- [33] A. Krizhevsky, "One weird trick for parallelizing convolutional neural networks," 2014. [Online]. Available: https://arxiv.org/abs/1404.5997
- [34] K. He, X. Zhang, S. Ren, and J. Sun, "Deep residual learning for image recognition," 2015. [Online]. Available: https://arxiv.org/abs/1512.03385
- [35] S. Xie, R. Girshick, P. Dollár, Z. Tu, and K. He, "Aggregated residual transformations for deep neural networks," 2017. [Online]. Available: https://arxiv.org/abs/1611.05431
- [36] N. Ma, X. Zhang, H.-T. Zheng, and J. Sun, "Shufflenet v2: Practical guidelines for efficient cnn architecture design," 2018. [Online]. Available: https://arxiv.org/abs/1807.11164
- [37] K. Simonyan and A. Zisserman, "Very deep convolutional networks for large-scale image recognition," 2015. [Online]. Available: https://arxiv.org/abs/1409.1556
- [38] S. K. Saha, Y. Xiang, and H. Kim, "Stgm: Spatio-temporal gpu management for real-time tasks," in 2019 IEEE 25th International Conference on Embedded and Real-Time Computing Systems and Applications (RTCSA). IEEE, 2019, pp. 1–6.
- [39] Z. Wang, J. Yang, R. Melhem, B. Childers, Y. Zhang, and M. Guo, "Simultaneous multikernel: Fine-grained sharing of gpus," *IEEE Computer Architecture Letters*, vol. 15, no. 2, pp. 113–116, 2016.
- [40] J. J. K. Park, Y. Park, and S. Mahlke, "Dynamic resource management for efficient utilization of multitasking gpus," in *Proceedings of the Twenty-Second International Conference on Architectural Support for Programming Languages and Operating Systems*, ser. ASPLOS '17. New York, NY, USA: Association for Computing Machinery, 2017, p. 527–540. [Online]. Available: https://doi.org/10.1145/3037697.3037707
- [41] Z. Wang, J. Yang, R. Melhem, B. Childers, Y. Zhang, and M. Guo, "Simultaneous multikernel gpu: Multi-tasking throughput processors via fine-grained sharing," in 2016 IEEE International Symposium on High Performance Computer Architecture (HPCA), 2016, pp. 358–369.