惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

SecWiki News
SecWiki News
I
InfoQ
The Cloudflare Blog
人人都是产品经理
人人都是产品经理
博客园 - Franky
T
Tailwind CSS Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
量子位
博客园_首页
罗磊的独立博客
V
V2EX
李成银的技术随笔
大猫的无限游戏
大猫的无限游戏
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
True Tiger Recordings
Vercel News
Vercel News
Cyberwarzone
Cyberwarzone
Cisco Talos Blog
Cisco Talos Blog
F
Fox-IT International blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
M
Microsoft Research Blog - Microsoft Research
Know Your Adversary
Know Your Adversary
爱范儿
爱范儿
The Register - Security
The Register - Security
G
Google Developers Blog
The Hacker News
The Hacker News
Malwarebytes
Malwarebytes
S
Securelist
博客园 - 三生石上(FineUI控件)
Jina AI
Jina AI
T
Threat Research - Cisco Blogs
T
The Exploit Database - CXSecurity.com
S
SegmentFault 最新的问题
博客园 - 叶小钗
F
Fortinet All Blogs
Apple Machine Learning Research
Apple Machine Learning Research
宝玉的分享
宝玉的分享
博客园 - 聂微东
T
Threatpost
博客园 - 【当耐特】
D
Docker
P
Privacy & Cybersecurity Law Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
G
GRAHAM CLULEY
V
Visual Studio Blog
C
Cisco Blogs
IT之家
IT之家
S
Security Archives - TechRepublic
Latest news
Latest news
阮一峰的网络日志
阮一峰的网络日志

Jun's Blog

2023 年度总结 OS 学习记 之 XV6 如何编译 GraalVM LLVM 中端优化之 InstCombine C++ 中 inline 关键字的语义 链接与库 C++ 移动语义基础 如何优化矩阵相乘 2022年度总结 CUDA初学笔记 汇编语言之保护模式 汇编语言之实模式 浅析 libc++ 中的 string 实现 std::expected 基本使用 C++模板基础 CSAPP第九章笔记之虚拟内存 CSAPP第八章笔记之异常控制流 2021年度总结 编译安装GCC12 CSAPP第三章笔记Part 2 CSAPP第三章笔记Part 1 GDB基本使用笔记 读Effetive Modern C++ 之类型推导 给计算机新生的一封信 CMake学习笔记 由Redis学习数据结构--字典 C++中lambda表达式基础 由Redis学习数据结构--链表 对Python及爬虫行业的思考 Vim实用技巧 浅谈C++中的类 简要剖析const关键字 正则表达式基础总结 使用Hugo和Firebase部署个人博客 浅谈HTTPS证书 Linux下使用v2ray 娱乐至死读书笔记 自控力读书笔记 少有人走的路力读书笔记 Postfix & Dovecot 自建邮箱服务 Linux用户管理 Linux常用命令总结 Linux开机流程 Git学习笔记 Linux文件与目录 Linux硬盘管理 Linux服务浅谈 About Me
如何给LLVM贡献代码
2021-12-11 · via Jun's Blog

· Jun

LLVM 简介

LLVM的代码托管在Github,截止到这篇博客 发出时,其Bug tracker 已经从原来的Bugzilla 成功迁移到了Github issue上, 具体可以看这封邮件。但是LLVM暂时不接受,或者说主项目不接受Github PR, 而是使用Phabricator

编译安装

1
git clone https://github.com/llvm/llvm-project.git

如果不希望保留以前的Git历史的话,可以使用:

1
git clone --depth=1 https://github.com/llvm/llvm-project.git

这会极大减少下载时间和硬盘占用。

构建工具

因为LLVM是使用C++14标准写的(实际上使用了很多C++17特性),所以我们要保证我们的编译器支持其标准,以及有其它配套的构建工具:

  • ninja
  • cmake
  • gcc/clang/MSVC
  • ccache
  • gold
