1. LTO
由于ThinLTO在编译时间上的巨大优势,LLVM默认跑的是ThinLTO,如果想跑LTO,需要在LLVM二进制里将IsThinLTO属性至为0(false),然后在链接阶段就会跑LTO,LTO的实现比较简单,就是将输入的所有bc都链接成一个大的module,然后在整个module上进行分析优化。
2. ThinLTO
2.1 ThinLTO的使用
LLVM默认就会跑ThinLTO,但是前提是我们在链接时候使用的bc有summary信息(这是ThinLTO实现的关键,可以通过选项--module-summary来生成summary信息)。
2.2 ThinLTO增量编译
ThinLTO增量编译的前提是bc中有module-hash,然后在链接阶段通过选项--thinlto-cache-dir=<value>指定cache目录,我们在链接的时候能够在在目录中生成cache文件。下一次在编译的时候就可以直接使用cache已经优化好的缓存文件。
有待补充。。。。。。
文章介绍了LLVM默认采用的ThinLTO技术,它在编译时提供时间优势。LTO通过合并所有输入模块进行优化,而ThinLTO依赖于模块摘要信息。ThinLTO还支持增量编译,利用--thinlto-cache-dir指定缓存目录以提升效率。
3739

被折叠的 条评论
为什么被折叠?



