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 性能会更好吗 ?

相关推荐
2601_9516457415 天前
C语言环境搭建指南
c语言·编译器·开发环境·helloworld·集成开发环境
大熊猫侯佩23 天前
丢掉包袱,硬刚 Rust:WWDC26 前瞻与 Swift 6.4 的底层革命
swift·编译器·wwdc
xgstb25 天前
计算机编程语言
c语言·编译器·标准·计算机编程语言·历史沿革
YangWeiminPHD1 个月前
金水32051编译器下的AI8051U单片机入门:从点亮LED到“你好,世界,我来了!”
c语言·汇编·51单片机·编译器
用户75389755281752 个月前
《手写解释器》第10章 函数
编译原理·编译器
jump_jump2 个月前
TSRX:一份源码,编译到 React / Solid / Vue / Preact / Ripple
前端框架·代码规范·编译器
YangWeiminPHD2 个月前
金水32051编译器:人与单片机CPU之间的桥梁
c语言·单片机·编译器
shada2 个月前
mini-dog-c编译器开发 - 04 递归下降解析器
c语言·编译器
shada2 个月前
mini-dog-c编译器开发 - 01 功能需求与设计
编译器