FreeBSD 中文社区 2025 第二季度问卷调查
FreeBSD 中文社区(CFC)
VitePress 镜像站QQ 群 787969044视频教程Ⅰ视频教程Ⅱ
  • FreeBSD 从入门到追忆
  • 中文期刊
  • 状态报告
  • 发行说明
  • 手册
  • 网络文章集锦
  • 笔记本支持报告
  • Port 开发者手册
  • 架构手册
  • 开发者手册
  • 中文 man 手册
  • 文章
  • 书籍
  • FreeBSD 中文期刊
  • 编辑日志
  • 2025-123 下游项目
    • FreeBSD 发布工程:新主管上任
    • GhostBSD:从易用到挣扎与重生
    • BSD Now 与将来
    • 字符设备驱动教程(第三部分)
    • 学会走路——连接 GPIO 系统
    • FreeBSD 中对 SYN 段的处理
    • FreeBSD 2024 年秋季峰会
  • 2024-1112 虚拟化
    • 字符设备驱动程序教程(第二部分)
    • 面向 Linux 和 Windows 用户的 bhyve
    • Xen 与 FreeBSD
    • Wifibox:一种嵌入式虚拟化无线路由器
    • 嵌入式 FreeBSD:Fabric——起步阶段
    • DGP:一种新的数据包控制方法
    • 会议报告:我在都柏林的 EuroBSDCon 体验
  • 2024-0910 内核开发
    • 字符设备驱动程序教程
    • VPP 移植到了 FreeBSD:基础用法
    • 利用 Kyua 的 Jail 功能提升 FreeBSD 测试套件的并行效率
    • FreeBSD 上的 Valgrind
    • 嵌入式 FreeBSD:探索 bhyve
    • TCP/IP 历险记:FreeBSD TCP 协议栈中的 Pacing
    • 实用软件:实现无纸化(Paperless)
  • 2024-0708 存储与文件系统
    • FreeBSD 中的 NVMe-oF
    • FreeBSD iSCSI 入门
    • 使用 ZFS 原生加密保护数据
    • 嵌入式 FreeBSD:打造自己的镜像
    • TCP LRO 简介
    • 基于 Samba 的时间机器备份
  • 2024-0506 配置管理对决
    • 基本系统中的 mfsBSD
    • rdist
    • Hashicorp Vault
    • 在 GitHub 上向 FreeBSD 提交 PR
    • 悼念 Mike Karels
    • 2024 年 5-6 月来信
    • 嵌入式 FreeBSD 面包板
    • TCP/IP 历险记:TCP BBLog
    • 实用软件:开发定制 Ansible 模块
  • 2024-0304 开发工作流与集成
    • FreeBSD 内核开发工作流程
    • FreeBSD 与 KDE 持续集成(CI)
    • 更现代的内核调试工具
    • 从零开始的 ZFS 镜像及 makefs -t zfs
    • 提升 Git 使用体验
  • 2024-0102 网络(十周年)
    • FreeBSD 中的 RACK 栈和替代 TCP 栈
    • FreeBSD 14 中有关 TCP 的更新
    • if_ovpn 还是 OpenVPN
    • SR-IOV 已成为 FreeBSD 的重要功能
    • FreeBSD 接口 API(IfAPI)
    • BATMAN:更优的可移动热点网络方式
    • 配置自己的 VPN——基于 FreeBSD、Wireguard、IPv6 和广告拦截
    • 实用软件:使用 Zabbix 监控主机
  • 2023-1112 FreeBSD 14.0
    • LinuxBoot:从 Linux 启动 FreeBSD
    • FreeBSD 容器镜像
    • 现在用 Webhook 触发我
    • 新的 Ports 提交者:oel Bodenmann (jbo@freebsd.org)
  • 2023-0910 Port 与软件包
    • 回忆录:与 Warner Losh(@imp)的访谈
    • 在你自己的仓库中定制 Poudriere 源
    • Wazuh 和 MITRE Caldera 在 FreeBSD Jail 中的使用
    • PEP 517
    • CCCamp 2023 旅行报告
  • 2023-0708 容器与云
    • 在 Firecracker 上的 FreeBSD
    • 使用 pot 和 nomad 管理 Jail
    • 会议报告:C 与 BSD 正如拉丁语与我们——一位神学家的旅程
    • 抒怀之旅:与 Doug Rabson 的访谈
    • 基于 Jail 的广告拦截教程
    • 我们收到的来信
  • 2023-0506 FreeBSD 三十周年纪念特刊
    • CheriBSD 近十多年的历程
    • AArch64:成为 FreeBSD 新的一级架构
    • 岁月如梭:我个人的时间线
    • 安装 FreeBSD 1.0:回顾 30 年前
    • ZFS 是如何进入 FreeBSD 的呢?
    • 我不是来自约克郡的,我保证!
    • 回忆录:采访 David Greenman Lawrence
    • FreeBSD 和早期的 Unix 社区
    • 早期的 FreeBSD 移植
    • FreeBSD 30 周年:成功的秘诀
    • FreeBSD 在日本:回忆之旅与今日之实
  • 2023-0304 嵌入式
    • CheriBSD port 和软件包
    • 让我们来试试 ChatGPT
    • GPU 直通
  • 2023-0102 构建 FreEBSD Web 服务器
    • ZFS 的原子 I/O 与 PostgreSQL
    • 虚拟实验室——BSD 编程研讨会
    • ZFS 简介
    • 会议报告:落基山庆祝女性计算机科学家
    • 进行中的工作/征求反馈:数据包批处理
    • 基金会与 FreeBSD 桌面
  • 2022-1112 可观测性和衡量标准
    • 在 FreeBSD 的 DDB 内核调试器中编写自定义命令
    • DTrace:老式跟踪系统的新扩展
    • 基于证书的 Icinga 监控
    • 活动监控脚本(activitymonitor.sh)
    • 实用 IPv6(第四部分)
    • EuroBSDCon 会议报道
    • 实用 Port:Prometheus 的安装与配置
    • 书评:《用火解决问题:管理老化的计算机系统(并为现代系统保驾护航)》Kill It with Fire: Manage Aging Computer Systems (and Future Proof Modern Ones)
  • 2022-0910 安全性
    • CARP 简介
    • 重构内核加密服务框架
    • PAM 小窍门
    • SSH 小窍门
    • 实用 IPv6(第三部分)
    • 书评:Understanding Software Dynamics(深入理解软件性能——一种动态视角)—— Richard L. Sites 著
    • 访谈:保障 FreeBSD 安全性
    • MCH 2022 会议报告
  • 2022-0708 科研、系统与 FreeBSD
    • 在 FreeBSD 上构建 Loom 框架
    • 教授本科生 Unix 课程
    • FreeBSD 入门研讨会
    • 实用 IPv6(第二部分)
    • 在 2022 年及以后推广 FreeBSD
    • 进行中的工作/征求反馈:Socket 缓冲区
    • FreeBSD 开发者峰会报告
    • 支持 Electromagnetic Field 2022
  • 2022-0506 灾难恢复
    • 使用 FreeBSD 构建高弹性的私有云
    • LLDB 14 —— FreeBSD 新调试器
    • 实用 IPv6(第一部分)
    • 利用 netdump(4) 进行事后内核调试
    • 进行中的工作/征求反馈:FreeBSD 启动性能
    • 实用 Port:在 OpenZFS 上设置 NFSv4 文件服务器
  • 2022-0304 ARM64 是一级架构
    • FreeBSD/ARM64 上的数据科学
    • Pinebook Pro 上的 FreeBSD
    • 嵌入式控制器的 ACPI 支持
    • 进行中的工作/征求反馈:Lumina 桌面征集开发人员
    • 实用 Port:如何设置 Apple 时间机器
  • 2022-0102 软件与系统管理
    • 为 FreeBSD Ports 做贡献
    • 使用 Git 贡献到 FreeBSD Ports
    • CBSD:第一部分——生产环境
    • 将 OpenBSD 的 pf syncookie 代码移植到 FreeBSD 的 pf
    • 进行中的工作/征求反馈:mkjail
    • 《编程智慧:编程鬼才的经验和思考》(The Kollected Kode Vicious)书评
    • 会议报告:EuroBSDCon 2021 我的第一次 EuroBSDCon:一位新组织者的视角
  • 2021-1112 存储
    • 开放通道 SSD
    • 构建 FreeBSD 社区
    • 与完美操作系统同行 27 年
    • 进行中的工作/征求反馈:OccamBSD
    • 通过 iSCSI 导入 ZFS ZIL——不要在工作中这样做——就像我做的那样
  • 2021-0910 FreeBSD 开发
    • FreeBSD 代码审查与 git-arc
    • 如何为 FreeBSD 实现简单的 USB 驱动程序
    • 内核开发技巧
    • 程序员编程杂谈
  • 2021-0708 桌面/无线网
    • 通往 FreeBSD 桌面的直线路径
    • FreeBSD 13 中的人机接口设备 (HID) 支持
    • Panfrost 驱动程序
    • 用 Git 更新 FreeBSD
    • FreeBSD 的新面孔
    • 想给你的桌面加点佐料?
  • 2021-0506 安全
    • 七种提升新安装 FreeBSD 安全性的方法
    • copyinout 框架
    • 使用 TLS 改善 NFS 安全性
    • Capsicum 案例研究:Got
    • 对 Jail 进行安全扫描
  • 2021-0304 FreeBSD 13.0
    • 展望未来
    • FreeBSD 13.0 工具链
    • FreeBSD 13.0 中有新加载器吗?
    • TCP Cubic 准备起飞
    • OpenZFS 中的 Zstandard 压缩
    • 会议报告:FreeBSD 供应商峰会
    • Git 不够吗?
  • 2021-0102 案例研究
    • Tarsnap 的 FreeBSD 集群
    • BALLY WULFF
    • Netflix Open Connect
    • FreeBSD 的新面孔
    • 写作学者的 FreeBSD
    • 在世界之巅
  • 2020-1112 工作流/持续集成(CI)
    • FreeBSD Git 快速入门
    • 使用 syzkaller 进行内核 Fuzzing
    • Mastering Vim Quickly 书评
    • 线上会议实用技巧
    • 在控制台上进行网络监控
  • 2020-0910 贡献与入门
    • 采访:Warner Losh,第 2 部分
    • 代码审查
    • 撰写良好的提交消息
    • 如何在不是程序员的情况下做出贡献——成为 FreeBSD 译者
    • 如何成为文档提交者
    • 谷歌编程之夏
    • 为 FreeBSD 期刊撰写文章
    • 你为什么使用 FreeBSD
    • FreeBSD 的新面孔
  • 2020-0708 基准测试/调优
    • FreeBSD Friday
    • 采访:Warner Losh,第 1 部分
    • 构建和运行开源社区
    • 在 FreeBSD 上轻松搭建我的世界(Minecraft)服务器
    • FreeBSD 的新面孔
  • 2020-0506 网络性能
    • 内核中的 TLS 卸载
    • 访谈:Michael W Lucas
    • FreeBSD 桌面发行版
    • 使用 Poudriere 进行 Port 批量管理
    • FreeBSD 的新面孔
