Linux 内核,30 年C 语言将升级至 C11
还在使用 89 年版 C 语言的 Linux 内核,现在终于要做出改变了。今天,Linux 开源社区宣布,未来会把内核 C 语言版本升级到 C11,预计 5.18 版之后生效,也就是今年 5 月。

这个决定很突然,从发起问题到官方声明,不过才一个星期,要知道说服固执的 Linux 之父 Linus Torvalds 可不是件容易的事。事情的原因,说起来还有那么一点偶然的因素。
一个bug的连锁反应
问题的起源是来自上周的一次 Linux 社区讨论。
一位名叫 Jakob Koschel 的博士生,在研究阻止与内核链表 primitive 相关的预测执行漏洞时,发现了这样一个问题。
Linux 内核广泛使用由 struct list_head 定义的双向链表:
struct list_head {
struct list_head *next, *prev;
};
这种结构通常嵌入到其他结构中。通过这种方式,可以使用任何相关的结构类型制作链表。
除此之外,内核还提供大量可用于遍历和操作链表的函数和宏。list_for_each_entry () 就是其中之一,这是伪装成一种控制结构的宏。问题就出在这个宏上。假设内核包含如下结构:
struct foo {
int fooness;
struct list_head list;
};
list 中的元素可用于创建 foo 结构的双向链表。假设有一个叫做 foo_list 的结构声明作为此类链表的头,使用以下代码可以遍历此链表:
struct foo *iterator;

list_for_each_entry(iterator, &foo_list, list) {do_something_with(iterator);
}
/* Should not use iterator here */

list 参数告诉宏在 foo 结构中 list_head 结构的名称。这个循环将为列表中的每个元素执行一次,迭代器指向该元素。由此导致了 USB 子系统中的一个 bug:传递给该宏的迭代器在退出宏后还能被使用。
这是一件危险的事情,所以 Koschel 提交了一个修复补丁,在循环后停止使用迭代器搞定了 bug。

说服Linus
但是 Linus Torvalds 本人并不太喜欢这个补丁,也没有看到与预测执行漏洞的关系。在 Koschel 详细解释后,Linus 承认这只是一个普通的 bug。
然而事情并没有那么简单,Linus 不久后意识到了真正的根源:传递给链表遍历宏的迭代器,必须在循环本身之外的范围内声明。这种非预测性 bug 发生的原因是,C89 中没有“在循环中声明变量”。
像 list_for_each_entry () 这样的宏,从根本上总是将最后一个 HEAD 入口泄漏到循环之外,仅仅是因为不能在循环本身中声明迭代器变量。
如果可以编写一个可以声明迭代器列表遍历宏,那么迭代器在循环之外将不可见,并且不会出现此类问题。但是,由于内核停留在 C89 标准上,因此无法在循环中声明变量。
Linus 决定,还是升级吧,也许是时候转向 C99 标准了。虽然也有 20 多年的历史,但至少比 C89 新,可以在循环中声明变量。
既然 C89 如此陈旧,这么多年还没做出改变呢?Linus 说,那是因为在一些古老的 gcc 编译器版本中遇到了一些奇怪的问题,不能随便升级。

但是,现在 Linux 内核已将 gcc 的最低要求提升至 5.1 版,因此过去那些奇怪的 bug 应该不会有了。
而另一位核心开发者 Arnd Bergmann 认为,完全可以升级到 C11 甚至更高版本。但如果升级到 C17 或 C2x,会破坏对 gcc-5/6/7 的支持,因此升级到 C11 更容易实现。
最终,Torvalds 赞成这个想法:“好的,在 5.18 合并窗口的早期尝试一下。”接下来迁移到 C11 可能会导致一些意想不到的 bug,但如果一切顺利,下一个 Linux 内核版本将正式转向 C11。

参考链接:
[1]https://lwn.net/SubscriberLink/885941/01fdc39df2ecc25f/
[2]https://news.ycombinator.com/item?id=3045963
[3]https://mp.weixin.qq.com/s/0wxJcdC8Crew-XPOWtvXgw