1
2
cd llvm-project
mkdir build && cd build
1
2
3
4
5
6
7
8
cmake -DCMAKE_BUILD_TYPE=Release  \
      -DLLVM_TARGETS_TO_BUILD=X86 \
	  -DLLVM_USE_LINKER=gold      \
      -DBUILD_SHARED_LIBS=ON      \
      -DLLVM_CCACHE_BUILD=ON      \
	  -DLLVM_APPEND_VC_REV=OFF     \
	  -DLLVM_ENABLE_PROJECTS="clang;clang-tools-extra" \
      -G"Ninja" ../llvm

可以看到在cmake配置中我们使用了大量额外选项,这主要是为了减少编译时间和硬盘占用:

  • DLLVM_USE_LINKER=gold 使用gold而不是默认的ld,这可以减少链接时的内存消耗
  • BUILD_SHARED_LIBS=ON 默认LLVM会使用静态链接,这会导致非常夸张的硬盘消耗,个人建议 使用shared library。
  • DLLVM_CCACHE_BUILD=ON 使用ccache, 这样当我们修改代码重新编译后只会编译修改的部分, 便免消耗时间重新编译未更改的代码。
  • Ninja 可以比make更快地编译。
  • LLVM_APPEND_VC_REV=OFF 避免git pull后无意义的重新链接
  • LLVM_ENABLE_PROJECTS可以选择启用的子项目,我们这里只编译clangclang-tools-extra
1
ninja

提交代码

前面说到LLVM使用的是Phabricator,而不是Github PR。如果你需要在Phabricator注册一个账号,可以直接将Github账号绑定在一起。

在命令行中提交代码个人认为比较简单,只要使用官方提供的工具arcanist即可。当然使用Web界面也是可以的,但是要麻烦的多,具体可以看LLVM官方的文档

下载安装:

1
2
3
git clone https://github.com/phacility/arcanist.git
cd arcanist
git fetch https://github.com/rashkov/arcanist update_cacerts

将其添加到环境变量中:

1
export PATH="$PATH:/somewhere/arcanist/bin/"

授权登陆:

1
arc install-certificate

在写代码的时候可以使用git commit --amend将多个提交压缩成一个,从而以patch的形式发出去。 举个例子:

1
2
3
4
5
6
git checkout -b patch
# make some changes
git add .
git commit
# make more changes
git commit --amend -a

当我们的patch在本地通过测试后,便可以准备发出去了,但在此之前一定要注意用clang-format保证我们的 patch符合LLVM Coding Style。

建议使用LLVM官方提供的git-clang-format工具,效果最好,避免意外修改到其他的代码。 可以直接将git-clang-format复制一份到PATH所在的路径中就可以了,比如/usr/local/bin

1
git clang-format HEAD~1

注意format后并不会自动提交,所以你需要:

1
git commit --amend -a

寻找Reviewer

arcanist提供了一个选项帮助我们寻找潜在的Reviewer:

1
arc cover

这会在终端中显示同样修改过最近一个commit中的文件的所有人。注意显示的只是修改者的人名, 而我们需要的是他们在Phabricator中的账号名。此后:

1
arc diff --reviewers=account1,account2

接着你便需要写一个title和summary,这个之后会作为commit message。成功后arcanist会给我们 一个链接,这便是我们的Revision啦。

更新patch

再Reviewer看过代码后,可能会给我们一些修改的建议,我们可以继续使用arcanist更新我们的patch:

1
2
# make some changes
git commit --amend -a

其中DXXXXX是我们之前的Revision,因为arcanist无法知道上下文,所以我们必须手动指定。

1
arc diff `git merge-base HEAD origin` --update DXXXXX

社区支持

LLVM有一个非常活跃,非常热情的社区。如果遇到了任何问题,完全可以寻找社区的帮助,那里有大量的志愿者非常乐意回答你的问题。当然,和所有成熟的开源项目一样,LLVM有着非常丰富的文档,善于从文档中寻找解决答案也是一项重要的技能。

Happy Hacking :^)