由 GitBook 提供支持
LogoLogo

FreeBSD 中文社区(CFC) 2025

在本页
  • 编译器
  • 链接器
  • 二进制工具
  • 源代码级调试器
  • CTF 工具
  • 诊断工具
  • 后续工作
在GitHub上编辑
导出为 PDF
  1. 2021-0304 FreeBSD 13.0

FreeBSD 13.0 工具链

上一页展望未来下一页FreeBSD 13.0 中有新加载器吗?

最后更新于1个月前

  • 原文链接:

  • 作者:ED MASTE

FreeBSD 13.0 标志着 FreeBSD 工具链演变的一个重要里程碑:完成了长达十年的迁移,采用现代的、许可宽松的编译器、链接器、调试器以及其他各种二进制工具,适用于所有 FreeBSD 支持的架构。

从一开始,FreeBSD 就依赖 GNU 工具链,包括 GCC 编译器、Binutils 链接器和二进制工具,以及 GDB 调试器。这些工具通过一群开发者的定期更新得到了保持,包括志愿者和付费开发者。这一过程持续到 2007 年,当时 GNU 项目将这些工具的许可证更改为 GNU 通用公共许可证第 3 版(GPLv3),之后它们再也没有更新。

几年后,大约二十名开发者在 2010 年 BSDCan 大会上的开发者峰会上会面,规划工具链的未来,目标是迁移到一个现代的、许可宽松的工具链。许可证问题只是其中的一部分理由。新技术、实施新的和定制功能的能力,以及推动开源工具的竞争也成为团队目标的一部分。

