写点什么

Linus 妥协?30 年 Linux 内核语言标准将更新

  • 2022-02-28
  • 本文字数:1490 字

    阅读完需:约 5 分钟

Linus 妥协?30 年 Linux 内核语言标准将更新

近日,据 Linux 内核邮件消息,Linux 内核有望在近期采用最新 C 语言标准。Linux 内核一直在快速发展,但由于仍然有着许多老的依赖项,其内核代码仍是 1989 年的 C 语言标准,距今已有 30 余年。不过,这一情况有望在近期的 5.18 版本中发生改变。

修复补丁引发内核升级讨论,Linus 被说服

 

问题起源来自 Linux 的一次社区讨论,一位名叫 Jakob Koschel 的博士生,在研究阻止与内核链表 primitive 相关的预测执行漏洞时,发现了一个问题。Linux 内核广泛使用由 struct list_head 定义的双向链表,这个情况最终就导致了 USB 子系统中的一个 bug:传递给该宏的迭代器在退出宏后还能被使用。发现这个问题后,Koschel 随即提交了一个修复补丁,在循环停止后使用迭代器修复了 bug。

 

起初,Linus Torvalds 并不喜欢这个修复补丁,他认为这只是一个普通的 bug。不久之后,Linus 发现了问题的根源:传递给链表遍历宏的迭代器,必须在循环本身之外的范围内声明。而导致这个问题出现的原因就是内核在 C89 标准上无法在循环中声明变量。

 

于是 Linus 写信给 Linux 内核邮件列表(LKML),他认为是时候转向 C99 标准了,虽然 C99 也有 20 多年的历史,但至少是较近的,足以解决这个问题。而对于为什么一直沿用 C89,Linus 解释是因为一些老的 GCC 编译器版本有奇怪的问题,因此不敢升级。

 

Linux 内核开发人员 Arnd Bergmann 同意升级 Linus 内核标准的看法,他也希望在这方面取得进展。不过他认为应该升级到 2011 年的 C11 标准,因为 C99 并没有流行特别广泛,而 C11 引入了标准化的多线程支持并使 C 语言更加安全。同时他表示,Linux 内核的最低 C 编译器 GCC 5.1 版本已经支持 C11,这让升级标准实行起来也不会很难。

 

最终,Linus 被说服,表示赞同这个想法,决定在下个版本早期尝试一下。如果顺利的话,C 语言标准有望在下一个内核版本也就是 Linux 5.18 中迁移到 C11。不过 Linux 内核开发人员兼记者 Jonathan Corbet 警告称,“语言标准的升级可能在内核中某些不为人知的角落引发 bug,所以必须尽早发现问题才能及时进行版本还原,但如果一切进展顺利,下一个 Linux 内核版本将正式转向 C11。”

Rust 成 Linux 第二官方语言

 

一直以来,Linux 都是 C 语言的代言人,但是 Rust 的兴起赢得了越来越多人的支持。年前,Linux 内核增加对 Rust 作为第二语言的支持,Rust 凭借优秀的性能与安全等特性赢得了 Linus 和其他社区内核维护者的支持。

 

Linus 鼓励采用缓慢稳定的方法将 Rust 引入 Linux,他也表示将 Rust 接口用于驱动程序和其他非核心内核程序是有道理的:“我相信这会发生。它可能不是 Rust,但我们将会有不同的模型来编写这些类型的东西,而且 C 不会是唯一的模型。”

 

Linux 内核维护者 Miguel Ojeda 也曾表示,“该项目尚未完成,大多数工作还没有完成。但如果高级维护人员接受当前的更改并希望我们在内核中工作,我们就准备好进入主线。”

 

关联阅读:

 

2022 年,Rust 将成为 Linux 内核第二官方语言?

另一重大更新:软件定义芯片

 

除了内核的相关更新,英特尔的软件定义芯片也将在 Linux 5.18 中首次亮相。据外媒 Phoronix 报道,一位来自红帽的 Linux 开发员工 Hans de Goede 透露,如果无意外,英特尔为 Xeon CPU 添加的软件定义芯片(SDSi)机制将在 Linux 5.18 内核中得到正式支持。

 

芯片已内建许多强大的功能,但都以软件锁住,用户必须付费购买授权来解锁功能,用户购买的功能是结合芯片驱动程序控制的启动功能来解锁。SDSi 特点是能够通过软件激活被锁定的芯片功能,能够给在 CPU 上运行的 Linux 系统带来较大优化。

 

参考链接:

 

https://lwn.net/SubscriberLink/885941/01fdc39df2ecc25f/

2022-02-28 16:568145

评论

发布
暂无评论
发现更多内容

服务至上的时代,生态才是ToB软件厂商发展加速的油门

ToB行业头条

一天梳理完react面试题

beifeng1996

React

GitLab 服务的数据备份与恢复

忙着长大#

gitlab

极客时间运维进阶训练营第三周作业

chenmin

Flowable 定时器的各种玩法

江南一点雨

Java spring springboot flowable JavaEE

经常会采坑的javascript原型应试题

loveX001

JavaScript

React源码分析(一)Fiber

goClient1992

React

极客时间运维进阶训练营第三周作业

独钓寒江

极客时间运维进阶训练营第三周作业

Starry

问:React的useState和setState到底是同步还是异步呢?

beifeng1996

React

Git学习笔记

lxmoe

git 学习笔记 常用命令 11月月更

Spring 5(三)AOP

浅辄

Java Spring5 11月月更

图学习初探Paddle Graph Learning 构建属于自己的图【系列三】

汀丶人工智能

图神经网络 11月月更 随机游走算法 异质图

《数字经济全景白皮书》中国商业银行普惠金融可持续发展能力评价2022

易观分析

普惠金融 数字技术应用

Vue内置组件之Transition(一)

Augus

vue.js 11月月更

谈谈前端性能优化-面试版

loveX001

JavaScript

Python进阶(三十五)Fiddler命令行和HTTP断点调试

No Silver Bullet

Python fiddler 11月月更

问:你是如何进行react状态管理方案选择的?

beifeng1996

React

高频react面试题自检

beifeng1996

React

看透react源码之感受react的进化

goClient1992

React

Ubuntu部署和体验Nexus3

程序员欣宸

Docker 11月月更 nexus3

20道前端高频面试题(附答案)

loveX001

JavaScript

Python进阶(三十四)Python3多线程解读

No Silver Bullet

多线程 Python3 11月月更

HTML知识框架 二

默默的成长

html 前端 11月月更

Map接口的子类HashMap和LinkedHashMap

共饮一杯无

Java 11月月更 Map集合

词向量word2vec(图学习参考资料1)

汀丶人工智能

图神经网络 图学习 11月月更

前端高频面试题合集(中高级必备)

loveX001

JavaScript

CSS知识框架(一)

默默的成长

CSS 前端 11月月更

React-Hooks源码深度解读

goClient1992

React

Python进阶(三十六)Web框架Django项目搭建全过程

No Silver Bullet

Python django 11月月更

Map接口概述和基本使用

共饮一杯无

Java map 11月月更

Linus 妥协?30 年 Linux 内核语言标准将更新_架构_辛晓亮_InfoQ精选文章