您现在的位置是:人工智能 >>正文
谷歌正寻求提高 C++ 内存安全
人工智能774人已围观
简介谷歌 Chrome 安全团队称其一直在致力于改善 Chrome 浏览器的内存安全;近期,该团队正在研究使用 heap scanning 技术来提高 C++ 的内存安全。虽然从内存安全方面出发,Rust ...
谷歌 Chrome 安全团队称其一直在致力于改善 Chrome 浏览器的谷歌高内存安全;近期,该团队正在研究使用 heap scanning 技术来提高 C++ 的正寻内存安全。
虽然从内存安全方面出发 ,求提Rust 当下可能更受大众喜爱。内存但 Chrome 安全团队认为,安全尽管人们对比 C++ 具有更强内存安全保证的谷歌高其他语言有兴趣,但在可预见的正寻未来 ,像 Chromium 这样的求提大型代码库将使用 C++ 。鉴于此 ,内存Chrome 工程师已经找到了使 C++ 更安全的安全方法 ,以减少缓冲区溢出和 use-after free (UAF) 等与内存相关的源码库谷歌高安全漏洞。数据表明 ,正寻这些漏洞占所有软件安全漏洞的求提 70% 。
复制auto* foo = new Foo();
delete foo;
// The 内存memory location pointed to by foo is not representing
// a Foo object anymore, as the object has been deleted (freed).
foo->Process();1.2.3.4.5.如上示例 ,当应用程序使用的安全内存被返回到底层系统,但指针指向一个过期的对象时 ,就会出现一个被称为悬空指针(dangling pointers)的情况,通过它进行的任何访问都会导致 UAF 访问 。在最好的情况下 ,此类错误会导致 well-defined 的源码下载崩溃;在最坏的情况下,它们会造成可以被恶意行为者利用的破坏。
在较大的代码库中,UAF 通常很难被发现,因为对象的所有权是在不同组件之间转移的。这个问题非常普遍,以至于到目前为止,工业界和学术界都在频繁地针对其提出缓解策略。而 Chrome 中 C++ 的使用也没有什么不同,建站模板大多数高严重性安全漏洞都是 UAF 问题。近期发布的 Chrome 102 中,就修复了一个关键的 UAF 问题 ,且八个高危漏洞中有六个是 UAF。
为了解决这一问题,Chrome 方面已经使用了各种技术手段;包括 C++ 智能指针(如 MiraclePtr) 、编译器中的静态分析、动态工具(如 C++ sanitizers )、代码模糊器,以及一个名为 Oilpan 的 C++ 垃圾回收器。云计算Oilpan、MiraclePtr 和基于智能指针的解决方案需要大量采用应用程序代码 。
此外 ,谷歌还探索了另一种方法 :内存隔离(memory quarantine)。基本思路是将 explicitly freed memory 放入隔离区,并且仅在达到特定安全条件时才使其可用 。Chrome 安全团队在博文中总结了在 Chrome 中实验隔离和 heap scanning 的历程。
工作原理在于 ,用隔离和 heap scanning 保证 temporal safety 的主要思想是避免重用内存,直到证明没有更多的(悬空的服务器租用)指针指向它 。为了避免改变 C++ 用户代码或其语义,提供 new 和 delete 的内存分配器被拦截。

在调用删除时 ,内存实际上被放入隔离区,无法再用于应用程序的后续新调用。“在某些时候触发了 heap scan ,它扫描整个堆,就像垃圾回收器一样 ,以查找对隔离内存块的引用。那些没有从常规应用内存中获得引用的块被转移回分配器,在那里它们可以被重新用于后续的香港云服务器分配。”
根据介绍 ,谷歌的 heap scanning 由一套被命名为 StarScan(简称为 *Scan)的算法组成。他们将 *Scan 应用于渲染器进程的非托管部分,使用 Speedometer2 评估性能影响 ,并尝试了不同版本的 *Scan 。

