一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux 內(nèi)核對(duì)Rust的支持可能涉及到的三個(gè)方面

如意 ? 來(lái)源:開(kāi)源中國(guó) ? 作者:xplanet ? 2020-09-04 10:36 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

從去年九月,Linux 內(nèi)核維護(hù)者 Greg 表示愿意接受用 Rust 開(kāi)發(fā) Linux 驅(qū)動(dòng),到今年七月,Linus Torvalds 回應(yīng)稱(chēng)可以默認(rèn)啟用 Rust 支持,Linux 開(kāi)發(fā)者并非只是說(shuō)說(shuō)而已。

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

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

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

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

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

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

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

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

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

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

架構(gòu)支持

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

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

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

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

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

參與討論者擔(dān)心 LLVM 與 GCC 可能會(huì)有 ABI 兼容的問(wèn)題,于是提出一個(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í),才能保證兼容性。不過(guò),他仍然對(duì)將 LLVM 構(gòu)建的 Rust 對(duì)象鏈接到 GCC 構(gòu)建的內(nèi)核表示滿(mǎn)意,因?yàn)橹灰渲眠m當(dāng),并通過(guò)測(cè)試即可。他認(rèn)為不需要任何預(yù)先的限制,直到真正有實(shí)際問(wèn)題產(chǎn)生。

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

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11511

    瀏覽量

    213781
  • API
    API
    +關(guān)注

    關(guān)注

    2

    文章

    1617

    瀏覽量

    64031
  • Rust
    +關(guān)注

    關(guān)注

    1

    文章

    234

    瀏覽量

    7096
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    一文讀懂:嵌入式Linux實(shí)時(shí)性進(jìn)階

    ,Linux內(nèi)核才能得到運(yùn)行的機(jī)會(huì)。 4兩個(gè)的性能對(duì)比 ?實(shí)時(shí)性: PREEMPT_RT:提供了較好的軟實(shí)時(shí)性能,通過(guò)減少內(nèi)核對(duì)任務(wù)執(zhí)行的干擾,提供可預(yù)測(cè)的實(shí)時(shí)性能。然而,在
    發(fā)表于 07-10 15:26

    怎么結(jié)合嵌入式,Linux,和FPGA三個(gè)方向達(dá)到一個(gè)均衡發(fā)展?

    在嵌入式領(lǐng)域,不少人都懷揣著讓嵌入式、Linux 和 FPGA 三個(gè)方向?qū)崿F(xiàn)均衡發(fā)展的夢(mèng)想,然而實(shí)踐中卻面臨諸多挑戰(zhàn)。就像備受矚目的全棧工程師稚暉君,他從大學(xué)玩單片機(jī)起步,憑借將智能算法融入嵌入式而
    的頭像 發(fā)表于 06-25 10:08 ?318次閱讀
    怎么結(jié)合嵌入式,<b class='flag-5'>Linux</b>,和FPGA<b class='flag-5'>三個(gè)</b>方向達(dá)到一<b class='flag-5'>個(gè)</b>均衡發(fā)展?

    請(qǐng)問(wèn)OpenVINO? 是否支持 Rust 綁定?

    無(wú)法確定OpenVINO?是否支持 Rust 綁定。
    發(fā)表于 06-25 07:45

    嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶(hù)空間的數(shù)據(jù)拷貝之?dāng)?shù)據(jù)拷貝介紹

    注意的是,在進(jìn)行數(shù)據(jù)拷貝時(shí),應(yīng)確保源地址和目標(biāo)地址的有效性,并進(jìn)行適當(dāng)?shù)腻e(cuò)誤處理。此外,數(shù)據(jù)拷貝涉及到用戶(hù)空間和內(nèi)核空間的切換,可能會(huì)引發(fā)性能開(kāi)銷(xiāo),因此在性能敏感的場(chǎng)景下,應(yīng)謹(jǐn)慎使用數(shù)據(jù)拷貝操作。
    發(fā)表于 03-20 11:50

    飛凌嵌入式ElfBoard ELF 1板卡-內(nèi)核空間與用戶(hù)空間的數(shù)據(jù)拷貝之?dāng)?shù)據(jù)拷貝介紹

    拷貝涉及到用戶(hù)空間和內(nèi)核空間的切換,可能會(huì)引發(fā)性能開(kāi)銷(xiāo),因此在性能敏感的場(chǎng)景下,應(yīng)謹(jǐn)慎使用數(shù)據(jù)拷貝操作。
    發(fā)表于 03-19 08:55

    Linux系統(tǒng)中最重要的三個(gè)命令

    Linux劍客是Linux系統(tǒng)中最重要的三個(gè)命令,它們以其強(qiáng)大的功能和廣泛的應(yīng)用場(chǎng)景而聞名。這三個(gè)工具的組合使用幾乎可以完美應(yīng)對(duì)Shell
    的頭像 發(fā)表于 03-03 10:37 ?432次閱讀

    飛凌嵌入式ElfBoard ELF 1板卡-Linux內(nèi)核移植之內(nèi)核簡(jiǎn)介

    學(xué)到本章節(jié),大家應(yīng)該對(duì)Linux操作系統(tǒng)都有了一定的了解,但可能還不知道我們拿到手的內(nèi)核源碼都經(jīng)歷了什么。linux有一個(gè)龐大的開(kāi)源社區(qū),每
    發(fā)表于 12-13 09:03

    Linux應(yīng)用編程的基本概念

    Linux應(yīng)用編程涉及到Linux環(huán)境下開(kāi)發(fā)和運(yùn)行應(yīng)用程序的一系列概念。以下是一些涵蓋Linux應(yīng)用編程的基本概念。
    的頭像 發(fā)表于 10-24 17:19 ?651次閱讀

    嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-應(yīng)用編程示例控制LED燈之sysfs文件系統(tǒng)

    。/sys/目錄結(jié)構(gòu)解釋如下:sysfs文件系統(tǒng)中控制LED狀態(tài)給ELF1開(kāi)發(fā)板上電,進(jìn)入Linux系統(tǒng)后,進(jìn)入/sys目錄下查看:進(jìn)入class目錄,找到led設(shè)備,進(jìn)入led1里:常用的三個(gè)屬性
    發(fā)表于 10-21 09:52

    機(jī)械振動(dòng)的三個(gè)基本要素

    機(jī)械振動(dòng)是物體或質(zhì)點(diǎn)在其平衡位置附近進(jìn)行的往復(fù)運(yùn)動(dòng)。在物理學(xué)中,機(jī)械振動(dòng)是一種非常普遍的現(xiàn)象,它涉及到許多不同的物理過(guò)程和應(yīng)用。機(jī)械振動(dòng)的三個(gè)基本要素是:振幅、周期和頻率。 1. 振幅
    的頭像 發(fā)表于 09-26 14:55 ?2602次閱讀

    如何用Rust編寫(xiě)一個(gè)ChatGPT桌面應(yīng)用(保姆級(jí)教程)

    官方網(wǎng)站 并遵循說(shuō)明來(lái)安裝。 安裝 Rust 插件:打開(kāi) IntelliJ IDEA,然后轉(zhuǎn)到 "File" > "Settings" (Windows/Linux) 或
    的頭像 發(fā)表于 09-25 11:19 ?660次閱讀
    如何用<b class='flag-5'>Rust</b>編寫(xiě)一<b class='flag-5'>個(gè)</b>ChatGPT桌面應(yīng)用(保姆級(jí)教程)

    linux驅(qū)動(dòng)程序如何加載進(jìn)內(nèi)核

    Linux系統(tǒng)中,驅(qū)動(dòng)程序是內(nèi)核與硬件設(shè)備之間的橋梁。它們?cè)试S內(nèi)核與硬件設(shè)備進(jìn)行通信,從而實(shí)現(xiàn)對(duì)硬件設(shè)備的控制和管理。 驅(qū)動(dòng)程序的編寫(xiě) 驅(qū)動(dòng)程序的編寫(xiě)是Linux驅(qū)動(dòng)開(kāi)發(fā)的基礎(chǔ)。在編
    的頭像 發(fā)表于 08-30 15:02 ?1099次閱讀

    Linux內(nèi)核測(cè)試技術(shù)

    Linux 內(nèi)核Linux操作系統(tǒng)的核心部分,負(fù)責(zé)管理硬件資源和提供系統(tǒng)調(diào)用接口。隨著 Linux 內(nèi)核的不斷發(fā)展和更新,其復(fù)雜性和代碼規(guī)
    的頭像 發(fā)表于 08-13 13:42 ?1295次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>內(nèi)核</b>測(cè)試技術(shù)

    對(duì)稱(chēng)相電壓的特點(diǎn)是哪三個(gè)方面

    對(duì)稱(chēng)相電壓是電力系統(tǒng)中常見(jiàn)的一種電壓形式,它具有三個(gè)相位,每個(gè)相位之間的相位差為120度。對(duì)稱(chēng)相電壓在工業(yè)生產(chǎn)和日常生活中有著廣泛的應(yīng)用,如電動(dòng)機(jī)、變壓器、發(fā)電機(jī)等。本文將從三個(gè)
    的頭像 發(fā)表于 08-12 18:18 ?3153次閱讀

    未來(lái)嵌入式系統(tǒng)的黃金搭檔 MCX N947遇上Rust

    ? Rust 介紹 Rust 是一門(mén)注重安全的語(yǔ)言,相比于 C/C++/ASM 有著更高級(jí)的抽象能力、編譯器帶來(lái)的安全特性與廣泛友好的社區(qū)支持。 Linux 與 Windows
    的頭像 發(fā)表于 07-25 09:14 ?1805次閱讀
    未來(lái)嵌入式系統(tǒng)的黃金搭檔 MCX N947遇上<b class='flag-5'>Rust</b>