与此同时,多个工具链项目在 FreeBSD 项目内部和外部逐渐成形。峰会与会者注意到,LLVM 和 Clang 正在迅速成熟,并且在编译器研究社区中获得越来越多的关注。一款 BSD 许可的 ELF 工具链项目也在进行中,同时还有多个调试器项目。

团队设定了与这些工具链项目合作并迁移到新组件的目标。随着个别组件变得可用,它们被逐步添加到 FreeBSD 中,通常与现有工具并行安装,但默认禁用。在测试和验证后,它们成为默认工具,有时是逐架构启用。最终,新的工具在所有支持的架构中启用,旧的工具则被移除。除了调试器的一个小例外,现在,所有工具链组件和所有支持的架构的迁移已经完成。请继续阅读,了解详细信息。

编译器

编译器是工具链中最重要的组件之一,也是我们迁移的首个主要组件。Clang 编译器于 2007 年首次发布,并迅速成熟。Roman Divacky 于 2010 年 6 月将一个版本导入 FreeBSD 的 contrib 软件树,并在 FreeBSD 9.0 中为 x86 和 PowerPC 架构提供了它(作为 /usr/bin/clang)。

在 Clang 开发者的大力努力以及 Roman、Ed Schouten、Dimitry Andric 等人的集成工作下,我们在 2012 年将 Clang 启用为 i386 和 amd64 的默认编译器(/usr/bin/cc)。这一版本随 FreeBSD 10.0 发布。

