當(dāng)前位置:首頁 > 嵌入式 > 嵌入式動(dòng)態(tài)
[導(dǎo)讀]自去年9月以來,Linux內(nèi)核維護(hù)者Greg表示愿意使用Rust來開發(fā)Linux驅(qū)動(dòng)程序。 今年7月,Linus Torvalds回復(fù)說默認(rèn)情況下可以啟用Rust支持。 Linux開發(fā)人員不只是談?wù)摗?

自去年9月以來,Linux內(nèi)核維護(hù)者Greg表示愿意使用Rust來開發(fā)Linux驅(qū)動(dòng)程序。 今年7月,Linus Torvalds回復(fù)說默認(rèn)情況下可以啟用Rust支持。 Linux開發(fā)人員不只是談?wù)摗?

在八月底舉辦的 2020 Linux Plumbers 大會(huì)上,關(guān)于 Linux 內(nèi)核上游對(duì) Rust 的開放程度成為了最熱門的討論話題。Rust 語言團(tuán)隊(duì)的聯(lián)合負(fù)責(zé)人 Thomas 和 Gaynor,以及 Linux 內(nèi)核開發(fā)者 Josh Triplett 等人參與了這場討論,并向大家展示了截至目前的一些研究成果、想法,還有遇到的問題。

他們強(qiáng)調(diào),并不打算將已有的內(nèi)核改寫成 Rust,而只專注于可以用 Rust 編寫的新代碼。具體來講,與會(huì)者集中討論了 Linux 內(nèi)核對(duì) Rust 的支持可能涉及到的三個(gè)方面:內(nèi)核中現(xiàn)有的 API、架構(gòu)支持,和 ABI 與內(nèi)核的兼容性問題。

綁定到現(xiàn)有的 C API

目前來看,Rust 能夠生成可以鏈接到內(nèi)核的代碼還不夠。它還需要一種方法來訪問 Linux 內(nèi)核中使用的大量 API,這些 API 目前都在 C 頭文件中定義。

Linux 內(nèi)核開發(fā)者指出,Rust 與 C 具有良好的互操作性;此外,bindgen 工具能夠解析 C 頭文件以生成適當(dāng)?shù)?Rust 聲明,因此 Rust 不需要從 C 復(fù)制重復(fù)的定義,這也提供了一種跨語言類型檢查的措施。

從表面上看,這些特性使 Rust 具備了與現(xiàn)有 C API 集成的良好條件,但實(shí)際上實(shí)施起來還存在一些挑戰(zhàn)。例如,Linux 大量使用了預(yù)處理器宏和內(nèi)聯(lián)函數(shù),bindgen 和 Rust 的外函數(shù)接口不容易支持它們。

有關(guān) API 綁定的第二個(gè)問題是:需要手動(dòng)封裝多少 C API 才能呈現(xiàn)慣用的 Rust 接口?

Thomas 和 Gaynor 展示了一個(gè) linux-kernel-module-rust 項(xiàng)目,可在其中看到內(nèi)核模式的 Rust 代碼示例。在這個(gè)項(xiàng)目中,指向用戶空間的指針被封裝到 UserSlicePtr 類型中。這樣的封裝生成的代碼對(duì)現(xiàn)有 Rust 開發(fā)者而言更加熟悉,并使 Rust 的類型系統(tǒng)和借用檢查器提供最大程度的安全性。但是,必須針對(duì)每個(gè) API 進(jìn)行設(shè)計(jì)和開發(fā),用 C 和 Rust 編寫的模塊也會(huì)創(chuàng)建不同的 API。這無疑加重了工作的繁瑣度。

John Baublitz 也給出了一個(gè)演示模塊,它更直接地綁定了內(nèi)核的用戶訪問功能,綁定多由 bindgen 自動(dòng)生成。然而,Rust 開發(fā)者對(duì)這些代碼可能會(huì)不太習(xí)慣,并且這種方式可能需要放棄 Rust 的許多安全保證。

最后,會(huì)議達(dá)成了共識(shí):對(duì)于某些最常見和關(guān)鍵的 API,編寫 Rust 封裝器是有意義的,但是手動(dòng)封裝每個(gè)內(nèi)核 API 不可行。Thomas 還提到谷歌正致力于自動(dòng)生成 C++ 代碼的慣用綁定,并考慮內(nèi)核是否可以做類似的事情。

架構(gòu)支持

對(duì)架構(gòu)的支持是討論的另一個(gè)重點(diǎn)。與會(huì)者表示,在 Rust 中實(shí)現(xiàn) Linux 驅(qū)動(dòng)是可以接受的,但無論如何不能把它放在更晦澀難懂的架構(gòu)上。

在這方面,現(xiàn)階段唯一成熟的 Rust 實(shí)現(xiàn)是 rustc 編譯器,該編譯器通過 LLVM 發(fā)出代碼。Linux 內(nèi)核支持多種架構(gòu),其中一些沒有可用的 LLVM 后端,另一些存在 LLVM 后端,卻尚不受 rustc 支持。

Triplett 認(rèn)為,先將 Rust 添加到 Linux 內(nèi)核中,反過來會(huì)有助于增加對(duì)更多架構(gòu)的 Rust 支持。就像 Rust 軟件被引入 Debian 后,吸引了更多不同架構(gòu)的愛好者協(xié)助改進(jìn) Rust 支持一樣,他寄希望于為 Linux 內(nèi)核添加 Rust 支持也獲得類似的效果。

ABI 與內(nèi)核的兼容性

Gaynor 問到了有關(guān) ABI 兼容性的建議。當(dāng)前 Rust 是通過 LLVM 編譯的,而 Linux 內(nèi)核通常使用 GCC 構(gòu)建,因此將 Rust 代碼鏈接到內(nèi)核可能意味著混合 GCC 和 LLVM 發(fā)出的代碼。

參與討論者擔(dān)心 LLVM 與 GCC 可能會(huì)有 ABI 兼容的問題,于是提出一個(gè)設(shè)想,即 Linux 內(nèi)核社區(qū)是否可以將 Rust 支持僅限于使用 Clang 構(gòu)建的內(nèi)核,以確保兼容性。

Linux 內(nèi)核維護(hù)者 Greg 指出,當(dāng)前的內(nèi)核規(guī)則是,僅當(dāng)內(nèi)核中的所有目標(biāo)文件使用相同的編譯器并使用相同的標(biāo)志構(gòu)建時(shí),才能保證兼容性。不過,他仍然對(duì)將 LLVM 構(gòu)建的 Rust 對(duì)象鏈接到 GCC 構(gòu)建的內(nèi)核表示滿意,因?yàn)橹灰渲眠m當(dāng),并通過測試即可。他認(rèn)為不需要任何預(yù)先的限制,直到真正有實(shí)際問題產(chǎn)生。

另一位內(nèi)核開發(fā)者 Triplett 也強(qiáng)調(diào),GCC 和 Rust 之間的調(diào)用是常規(guī)且普遍的,不必?fù)?dān)心兼容性。因此目前看來,二者的兼容性問題目前不會(huì)成為將 Rust 引入 Linux 內(nèi)核的阻礙。

這場會(huì)議上的討論大致到此,暫時(shí)沒有后續(xù)消息。隨著越來越多的人對(duì)此抱有期待和熱情,正如 LWN.net 所說,或許待一個(gè)具體的 Rust 內(nèi)核驅(qū)動(dòng)用例出現(xiàn)時(shí),所有的爭議和決策都將變得更加清晰。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