跳到主要内容

每周一龙:第 32 期

· 阅读需 10 分钟
WANG Xuerui
🐲龙门客栈打杂的

每周一都为大家报道 LoongArch 社区最前线的第一手新鲜资讯! 上周的进展主要有 Linux、GCC、LLVM 以及许多的发行版。 详情点进来看!

如无特别说明,文中提及的日期、时间都为北京时间(UTC+8)。

先「马」再看

本栏目的内容具有一定延续性,将持续追踪报道 LoongArch 领域的重要或长期项目(坑)。

Linux

heiher 完成了 ClangBuiltLinux 的模块(CONFIG_MODULES)支持。 至此 LLVM/Clang 工具链已经可以用来构建全功能的 LoongArch Linux 了。

heiher 还为 Linux 的 Rust 基础设施提交了 LoongArch 支持。 很快就可用 Rust 这一新兴编程语言,为 LoongArch 这一新兴架构做内核、驱动开发了!

Bibo Mao 继续优化 LoongArch KVM 性能: 以协助虚拟化(para-virtualization)方式,通过 hvcl 指令, 加速虚拟机的处理器间中断(inter-processor interrupts,IPI)处理。 改过之后,16 核的虚拟机中 UnixBench 多核跑分达到了物理机情形的 98.8%(但作者未给出改过之前的性能开销情况)。

hvcl 是啥意思?

从用法上看,hvclHyperVisor CaLl 的缩写,「监管调用」的意思:向虚拟机管理器(VM hypervisor)请求些什么。

这样一来,可能有的读者会琢磨了:为啥不像 syscall 一样,叫一个长一点但更完整的名字呢? 作为一个能够对最常用指令之一却取到 pcaddu12i 这样长的名字保持容忍的架构, 显然 hypcall 这种名字更达意,并且与常用指令 syscall 风格一致。 实则不然:在 dbclDeBugger CaLl,调试器调用;用来将下位机 CPU 放入调试模式)与 hvcl 之间, syscall 反倒成了「异类」!

为了降低学习者的记忆负担,笔者以为命名上如果能做到一致,可能更加友好: 要么将 dbclhvcl 改成更达意的 dbgcallhypcall, 要么将 syscall 改成更简练的 syclsscl 之类。 考虑到 syscall 是个常见单词了,不用背,那么前一种改法可能更受欢迎。 汇编代码的兼容性不会受影响,因为先前的名称一时半会不会被移除支持。

工具链

GCC

杨屿杰在重构 LoongArch 后端的命令行选项处理逻辑。

Lulu Cheng 优化掉了伴随一些位操作的多余的符号扩展操作。 这对所有软件的位操作性能都有积极影响;在跑分方面,也对 SPEC2017 的 500.perlbench 用例有 1.8% 的提升。

杨屿杰为了更好的 LTO(链接时优化),给 LoongArch 后端实现了编译选项的保存恢复。 这将修复上游 bug PR113233

Jiahao Xu 为 LA464 避免了执行 xvpermi.q 指令时可能碰到的未定义行为。

chenxiaolong 为了能给 LoongArch 正常启用 GCC 向量化方面的公共测试用例,修了一堆地方。

liwei 把 LSX 与 LASX 原先不共享的两份常量向量排列(constant vector permutation)实现 统一成了一份。 在净删除了 888 行代码之外,跑分还提高了。

LLVM

heiher 最终完成了周报第 24 期报道的 code_model 支持工作: 合并了 ClangLoongArch 后端两部分的最终版本。

来自腾讯的 DamonFool 走过路过,给 LoongArch 后端修了一处非调试配置下未使用的变量(否则会报错)。

wangleiat 实现了更多 LoongArch psABI v2.30 语义: 换用 pcaddu18i + jirl 实现 medium 代码模型的过程调用, 并确保了 extreme 代码模型下装载符号地址操作的指令一定相邻。

MQ-mengqing 改进了 LLVM MC 对代码段对齐的处理方式,LoongArch 和 RISC-V 都从中获益。