2014 年,Clang 准备好成为小端 Arm 架构的默认编译器。它也在 PowerPC 上提供,但并非默认编译器。这是 FreeBSD 11.0 中的配置。FreeBSD 11.0 还引入了对 64 位 ARM(AArch64)的支持,并且 Clang 是唯一可用的编译器。

在 FreeBSD 12.0 发布之前,编译器更新持续进行,但架构支持保持不变。2019 年和 2020 年,Clang/LLVM 上游的架构改进显著,剩余的架构,包括 RISC-V 和 MIPS,都切换为默认使用 Clang。Sparc64 是唯一仍然依赖过时的内置 GCC 版本的架构。随着 FreeBSD/sparc64 被淘汰,树中不再需要保留 GCC,因此在 2020 年初将其移除。

工具链通常包括汇编器。从 FreeBSD 13.0 开始,我们使用 Clang 的集成汇编器(IAS)来组装 FreeBSD 基本系统的一部分,不再提供独立的 /usr/bin/as。

使用 Clang 作为 FreeBSD 的标准编译器,使其成为进行全系统研究的一个引人注目的系统。剑桥大学的时序增强安全逻辑断言(TESLA)和能力硬件增强 RISC 指令(CHERI)研究项目基于 Clang/LLVM,并从提供完整的、Clang 构建的操作系统内核和用户空间中受益。

链接器

链接器将目标文件和库合并成可执行文件或共享库。当工具链项目开始时,没有一个具有明确可行路径的替代链接器。MCLinker 项目展示了一些初步的势头,但最终没有支持 FreeBSD 构建所需的许多功能。

到了 2015 年,LLVM 的 lld 取得了良好的进展,我们在 2016 年导入了一个快照。最初,我们将其作为默认构建,但安装时使用非默认文件名。它可以通过编译器参数 -fuse-ld=lld 使用。

