联系管理员

开通文章发布权限

扫码 添加微信
微信图片
电话: QQ:3810899917

从 C 迁移到 Rust 的挑战与经验教训

在一个系列文章中,Immunant 软件工程师 Stephen Crane 和 Khyber Sen 讲述了他们如何将互联网安全研究小组 (ISRG) 的 VideoLAN 和 FFmpeg AV1 解码器从 C 语言移植到 Rust 语言。该系列文章详细介绍了他们如何确保不出错并优化性能。

VideoLan VLC 和 FFMpeg 中使用的 AV1 解码器 dav1d 已经开发了六年多,包含大约 5 万行 C 代码和 25 万行汇编程序。正如 Crane 所说的那样,它成熟、速度快且应用广泛。因为代码高度优化,所以它的体积小、可移植性好、速度快。因此,他们坚持要移植,而不是使用 Rust 从头开始重写。

Immunant 的工程师们首先要做的选择是,是一步一步地进行移植,还是使用 c2rust 移植整个代码库,获得一个不安全但可运行的 Rust 实现,然后再以此为基础进行重构和重写,使其变得安全而又符合 Rust 的语言习惯。最终,他们决定采用 c2rust,因为它有两大优势:一是可以在重构的同时测试移植的代码,二是降低了对专家领域知识的要求。

我们发现,在重写和改进 Rust 代码的过程中,从一开始就进行全面的 CI 测试是非常有益的。我们可以对代码库进行横向修改,并在每次提交时运行已有的 dav1d 测试。[…] 该项目的大部分团队成员都是系统编程和 Rust 方面的专家,但之前并没有 AV 编解码器方面的经验。我们的编解码器专家 Frank Bossen 为项目提供了宝贵的指导,但大部分的工作他并不需直接要参。

 

将移植生成的 Rust 代码重构为安全、符合语言习惯的 Rust 代码面临着许多挑战,其中一些挑战与 C 和 Rust 之间的不匹配有关,例如生命周期管理(借用)、内存所有权、缓冲指针和联合体;另一些挑战则源于 dav1d 的设计,它非常依赖于对跨线程共享可变数据的访问。

通过使用MutexRwLock加锁,并在运行时使用Mutex::try_lock()RwLock::try_read()/RwLock:: try_write()进行验证,他们确保了线程可以访问数据而且又不会引入延迟,从而解决了与共享状态相关的线程安全问题。

这种方法可以很好地处理只有一个线程需要修改跨线程共享值的情况。然而,dav1d 还依赖于多个线程对单个缓冲区的并发访问,其中每个线程访问缓冲区的特定子区域。对此,Immunant 工程师并没有使用更符合 Rust 语言习惯的方法,即使用专门分配给不同线程的不相连的区域,而是创建了一个缓冲区封装类型DisjointMut,负责处理可变借用,并确保每一个都能独占访问。

另外两个颇具挑战性的领域是自引用结构(主要用于跟踪缓冲区位置的游标以及上下文结构之间的链接)和无标签联合体。由于 Rust 不允许使用自引用结构,所以游标指针被整数索引取代,而上下文结构之间的链接被取消,并通过函数参数进行引用。在适当的时候,无标签联合体会被转换为带标签的 Rust 联合体,而在其他情况下,zerocopy crate 会在运行时将相同的字节重新解释为两种不同的类型,以避免改变联合体的表示和大小。

移植的一个主要目标是保持性能不变。因此,Immunant 的工程师在每次提交的重构阶段都会仔细监控性能回归情况。在向安全代码转换的过程中,他们意识到,性能主要是受到一些微妙因素的影响,如动态分派汇编代码、边界检查和结构初始化的成本。最后,他们进行了与分支、内联和堆栈使用相关的更细致的优化。

性能优化工作显著降低了移植带来的开销,从 11% 降至 6%。按照 Crane 的说法,总体上,将 dav1d 移植到 rav1d 花费了三个开发人员 20 多个月的时间,所耗费的人工比最初预计的要多。但这也表明,将现有的 C 代码重写为安全、高性能的 Rust 代码并解决所有线程和借用难题是可能的。

对特别注重安全性的应用程序,rav1d 提供了一个内存安全的实现,而且不会因为沙箱等风险缓解措施而额外增加开支。我们相信,通过不断地优化和改进,在任何情况下,Rust 实现都可以与 C 语言实现相媲美,同时还能提供内存安全性。

此文章转载自:https://www.infoq.cn/article/fFE1HMoLJ0dRNkXKIpFd

如有侵权或异议,请联系我们删除

相关文章

【付费阅读演示】6 款大模型官宣后,生成式 AI 淘汰赛的号角正式吹响了
亚马逊云科技在 2024 年的 re:Invent 大会上发布了自研的 Amazon Nova 系列六款基础模型,包括多模态和文本处理模型。这些模型在性能、成本和推理速度上表现出色,具有极高的性价比。Amazon Bedrock 的更新引入了模型蒸馏和自动化推理检查功能,以提高模型的效率和准确性。此外,Trainium2 和 NeuronLink 技术的推出进一步提升了 AI 应用的基础设施能力。Amazon Q Developer 的增强则为开发者提供了更高效的编程支持。这些创新标志着亚马逊在生成式 AI 领域的领先地位,并推动行业进入“能用、好用、用得起”的新阶段。
新手必备!养“金渐层”须知的10个注意事项!
金渐层猫,以其独特的外貌和温顺的性格,赢得了无数宠物爱好者的青睐。如果你准备迎接一只金渐层猫,恭喜你!但在开始之前,了解一些养猫的基本知识和注意事项是必不可少的。今天,我就为你整理了养金渐层猫的十大忠告,让你的养猫之旅更加顺利!🐱✨
金渐层为何是猫界的“香饽饽”?网友:优点太多数不过来!
金渐层因稀有、高颜值、性格友好、饲养体验好、适应力强、智商高通人性而受欢迎,寓意招财,撸猫手感佳。养护需注意饮食管理、毛发护理、健康管理、互动陪伴及训练引导。
英短金渐层图鉴|英短中的新势力
现在的年轻人都想生猫,那生什么样的哈基米你有想过吗?今天来说说绝大数人都考虑过的毛孩子——英短金渐层,生过的家长,评论区可以分享下生猫经验~

评论

快捷导航

把好文章收藏到微信

打开微信,扫码查看

关闭

还没有账号?立即注册