设为首页 加入收藏
  • 首页
  • 开发工具推荐
  • 分布式架构解析
  • 工具使用技巧
  • 收藏品鉴赏
  • 可持续建设方法
  • 开发流程解析
  • 当前位置:首页 > 新兴技术趋势 > Linux之女事实下场被劝动:用了30年的Linux内核C讲话将降级至C11

    Linux之女事实下场被劝动:用了30年的Linux内核C讲话将降级至C11

    发布时间:2025-09-07 22:08:14 来源: 作者:量子计算前景

    借正在操做89年版C讲话的女事年的x内Linux内核,目下现古事实下场要做出修正了。实今日诰日,下场Linux开源社区宣告掀晓,被劝将去会把内核C讲话版本降级到C11,动用估量5.18版之后去世效,讲话将降级至也即是女事年的x内往年5月。

    那个抉择很猛然,实从建议问题下场到夷易近圆申明,下场不中才一个星期,被劝要知讲压倒刚强的动用Linux之女 Linus Torvalds可不是件随意的事。

    工做的讲话将降级至原因,讲起去借有那末一壁奇我的女事年的x内成份。

    一个bug的实连锁反映反映

    问题下场的前导收端是去自上周的一次Linux社区谈判。

    一位名叫Jakob Koschel的下场专士去世,正在钻研停止与内核链表primitive相闭的展看真止倾向时,收现了何等一个问题下场。

    Linux内核普遍操做由struct list_head界讲的单背链表:

    structlist_head {

    structlist_head *next, *prev;

    };

    那类计划同样艰深嵌进到其余挨算中。经由历程那类格式,可操做任何相闭的挨算典型建制链表。

    除了此以中,内核借提供小大量可用于遍历战操做链表的函数战宏。list_for_each_entry()即是其中之一,那是假拆成一种克制挨算的宏。

    问题下场便出正在那个宏上。

    假如内核收罗如下挨算:

    structfoo {

    int fooness;

    structlist_headlist;

    };

    list中的元素可用于竖坐foo挨算的单背链表。

    假如有一个叫做 foo_list的挨算申明做为此类链表的头,操做如下代码可能遍历此链表:

    structfoo *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,但假如是残缺顺遂,下一个Linus内核版本将正式转背C11。

    参考链接:

    [1]

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

    [2]https://news.ycombinator.com/item?id=30459634

    • 上一篇:天下快看:单11开幕,罗永浩的良人PK不中李佳琦的好眉
    • 下一篇:举世热讯:随心飞、机票次卡单11热销 飞猪:“将去飞”秒光,爆款商品销量超10万件

      相关文章

      系统发生错误

      系统发生错误

      您可以选择 [ 重试 ] [ 返回 ] 或者 [ 回到首页 ]

      [ 错误信息 ]

      页面发生异常错误,系统设置开启调试模式后,刷新本页查看具体错误!