到了 FreeBSD 12.1,lld 已为除 sparc64 和 riscv64 外的所有架构构建,并成为 32 位和 64 位 ARM 以及 x86 的默认链接器。随着 lld 上游对 riscv64 支持的开发和 sparc64 的淘汰,lld 成为 FreeBSD 13.0 中所有架构的唯一链接器。

二进制工具

工具链包括一些小工具,用于检查或处理目标文件、库和可执行文件——在 FreeBSD 中是 ELF 对象。这些工具包括像 size、strings 和 readelf 这样的文件检查工具,objcopy 用于转换或处理对象文件,ar 用于创建和提取库档案。此类别还包括其他工具用于解析对象的库——例如,libelf 和 libdwarf。

在较早版本的 FreeBSD 中,这些工具大多来自 GNU binutils,少数例外——例如,档案管理工具是基于 libarchive 的定制工具。FreeBSD 从 2006 年开始还实现了 libelf 和 libdwarf 的版本。

ELF 工具链项目始于 2008 年作为一个独立的努力,由 Joseph Koshy 主导。该项目导入了一些现有的 FreeBSD 工具和库,更多的贡献者也加入了项目。Kai Wang 实现了许多缺失的工具,包括 elfcopy/objcopy 和 readelf。

到了 2015 年,ELF 工具链版本的 addr2line、elfcopy/objcopy、nm、size 和 strings 功能足够完善,以至于我们默认切换使用它们,并在 FreeBSD 11.0 中发布。

这一工作没有涉及汇编器或链接器;虽然 ELF 工具链中开始着手这两个工具的工作,但目前它们还不可用。我们通过依赖 Clang 的集成汇编器来解决汇编器问题,并将大多数架构切换到 LLVM 的 lld 作为链接器。Sparc64 是唯一依赖内置 GNU ld 的架构。随着 sparc64 支持的退役,我们能够在 FreeBSD 13.0 发布前将 binutils 从 FreeBSD 树中移除。

从 binutils 的迁移还使得 FreeBSD 在基本系统中移除了 objdump。objdump 提供的大部分信息(以略微不同的格式)也可以通过 readelf 获得,并且 LLVM 提供了一个 llvm-objdump,它在很大程度上是兼容的。该工具尚未在基本系统中默认安装,但很可能会在未来的版本中启用。当然,也可以通过安装 binutils 的 Port 或软件包来获取 GNU objdump。

源代码级调试器

剩下的工具链组件是调试器,LLVM 在这里也提供了前进的路径。LLDB 是 LLVM 的调试器,已在之前的 FreeBSD Journal 文章中详细描述。它基于 LLVM 组件进行反汇编,使用 Clang 作为表达式解析器,并且可以通过 Python 和 Lua 脚本化。

我们在 2013 年将 LLDB 作为实验性功能添加到构建中,在 FreeBSD 10.0 发布之前,并在 2015 年为 amd64 和 arm64 启用默认支持,随 FreeBSD 11.0 发布。在 2017 年,Karnajit Wangkhem 提交了一个补丁,添加了对 i386 JIT 表达式引擎的支持,我们在 FreeBSD 12.0 中将其作为默认功能启用。

LLDB 包括对 32 位 ARM、PowerPC 和 MIPS 的 FreeBSD 目标支持,尽管其测试尚不充分。经过足够的测试和集成后,可能会默认启用这些构建。LLDB 现在是一个功能完整的 FreeBSD 用户空间调试器,但目前缺乏内核调试支持。

在 FreeBSD 基金会的赞助下,Moritz Systems 最近修复了许多未解决的 bug,改善了 arm64 目标支持,添加了初步的跟随 fork 模式,并正在改进用户空间核心文件调试。关于实现实时内核调试和死后内核核心转储支持的项目正在讨论中。我们还需要实现 RISC-V 目标支持。

CTF 工具

FreeBSD 的 DTrace 支持使用了紧凑 C 类型格式(CTF),该格式提供了最小的调试信息,使 C 语言类型能够在 DTrace 脚本中使用。目前,使用了三种工具,这些工具根据通用开发与分发许可协议(CDDL)发布。它们实现了 CTF 版本 2,自从 2008 年从 OpenSolaris 导入 DTrace 以来几乎没有改变。

