Fedora Linux 已经支持使用 glibc HWCAPs,允许为不同的 x86_64 微体系结构功能级别构建库,用于对性能敏感的代码,这样在利用 AVX/AVX2 或其他较新的 Intel/AMD CPU 指令集扩展时可以获得性能上的回报。 现在,Fedora 42 提议进一步扩展该功能,允许二进制可执行文件也利用 glibc HWCAP 获得更好的表现。
Fedora 42 已提交变更提议,允许为 x86_64 微体系结构特性级别提供优化的二进制文件。 其目的是将 glibc-hwcaps 机制扩展到完整的可执行文件,而不仅仅是共享库。
"单个软件包可以通过 glibc-hwcaps 机制提供已优化的库。 这种方法将扩展到可执行文件。 软件包提供不同目录下二进制文件的优化变体。 它是一个小程序的符号链接,用于替换 /usr/bin 中的二进制文件。 运行时,该程序将找到最合适的变体并执行它。哪些软件包提供优化代码,以及在哪个级别上提供优化代码,将由各个软件包维护者根据基准测试结果决定。
...
本变更是关于将 glibc-hwcaps 机制扩展到可执行文件。 我们提供了一个小的辅助二进制文件。 /usr/bin(或其他路径)中的程序会被链接到该辅助程序。 执行时,辅助程序会检查 CPU 的能力,并在单独的目录层次结构中搜索目标程序的最合适变体。 然后启动优化后的二进制文件或为基线编译的"通用"二进制文件。"
变更提案继续补充道:
"对此类优化工作感兴趣的开发人员可以在 Fedora 中执行,而无需构建单独的软件源。 拥有相应硬件的用户将获得性能优势。 更快的代码也更节能。 这一变更将自动进行,对用户透明。请注意,其他发行版使用的微体系结构级别更高。 例如,RHEL 9 使用 x86-64-v2 作为基线,RHEL 10 使用 x86-64-v3,其他发行版提供了优化变体(OpenSUSE、Arch Linux、Ubuntu)。 我们在 Fedora 中实现相同变化的方式范围更窄,因此在开发工作量、代码编译时间、存储和发布开销方面大大降低,但应提供相同的性能和能耗优势。"
Fedora打包商/开发人员仍将自行评估性能优势,并决定是否为其软件包提供针对不同 x86_64 微体系结构特性级别的优化可执行文件。