@inproceedings{2793e882b66a440f826f2049106d38d5,
title = "Providing fairness on shared-memory multiprocessors via process scheduling",
abstract = "Competition for shared memory resources on multiprocessors is the most dominant cause for slowing down applications and makes their performance varies unpredictably. It exacerbates the need for Quality of Service (QoS) on such systems. In this paper, we propose a fair-progress process scheduling (FPS) policy to improve system fairness. Its strategy is to force the equally-weighted applications to have the same amount of slowdown when they run concurrently. The basic approach is to monitor the progress of all applications at runtime. When we find an application suffered more slowdown and accumulated less effective work than others, we allocate more CPU time to give it a better parity. Our policy also allows different weights to different threads, and provides an effective and robust tuner that allows the OS to freely make tradeoffs between system fairness and higher throughput. Evaluation results show that FPS can significantly improve system fairness by an average of 53.5% and 65.0% on a 4-core processor with a private cache and a 4-core processor with a shared cache, respectively. The penalty is about 1.1% and 1.6% of the system throughput. For memory-intensive workloads, FPS also improves system fairness by an average of 45.2% and 21.1% on 4-core and 8-core system respectively at the expense of a throughput loss of about 2%.",
keywords = "memory bandwidth, performance fairness, process scheduling",
author = "Di Xu and Chenggang Wu and Yew, {Pen Chung} and Jianjun Li and Zhenjiang Wang",
year = "2012",
doi = "10.1145/2254756.2254792",
language = "English (US)",
isbn = "9781450310970",
series = "Performance Evaluation Review",
number = "1 SPEC. ISS.",
pages = "295--306",
booktitle = "SIGMETRICS/Performance 2012 - Proceedings of the 2012 ACM SIGMETRICS/Performance, Joint International Conference on Measurement and Modeling of Computer Systems",
edition = "1 SPEC. ISS.",
note = "12th Joint International Conference on Measurement and Modeling of Computer Systems, ACM SIGMETRICS/Performance 2012 ; Conference date: 11-06-2012 Through 15-06-2012",
}