ThreeWayBranch 优化阅读笔记

1. 优化目的

通过重排三分支的 BB 块减少比较指令的执行次数

代码路径:

bash 复制代码
bolt/lib/Passes/ThreeWayBranch.cpp

2. 效果

优化前:
注: 黄色数字表示BB块编号, 紫色表示该分支跳转的次数,绿色是代码里BB块的变量名

ThreeWayBranch 优化后:

注: BB块1.5 会在后面的优化删除

ThreeWayBranch + reorder-block 优化后:

测试用例:

bolt/test/runtime/X86/three-way-branch-pass.s

asm 复制代码
    .text
    .globl main
    .type main, %function
    .size main, .Lend-main
main:
    mov $0x0, %eax
    cmp $0x1, %eax
    jge .BB1
    mov $0xf, %eax
    xor %eax, %eax
    retq
.BB1:
    jg .BB2
    retq
.BB2:
    mov $0x7, %eax
    retq
.Lend:

遗留问题:

优化后的 BB 5 跳转变成 fallthrough 性能会更好吗 ?

相关推荐
杨艺韬6 天前
Rust编译器原理-第11章 闭包:匿名函数的编译器实现
rust·编译器
杨艺韬6 天前
Rust编译器原理-第15章 MIR 优化:编译器的中间表示与优化管线
rust·编译器
杨艺韬6 天前
Rust编译器原理-第6章 单态化:泛型的编译期展开
rust·编译器
杨艺韬6 天前
Rust编译器原理-第14章 宏系统:编译期的元编程引擎
rust·编译器
杨艺韬6 天前
Rust编译器原理-第16章 LLVM 代码生成:从 MIR 到机器码
rust·编译器
杨艺韬6 天前
Rust编译器原理-第5章 内存布局:编译器如何排列数据
rust·编译器
杨艺韬6 天前
Rust编译器原理-第3章 借用检查器:编译器如何证明内存安全
rust·编译器
杨艺韬6 天前
Rust编译器原理-第9章 async/await:状态机的编译器变换
rust·编译器
杨艺韬6 天前
Rust编译器原理-第8章 Trait Object 与虚表:运行时多态的内存布局
rust·编译器
杨艺韬6 天前
Rust编译器原理-第13章 FFI:与 C 世界的桥梁
rust·编译器