A graph-based iterative compiler pass selection and phase ordering approach

编译程序 计算机科学 过程间优化 加速 并行计算 优化编译器 管道(软件) 图形 循环优化 绩效改进 算法 理论计算机科学 程序设计语言 运营管理 经济
作者
Ricardo Nobre,Luiz G. A. Martins,João M. P. Cardoso
标识
DOI:10.1145/2907950.2907959
摘要

Nowadays compilers include tens or hundreds of optimization passes, which makes it difficult to find sequences of optimizations that achieve compiled code more optimized than the one obtained using typical compiler options such as -O2 and -O3. The problem involves both the selection of the compiler passes to use and their ordering in the compilation pipeline. The improvement achieved by the use of custom phase orders for each function can be significant, and thus important to satisfy strict requirements such as the ones present in high-performance embedded computing systems. In this paper we present a new and fast iterative approach to the phase selection and ordering challenges resulting in compiled code with higher performance than the one achieved with the standard optimization levels of the LLVM compiler. The obtained performance improvements are comparable with the ones achieved by other iterative approaches while requiring considerably less time and resources. Our approach is based on sampling over a graph representing transitions between compiler passes. We performed a number of experiments targeting the LEON3 microarchitecture using the Clang/LLVM 3.7 compiler, considering 140 LLVM passes and a set of 42 representative signal and image processing C functions. An exhaustive cross-validation shows our new exploration method is able to achieve a geometric mean performance speedup of 1.28x over the best individually selected -OX flag when considering 100,000 iterations; versus geometric mean speedups from 1.16x to 1.25x obtained with state-of-the-art iterative methods not using the graph. From the set of exploration methods tested, our new method is the only one consistently finding compiler sequences that result in performance improvements when considering 100 or less exploration iterations. Specifically, it achieved geometric mean speedups of 1.08x and 1.16x for 10 and 100 iterations, respectively.

科研通智能强力驱动
Strongly Powered by AbleSci AI
科研通是完全免费的文献互助平台,具备全网最快的应助速度,最高的求助完成率。 对每一个文献求助,科研通都将尽心尽力,给求助人一个满意的交代。
实时播报
艾米修兔完成签到,获得积分10
1秒前
1秒前
Lifel发布了新的文献求助10
2秒前
ding应助迷路枫采纳,获得10
3秒前
酷波er应助淡淡戎采纳,获得10
4秒前
Copyright应助BBF3采纳,获得10
5秒前
dhzlzz发布了新的文献求助10
5秒前
豚踢兔发布了新的文献求助10
7秒前
田様应助宝宝熊的熊宝宝采纳,获得10
9秒前
刘霞完成签到 ,获得积分20
9秒前
我要发一刊完成签到,获得积分10
10秒前
10秒前
luilui0000完成签到 ,获得积分10
10秒前
11秒前
12秒前
12秒前
魔幻嘉懿发布了新的文献求助10
15秒前
17秒前
DAHove发布了新的文献求助20
17秒前
17秒前
迷路枫发布了新的文献求助10
18秒前
是~巧呀完成签到,获得积分10
19秒前
上好佳发布了新的文献求助10
19秒前
kkkk完成签到,获得积分20
21秒前
自由马儿发布了新的文献求助10
22秒前
背后的代秋完成签到,获得积分10
24秒前
24秒前
25秒前
26秒前
李太白完成签到,获得积分10
26秒前
28秒前
秋星人完成签到,获得积分20
28秒前
李健的小迷弟应助gyq采纳,获得10
28秒前
30秒前
lyf471发布了新的文献求助30
31秒前
meelerfor完成签到 ,获得积分10
31秒前
31秒前
xukaixuan001完成签到,获得积分10
33秒前
二十三点一完成签到,获得积分10
33秒前
34秒前
高分求助中
(应助此贴封号)【重要!!请各用户(尤其是新用户)详细阅读】【科研通的精品贴汇总】 10000
Cronologia da história de Macau 5000
Petrology and Plate Tectonics 800
Electrode Potentials 550
Matrix Methods in Data Mining and Pattern Recognition 510
Association of Reentry Well-Being with Psychological Distress, Employment, and Housing Instability 15-Months After Incarceration 500
Trees of tropical Asia : an illustrated guide to diversity 500
热门求助领域 (近24小时)
化学 材料科学 医学 生物 纳米技术 工程类 有机化学 化学工程 生物化学 计算机科学 内科学 物理 复合材料 催化作用 细胞生物学 无机化学 光电子学 物理化学 电极 基因
热门帖子
关注 科研通微信公众号,转发送积分 7029603
求助须知:如何正确求助?哪些是违规求助? 8699548
关于积分的说明 18431904
捐赠科研通 6530455
什么是DOI,文献DOI怎么找? 3112251
关于科研通互助平台的介绍 2190157
邀请新用户注册赠送积分活动 2087741