Linux 內核從 C89 遷移到 C11 的新進展
內核開發者 Arnd Bergmann 發出了一個新的補丁,允許 Linux 內核在指定 C11 的 GNU 方言時默認使用“-std=gnu11”。這樣一來,內核將允許使用不錯的 C99/C11 功能,而不是僅限于 C89。鑒于這一變更已經得到了 Linus Torvalds 的支持,如果沒有發現任何根本性的問題,它可能會在下一個內核合并窗口中繼續進行。
在一次補丁討論中,Linus 提出了將 C 的標準版本從 gnu89 改為 gnu99 的選擇,它允許在 for() 循環中使用變量聲明。雖然 C99、C11 和后來的標準引入了許多其他功能,但其中大部分在 gnu89 中也已經可以作為 GNU 擴展使用。
早些時候,gcc-5 曾試圖默認為 -std=gnu1,但失敗了,因為當時這引起了對舊編譯器的指定初始化器的警告。現在,gcc-5.1 是用于構建內核的最小編譯器版本,這不再是一個問題。同樣地,"inline"函數的行為在 gnu89 和 gnu11 之間發生了變化,但這已經通過定義"inline"包括 __attribute__((gnu_inline)) 來解決了,以便在不久前允許用 clang 來構建。
剩下的一個小問題是,在使用 -Werror 構建時添加了一個針對負整數移位的 gcc 警告,這發生在"make W=1"選項中,以及內核中的三個驅動程序總是啟用 -Werror,但目前只在 i915 驅動程序中觀察到。為了安全起見,在 Makefile 的任何 -Wextra 中添加 -Wno-shift-negative-value。
Nathan Chancellor 報告了一個額外的 -Wdeclaration-after-statement 警告,出現在 arm 的 system header 中,這仍然需要一個解決方法。
gnu99、gnu11、gnu1x 和 gnu17 之間的差異相當小,主要影響內核從不啟用的 -Wpedantic 級別的警告。在這些版本之間,gnu11 是被所有支持的編譯器版本所支持的最新版本,盡管它只是 gcc-5 的默認版本,而所有其他支持的 gcc 或 clang 版本都默認為 gnu1x/gnu17。
事件的前因后果為,Linux 內核社區日前曾討論了是否要為內核采用現代 C 語言標準。Linus 在討論中提出了從 C89 提升到 C99 的想法;并表示,內核代碼一直停留在 C89 的原因之一是編譯器 gcc 的舊版本會出現奇怪的問題,導致初始化程序被破壞。但現在內核要求的 GCC 最低版本已經提高到了 v5.1,那些 bug 可能已經不再相關。
最后事實證明,以當前內核的最低版本編譯器要求和當前代碼的條件,他們實際上可以開始使用 C11 構建內核。Arnd Bergmann 提議直接升級到 C11 甚至 C2x。雖然他不確定 C11 是否會帶來任何對內核有用的新內容,但如果升級到 C17 或 C2x,會破壞對 gcc-5/6/7 的支持;因此升級到 C11 更容易實現,而且跨越太大內核社區未必接受。
Linus 對該想法表示了贊成。在 Bergmann 確認此舉可行后,Linus 宣布將在下一個內核版本 v5.18 中嘗試使用 C11 標準。
更多詳情可查看??郵件列表??。
本文轉自OSCHINA
本文標題:Linux 內核從 C89 遷移到 C11 的新進展
本文地址:https://www.oschina.net/news/184534/linux-kernel-c89-to-c11