也有许多替代的 CTF 工具实现可用。现代的 binutils 包括了 libctf,这是一个解析和编辑 CTF 数据的库。CTF 格式已经扩展到版本 3,并且最近扩展到了版本 4。此外,OpenBSD 的 Martin Pieuchot 实现了一套最小的、具有宽松许可的 CTF 工具。未来的 FreeBSD 工具链工作将需要确定如何使用这些 CTF 工具。

诊断工具

Valgrind 是一套用于内存访问、内存泄漏调试以及检查程序行为其他方面的工具。FreeBSD 对 Valgrind 的支持已经在主 Valgrind 树之外维护了近二十年,已修补的 Valgrind 可以从 Ports 和软件包集合中获得。多年来,许多不同的开发者维护并更新了 FreeBSD 的 Valgrind Port;最近,Paul Floyd 更新了它到最新发布的版本 3.17.0,并正在努力将 FreeBSD 的更改提交到上游。

Clang 包括对各种 sanitizers 的内建支持,这些工具提供调试和诊断信息。AddressSanitizer 检测内存错误,如越界访问或使用后释放,可以通过命令行标志 -fsanitize=address 使用(使用基本系统中的 Clang)。一个相关的工具,MemorySanitizer,检测未初始化变量的读取。ThreadSanitizer 检测数据竞争,UndefinedBehaviourSanitizer 捕获运行时的未定义 C 行为(如有符号整数溢出)。其他 sanitizers 也存在,但需要更多的工作才能在 FreeBSD 上启用。

Clang 还包括一款静态分析器,通过 scan-build 前端调用。它可以通过 LLVM 包安装的 Clang 使用,而不是基本系统中的 Clang。静态分析器的作用与编译器警告相似,但层次更高。

对于代码覆盖率分析,LLVM 提供了 llvm-cov。它也作为 gcov 安装,并在通过别名调用时以 GNU、gcov 兼容模式运行。当程序以 --coverage 编译时,它在退出时会生成一个 .gcov 文件,gcov 使用该文件显示源代码每行(或基本块)的执行次数。性能分析可以通过定制的 BSD 许可证代码实现:hwpmc 内核支持和 pmcstat 用户空间工具。

后续工作

随着向 Clang/LLVM 的过渡完成,工具链团队正在研究如何在此基础上进行扩展。其中之一是链接时优化(LTO),即在链接阶段执行的模块间优化。实际上,LTO 使用包含 LLVM 中间表示(IR)的目标文件和库,而不是目标二进制 ELF 对象。这允许在链接时将这些文件组合起来,并让 LLVM 优化传递作用于整个二进制文件,而不仅仅是单独的编译单元。LTO 的一个注意事项是,nm 和 ar 工具需要能够解析 LLVM IR 符号表,而基本系统使用的 ELF Tool Chain 版本不具备此功能。我们需要扩展 ELF Tool Chain 中的 nm 和 ar 工具,或切换到 LLVM 版本的这些工具。

Clang 提供的另一个工具链特性是控制流完整性(CFI)。CFI 广泛指的是编译器使用的技术,以避免恶意软件在获得执行权限后,试图破坏程序预定的操作(控制流)。Clang 的 CFI 支持需要 LTO,并包含多个单独的检查,用于检测各种不良类型转换和无效间接调用的情况。

CHERI 项目为 FreeBSD 工具链的未来工作提供了另一个机会。CheriBSD 是 FreeBSD 的衍生版本,实施了 CHERI 内存保护和软件隔离,并在外部代码库中维护。CHERI 还包括一款基于 LLVM 的工具链,支持多个 CHERI 增强的指令集架构(ISA)。


ED MASTE 负责 FreeBSD 基金会的项目开发。他也是选举产生的 FreeBSD 核心团队成员。除了 FreeBSD,他还为许多其他开源项目做出了贡献,包括 LLVM、ELF Tool Chain、QEMU 和 Open vSwitch。他与妻子 Anna 以及孩子 Pieter 和 Daniel 住在加拿大滑铁卢。

FreeBSD 13.0 Toolchain