测试结果表明,*Scan 的一个基础版本造成了 8% 的内存回归。“所有这些开销从何而来?不出所料,heap scanning 极其受 memory bound 影响,因为扫描线程必须遍历和检查整个用户内存的引用” 。在进行了多方面优化之后,Speedometer2 回归从 8% 降低到了 2%。此外 ,有关内存消耗的测量结果则表明,渲染进程中的扫描使内存消耗减少约 12%。
MTE(内存标签扩展,Memory Tagging Extension)是 ARM v8.5A 架构上的一个新扩展,有助于检测软件内存使用中的错误;这些错误可以是 spatial errors(如 out-of-bounds accesses),也可以是 temporal errors(use-after-free) 。谷歌方面获得了一些支持 MTE 的 actual hardware ,并在渲染器过程中重新进行了实验。结果表明,虽然 MTE 和 memory zeroing 会带来一些成本 ,但 Speedometer2 中的内存回归约为 2%。实验还表明 ,在 MTE 之上添加 *Scan 没有可衡量的成本。

Chrome 安全团队最后总结称,C++ 可以编写出高性能应用程序 ,但需要付出安全性方面的代价 。Hardware memory tagging 可以修复 C++ 的一些安全缺陷 ,同时保持高性能。“我们期待在未来看到更广泛地采用 Hardware memory tagging ,并建议在 Hardware memory tagging 之上使用 *Scan 来修复 C++ 的 temporary memory safety 。使用的 MTE 硬件和 *Scan 的实现都是 prototypes ,我们预计仍有性能优化的空间。”
本文转自OSCHINA
本文标题 :谷歌正寻求提高 C++ 内存安全
本文地址:https://www.oschina.net/news/198093/google-c-memory-safety
Tags:
转载:欢迎各位朋友分享到网络,但转载请说明文章出处“算法与编程”。http://www.bzli.cn/html/988a799004.html
相关文章
为什么以数据为中心的网络安全策略至关重要
人工智能在当今的数字环境中,数据是每个企业的核心,保护敏感信息已成为重中之重。 随着员工用于存储和访问数据的端点的增加,数据泄露的风险也随之增加。 因此,实施以数据为中心的网络安全措施对 ...
【人工智能】
阅读更多探讨夜班工作对身心健康的影响(研究表明,长期进行夜班工作可能对人体带来负面影响)
人工智能夜班工作指的是在晚上或深夜时段进行工作的员工。夜班工作对身心健康有着重要的影响,本文将探讨夜班工作对人体的影响及相关研究结果。夜班工作对睡眠质量的影响夜班工作会扰乱人体的生物钟,导致睡眠质量下降,常常 ...
【人工智能】
阅读更多AMDR71700处理器(性能强劲,价格亲民——透析AMDR71700处理器的优势与魅力)
人工智能如今,计算机技术的发展突飞猛进,处理器作为计算机的核心部件,在性能提升和功能创新方面扮演着重要的角色。AMDR71700处理器作为一款颇具性价比的产品,吸引了广大用户的关注。本文将深入分析AMDR71 ...
【人工智能】
阅读更多
热门文章
最新文章
友情链接
- win10系统使用隐藏的小技巧有哪些
- 彩泥平板电脑制作教程(DIY彩泥平板电脑,打造独一无二的创意科技玩具)
- 解决广东XP电脑DNS错误的方法(轻松应对广东XP电脑DNS错误,让网络畅通无阻)
- win11百度网盘下载安装教程
- win10副本和正版有区别吗
- 开展少儿电脑美术培训的重要性(培养创造力和美感,提升孩子综合素质)
- win10开机速度慢的解决办法
- 电脑插件设置教程(学会设置电脑插件,提升您的用户体验)
- 解决广东XP电脑DNS错误的方法(轻松应对广东XP电脑DNS错误,让网络畅通无阻)
- 极云普汇云电脑致命错误的原因与解决方法(探究极云普汇云电脑的常见致命错误,并提供解决方案) 企业服务器网站建设b2b信息平台亿华云源码库云服务器香港物理机