Linux 内核,30 年C 语言将升级至 C11相关推荐

  1. linux内核是用什么语言编写的?

    严格来说,绝大部分代码是用 C 语言编写的,但在某些关键地方使用了汇编代码,其中主要是在 Linux 的启动部分.由于这部分代码与硬件的关系非常密切,即使是 C 语言也会有些力不从心,而汇编语言则能够 ...

  2. Linux内核---30.触摸屏驱动分析

    查看input系统 root@OK6410:~# cat /proc/bus/input/devices I: Bus=0013 Vendor=dead Product=beef Version=01 ...

  3. Linux 内核 C 语言深度解析

    课程简介 在看一些 GNU 开源软件,或者阅读 Linux 内核.驱动源码时,相信大家和我一样,经常会遇到一些"看似熟悉",但一仔细分析又不是很懂的 C 语言"稀奇古怪& ...

  4. linux内核重要结构体,Linux中list_head结构体相关 | 技术部落

    在Linux内核中,提供了一个用来创建双向循环链表的结构 list_head.虽然linux内核是用C语言写的,但是list_head的引入,使得内核数据结构也可以拥有面向对象的特性,通过使用操作li ...

  5. Rust 要“进驻” Linux 内核了?Linux 之父:保持观望

    整理 | 郑丽媛 出品 | CSDN(ID:CSDNnews) 主要由 C 语言编写内核的开源操作系统 Linux 一直广受开发者喜爱,然而由于 Linux 内核漏洞不断,其中多数情况下皆由内存安全引 ...

  6. 华为安全技术专家与Linux内核到底发生了什么?这本小册子是怎么回事?

    第1章 介绍什么是Linux系统,以及常用的Linux发行版.接着介绍宏内核和微内核之间的区别,以及如何学习Linux 内核等内容.该章还包括如何安装Linux系统,如何编译Linux内核等实验. 第 ...

  7. Linux学习总结(68)——Linux 30年专访:Linus Torvalds谈Linux内核开发与Git

    三十年前,当Linus Torvalds(林纳斯·托瓦兹,下文统称Linus)首次发布Linux内核时,他还是赫尔辛基大学(University of Helsinki)的一名21岁的学生,他宣布说: ...

  8. 终于升级?89年的Linux内核C语言“跟上时代”转成现代C

    整理 | 章雨铭       责编 | 屠敏 出品 | CSDN(ID:CSDNnews) 上周<LINUX设备驱动程序第三版>的第一作者.LWN网络杂志创始人兼主编Jonathan Co ...

  9. Linux 30年专访:Linus Torvalds谈Linux内核开发与Git

    作者 | Jeremy Andrews 译者 | 火火酱,责编 | Carol 出品 | CSDN(ID:CSDNnews) 三十年前,当Linus Torvalds(林纳斯·托瓦兹,下文统称Linu ...

最新文章

  1. 刚刚,DeepMind被IJCAI授予杰出成就奖,因为他家把AlphaGo Zero做成了暖心的新垣结衣?
  2. 哪个瞬间让你突然觉得CV技术真有用?
  3. ADS1.2安装要点
  4. verilog 浮点转定点_浮点数0.1+0.2为何不等于0.3
  5. python【数据结构与算法】树状数组(附例题)
  6. JavaScript对象this指向(普通键this指向 非指向函数的键)
  7. 计算机组成与结 读写数据实验,计算机组成与结构实验报告现实版.doc
  8. 什么是跨域,什么是同源
  9. Centos Flex 2.6.4
  10. List 分页加载数据控制机制
  11. 操作系统(2)-创建线程的几种方式
  12. 【iCore4 双核心板_uC/OS-II】例程一:认识 uC/OS-II
  13. 海信计算机怎么开机,将海信电视连接到计算机的步骤_计算机的基本知识_IT /计算机_信息...
  14. 采用数字电位器来调整DC-DC的输出
  15. logback日志集成
  16. 电池充电电路(TP4059)详解
  17. 加密word去除密码教程
  18. AI基础:机器学习库Scikit-learn的使用
  19. 凭证录入模板-检查核算项目研发项目是否录入
  20. 淘宝买的AC+退款经历

热门文章

  1. 2022-2028年中国高等职业教育产业投资分析及前景预测报告
  2. jenkins+sonarqube流水线脚本模板
  3. 2022-2028年中国智慧物流行业深度调研及投资前景预测报告(全卷)
  4. 【算法基础】时间复杂度:大O阶方法
  5. LeetCode中等题之根据字符出现频率排序
  6. LeetCode简单题之二叉树中第二小的节点
  7. LeetCode简单题之二叉搜索树的范围和
  8. CodeGen结构循环回路
  9. 觉SLAM的主要功能模块分析
  10. Activity在有Dialog时按Home键的生命周期