杂闻播报

heiher 给 Rust 最常用的 JSON 格式支持库 serde_json 标记了 LoongArch 最适合大数运算的整数类型宽度是 64 位。 上游维护者半小时后就给合并了,且发了 1.0.111 新版本。 请同学们按需 cargo update 以查收这部分免费性能提升。

花絮

这坑是 xen0n 在编译 ripgrep 时候百无聊赖,躺在椅子上看屏幕上滚动的编译进度,偶然注意到的。 有时躺平放空也能创造价值!

xen0n 向 gentoo-zh overlay 推入了 AOSC OS 的 liblol 新旧世界兼容解决方案打包。 此 overlay 包含华语用户圈子常用的许多软件; 后续 Gentoo 用户们也能用相同姿势安装 WPS Office 等旧世界闭源软件了。 例如:只要 emerge wps-office 即可自动拉入 liblol 及其内核模块。

注意事项

目前 liblol 提供的依赖库主要都来自 Loongnix, 因此在我们完成审计这些来自 Loongnix 的文件的开源许可、并确认其中不含闭源或专有内容之前, 您都需要明确接受《基础版 Loongnix 操作系统最终用户许可协议》,才能安装 liblol:

# e.g. /etc/portage/package.license/liblol
app-emulation/liblol Loongnix-Base-EULA

此外,首次安装 la_ow_syscall 内核模块之后,该模块不会被自动载入——在 Gentoo 我们一般不帮用户做这种事,而代之以 emerge 结束后的温馨提醒。 在安装完 liblol 后、使用旧世界软件前, 您可以简单重启系统,或者以 root 身份 modprobe la_ow_syscall: 只需执行这一次即可,后续每次系统启动时都会自动加载了。

致打包人们

对旧世界软件包的标记方式是 RDEPEND 中的 loong? ( virtual/loong-ow-compat ) 表达式。

需要注意:旧世界程序的动态链接依赖都是基于 liblol sysroot(/opt/lol)解析的, 而与宿主系统 libdir 无关。 这与 Gentoo 当下的 multilib 方案不同,反倒与几年前的 emul-linux-x86-* 大包神似; 因此大部分情况下,意在满足动态链接依赖的 RDEPEND 项,都不应当对 loong 适用。

打包人们可参考 WPS Office 的打包做法, 为其他旧世界软件打包。 提交前,记得简单测下软件功能: 如果 liblol sysroot 里缺依赖,可以去 liblol 上游报告

后续,此打包工作(尤其是起到标记作用的 virtual 包)将进一步上游至 Gentoo 主源; 这将在 liblol 的 license 审计工作完成之后进行。

社区整活

本栏目接受任何网友的投稿,只要内容与 LoongArch 有关,并可以为读者带来价值, 无论严肃贡献(整的大活)或是博君一笑都一概欢迎!

社区新面孔 LiarOnce 给 Loong Arch Linux 打包了使用系统 Electron 的最新版本 VSCodium。

社区新面孔 hackpascal 在 OpenWrt 上游贴出了 LoongArch64 的移植,使用 Linux 6.6 内核。 先前 phorcys 已经维护了一个 fork 有一段时间,但笔者印象中 似乎无意将其上游;结果又一名勇士就出现了。 看起来 OpenWrt 确实是玩家刚需!

群友 amdyes 近日将 维护的 Proxmox VE(PVE)移植与上游最新版本同步了,支持 64 位的 LoongArch 以及 ARM、RISC-V 平台。 龙架构的家庭数据中心应用拼图眼见地完整起来!

张贴栏

本栏目可供张贴公益性质的各种信息。

  • 友情扩散:安同开源社区(AOSC)的龙架构移植主线化工作「合龙」仍在如火如荼进行中, 此工作完成后龙架构将升格为 AOSC OS 的 Tier 1 架构。 欢迎同学们试用、反馈,也欢迎有志之士一同加入(沟通渠道详见 AOSC 网站相关栏目)。
  • 本周报持续接受网友投稿。欢迎来上游坐坐!