色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創(chuàng)作中心

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

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

DPU編譯應(yīng)用程序的不同方法

科技綠洲 ? 來源:NVIDIA英偉達(dá) ? 作者:NVIDIA英偉達(dá) ? 2022-04-22 14:25 ? 次閱讀

您在說明書中常常看到“去喝杯咖啡”嗎?作為一名開發(fā)人員,我很早就發(fā)現(xiàn)這種令人生厭的俏皮話是我生活中的禍根。無論持續(xù)時間長短,進(jìn)程切換(Context Switches)在應(yīng)用程序開發(fā)周期中都是一項(xiàng)高昂的成本。在所有需要您離開的步驟中,等待應(yīng)用程序編譯是最難擺脫的。

當(dāng)我們進(jìn)入 NVIDIA BlueField DPU 應(yīng)用程序開發(fā)的新世界,有效地設(shè)置構(gòu)建步驟非常重要,以便您能夠無縫地編碼→編譯→單元測試。在本文中,我介紹了 DPU 編譯應(yīng)用程序的不同方法。

DOCA 數(shù)據(jù)平面插件的 FRR

(Free Range Routing)

在 DPU 應(yīng)用程序開發(fā)系列文章中,我談到了在 FRR 中創(chuàng)建 DOCA 數(shù)據(jù)平面插件以用于卸載策略。FRR 的代碼行數(shù)接近 100 萬行( 789678 SLOC ),這使得它成為衡量構(gòu)建時間的絕佳候選。

直接在 BlueField DPU 上開發(fā)

DPU 具有 Arm64 架構(gòu),一種快速啟動 DPU 應(yīng)用程序的方法就是直接在 DPU 上開發(fā)。本測試使用具有 8G RAM 和 8 個 A72 CPU 內(nèi)核的 NVIDIA BlueField2 DPU 。

我安裝了 BlueField 引導(dǎo)文件( BFB ),它為 DPU 提供 Ubuntu 20.04.3 操作系統(tǒng)映像。它還包括 DOCA 1.2 和 DPDK 20.11.3 庫。為了使用 DOCA 庫構(gòu)建應(yīng)用程序,我將 DPDK pkgconfig 位置添加到 PKG_CONFIG 路徑。

poYBAGJiSM-ADKhSAAA0-HM25uM779.png

接下來,我通過克隆 FRR 在 DPU 上設(shè)置了我的代碼工作區(qū),并切換到 DOCA 數(shù)據(jù)平面插件。

pYYBAGJiSNyAKI4PAABRnN3Rlik071.png

FRR 需要一個不斷發(fā)展的先決條件列表,這些先決條件列舉在 FRR 社區(qū)文檔中。安裝了這些依賴項(xiàng)后,我將 FRR 配置為包括 DPDK 和 DOCA 數(shù)據(jù)平面插件。

pYYBAGJiSOWAebWsAAGaEi-TMOg630.png

當(dāng)我使用 DPU 作為我的開發(fā)環(huán)境時,我構(gòu)建并安裝了 FRR 二進(jìn)制文件:

pYYBAGJiSPWAfhXBAAAaCAxtvCc412.png

以下是構(gòu)建時間的表現(xiàn)。我用多種方法來衡量:

使用 make -j12 all 和 make install 構(gòu)建和安裝二進(jìn)制文件的時候

使用 dpkg-buildpackage –j12 –uc –us 將它們組裝成 Debian 軟件包來構(gòu)建相同二進(jìn)制文件的時候

第一種方法用于編碼和單元測試。第二種生成 deb 的方法需要與其他外部開發(fā)環(huán)境上的構(gòu)建時間進(jìn)行比較。

poYBAGJiSQaAQcx_AABqX3AaQm0746.png

表 1 。 DPU Arm 構(gòu)建時間

時間上的差異是意料之中的。生成一個包需要幾個額外的步驟。

使用 DPU 作為開發(fā)環(huán)境有一些明顯的優(yōu)勢:

您可以在不離開工作區(qū)的情況下進(jìn)行編碼、構(gòu)建和安裝,然后進(jìn)行單元測試。

您可以針對增量代碼更改來優(yōu)化構(gòu)建。

與完整構(gòu)建(Complete make)相比,最后一個選擇通常可以大幅縮短構(gòu)建時間。例如,我在 FRR 中修改了 DOCA 數(shù)據(jù)平面代碼,并重建的結(jié)果如下:

pYYBAGJiSRWAPa8zAAA_d4TNlhE084.png

雖然這可能會讓事情變得更簡單,但它需要為每個開發(fā)人員無限期的保留 DPU ,僅用于應(yīng)用程序開發(fā)或維護(hù)。您的開發(fā)環(huán)境可能還需要更多的內(nèi)存和性能,因此長期來看,這是一個不太可行的選擇。

在 x86 服務(wù)器上開發(fā)

我的 BlueField-2 DPU 由一臺 x86-64 Ubuntu 20.04 服務(wù)器托管,我將這臺服務(wù)器用于我的開發(fā)環(huán)境。

poYBAGJiSUSAOLNhAABe0_ZMDeY239.png

o4YBAGC24DOAHECBAAAARmu_22A208.png

在本例中,構(gòu)建機(jī)器是 x86 ,應(yīng)用程序?qū)⑦\(yùn)行的主機(jī)是 DPU-Arm64 。有幾種方法可以做到這一點(diǎn):

在 x86 構(gòu)建機(jī)器上使用 Arm 仿真。 提供的 DOCA 開發(fā)容器 作為 DOCA 軟件包的一部分。

使用交叉編譯工具鏈。

在這個測試中,我使用了第一個選項(xiàng),因?yàn)樗亲詈唵蔚摹5诙€選項(xiàng)可以提供不同的性能,但創(chuàng)建該工具鏈有其挑戰(zhàn)。

我在x86 服務(wù)器上下載并加載了 bfb_builder_doca_ubuntu_20.04 容器,并啟動了它。

pYYBAGJiSVmAdlsmAABc4El4kyM985.png

o4YBAGC24DOAHECBAAAARmu_22A208.png

DOCA 和 DPDK 庫預(yù)先安裝在這個容器中,我只需要將它們添加到 PKG_CONFIG 路徑。

pYYBAGJiSaeAA6DxAAA7e9xntoI930.png

o4YBAGC24DOAHECBAAAARmu_22A208.png

我在容器中設(shè)置了工作區(qū)和 FRR 先決條件,與前面的選項(xiàng)相同。

poYBAGJiSbGAAlY8AABHA2eupwo769.png

o4YBAGC24DOAHECBAAAARmu_22A208.png

我可以在這個 DOCA 容器中構(gòu)建我的應(yīng)用程序,但我無法對其進(jìn)行測試。因此,必須將 FRR 二進(jìn)制文件構(gòu)建并打包到 deb 中,然后將其復(fù)制到 BlueField DPU 進(jìn)行測試。我設(shè)置了 FRR Debian 規(guī)則,以匹配前面選項(xiàng)中使用的 FRR 構(gòu)建配置,并生成了軟件包:

poYBAGJiSf2AB5KdAAAhp-tOlxQ827.png

o4YBAGC24DOAHECBAAAARmu_22A208.png

表 2 顯示了構(gòu)建時間與以前方法的比較:

pYYBAGJiSd6AJN9yAACcpOnJQKU984.png

表 2 。 DPU Arm 和 X86 構(gòu)建時間

構(gòu)建時間的大幅增加讓我感到驚訝,因?yàn)槲矣幸慌_充足 x86 資源的服務(wù)器,而且沒有 Docker 限制。因此,將 CPU 和 RAM 用于解決問題似乎并不總是有幫助的!這種性能下降是因?yàn)榭珞w系結(jié)構(gòu)造成的,正如您在下一個選項(xiàng)中看到的那樣。

在 AWS Graviton 實(shí)例中開發(fā)

接下來,我嘗試在 Arm 上構(gòu)建我的應(yīng)用程序,但這次是在性能更大的外部服務(wù)器上。為此,我使用了 Amazon EC2 Graviton 實(shí)例,其規(guī)格與我的 x86 服務(wù)器相當(dāng)。

Arm 64 arch , Ubuntu 20.04 操作系統(tǒng)

128G 內(nèi)存

32 vCPU

pYYBAGJiSg6AC2ysAABSdOs16j4440.png

為了在這個實(shí)例中設(shè)置 DOCA 和 DPDK 庫,我安裝了 DOCA SDK repo meta 包 。

poYBAGJiShuAdgXdAABdONwKHxw043.png

克隆和構(gòu)建 FRR Debian 軟件包的其余步驟與前面的選項(xiàng)相同。

表 3 顯示了構(gòu)建在 AWS Arm 實(shí)例上的運(yùn)行情況:

poYBAGJiSjCAUQBxAADWypr3srY185.png

表 3 。 DPU Arm 、X86 和 AWS Arm 的構(gòu)建時間

這是一個明顯的贏家,不需要咖啡。

圖 1 顯示了這些環(huán)境中的編譯時間。

poYBAGJiSj6AK_ctAABeyzwo--w253.png

圖 1 。 具有不同選項(xiàng)的 FRR 構(gòu)建時間

總結(jié)

在本文中,我討論了 DPU 應(yīng)用程序的幾個開發(fā)環(huán)境:

BlueField DPU

x86 服務(wù)器上的 DOCA 開發(fā)容器

AWS Graviton 計(jì)算實(shí)例

你可以直接在 DPU 上對您的應(yīng)用程序進(jìn)行原型設(shè)計(jì),在 x86 DOCA 開發(fā)容器中進(jìn)行開發(fā)實(shí)踐,然后用 DOCA 獲取一個 AWS Graviton 實(shí)例,使其高速運(yùn)行!

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

    關(guān)注

    0

    文章

    386

    瀏覽量

    24570
  • 應(yīng)用程序
    +關(guān)注

    關(guān)注

    38

    文章

    3316

    瀏覽量

    58514
  • 編譯
    +關(guān)注

    關(guān)注

    0

    文章

    674

    瀏覽量

    33555
收藏 0人收藏
  • jf_925912681

評論

相關(guān)推薦

嵌入式應(yīng)用程序開發(fā)Windows環(huán)境一鍵編譯下載

【知識分享】嵌入式應(yīng)用程序開發(fā),Windows環(huán)境一鍵編譯下載
的頭像 發(fā)表于 08-27 12:55 ?2146次閱讀
嵌入式<b class='flag-5'>應(yīng)用程序</b>開發(fā)Windows環(huán)境一鍵<b class='flag-5'>編譯</b>下載

如何構(gòu)建linux開發(fā)環(huán)境和編譯軟件工程、應(yīng)用程序

前文介紹了如何使用官方提供的鏡像文件啟動開發(fā)板,本文將說明如何構(gòu)建linux開發(fā)環(huán)境和編譯軟件工程、應(yīng)用程序
的頭像 發(fā)表于 01-03 12:31 ?2474次閱讀
如何構(gòu)建linux開發(fā)環(huán)境和<b class='flag-5'>編譯</b>軟件工程、<b class='flag-5'>應(yīng)用程序</b>

單片機(jī)編譯軟件keillic注冊機(jī)應(yīng)用程序軟件免費(fèi)下載

本文檔的主要內(nèi)容詳細(xì)介紹的是單片機(jī)編譯軟件keillic注冊機(jī)應(yīng)用程序軟件免費(fèi)下載。
發(fā)表于 09-26 11:25 ?19次下載
單片機(jī)<b class='flag-5'>編譯</b>軟件keillic注冊機(jī)<b class='flag-5'>應(yīng)用程序</b>軟件免費(fèi)下載

如何使用Xilinx SDK創(chuàng)建Linux應(yīng)用程序,并進(jìn)行開發(fā)和調(diào)試

了解如何使用Xilinx SDK創(chuàng)建Linux應(yīng)用程序。 我們還將重點(diǎn)介紹和演示支持Linux應(yīng)用程序開發(fā)和調(diào)試的不同方面的SDK功能。 整個過程快速而簡單。
的頭像 發(fā)表于 11-20 07:03 ?1.1w次閱讀

MCS-51單片機(jī)智能反編譯應(yīng)用程序免費(fèi)下載

本文檔的主要內(nèi)容詳細(xì)介紹的是MCS-51單片機(jī)智能反編譯應(yīng)用程序免費(fèi)下載。
發(fā)表于 01-17 14:32 ?56次下載
MCS-51單片機(jī)智能反<b class='flag-5'>編譯</b>器<b class='flag-5'>應(yīng)用程序</b>免費(fèi)下載

AVR程序編譯器avrubd應(yīng)用程序免費(fèi)下載

本文檔的主要內(nèi)容詳細(xì)介紹的是AVR程序編譯器avrubd應(yīng)用程序免費(fèi)下載,簡單的AVR程序編譯器,簡單實(shí)用,只需配置串口和時鐘頻率。
發(fā)表于 05-15 17:22 ?54次下載
AVR<b class='flag-5'>程序</b><b class='flag-5'>編譯</b>器avrubd<b class='flag-5'>應(yīng)用程序</b>免費(fèi)下載

MATLAB 64位C語言和C++編譯應(yīng)用程序免費(fèi)下載

本文檔的主要內(nèi)容詳細(xì)介紹的是MATLAB 64位C語言和C++編譯應(yīng)用程序免費(fèi)下載。
發(fā)表于 05-21 08:00 ?4次下載
MATLAB 64位C語言和C++<b class='flag-5'>編譯</b>器<b class='flag-5'>應(yīng)用程序</b>免費(fèi)下載

STM32的編譯器CubeIDE安裝包應(yīng)用程序免費(fèi)下載

本文檔的主要內(nèi)容詳細(xì)介紹的使用STM32的編譯器CubeIDE安裝包應(yīng)用程序免費(fèi)下載。
發(fā)表于 11-28 11:44 ?27次下載
STM32的<b class='flag-5'>編譯</b>器CubeIDE安裝包<b class='flag-5'>應(yīng)用程序</b>免費(fèi)下載

HI-TECH PICC編譯器8.05版應(yīng)用程序

本文檔的主要內(nèi)容詳細(xì)介紹的是HI-TECH PICC編譯器8.05版應(yīng)用程序免費(fèi)下載。
發(fā)表于 06-08 08:00 ?0次下載
HI-TECH PICC<b class='flag-5'>編譯</b>器8.05版<b class='flag-5'>應(yīng)用程序</b>

在BlueField DPU上通過DOCA加速方案開發(fā)

NVIDIA 希望您能輕松使用 DPU 的各種功能,并簡化以下流程:在 DPU 上創(chuàng)建新應(yīng)用程序,或者將現(xiàn)有應(yīng)用程序與 BlueField DPU
的頭像 發(fā)表于 04-14 15:51 ?1971次閱讀
在BlueField <b class='flag-5'>DPU</b>上通過DOCA加速方案開發(fā)

NVIDIA BlueField DPU應(yīng)用程序的不同編譯方法

  隨著我們進(jìn)入 NVIDIA BlueField DPU 應(yīng)用程序開發(fā)的新世界,高效地設(shè)置構(gòu)建步驟非常重要,以便您能夠無縫地{code =》 compile =》 unit-test}。在本文中,我介紹了為 DPU
的頭像 發(fā)表于 04-20 14:12 ?2003次閱讀
NVIDIA BlueField <b class='flag-5'>DPU</b><b class='flag-5'>應(yīng)用程序</b>的不同<b class='flag-5'>編譯</b><b class='flag-5'>方法</b>

NVIDIA BlueField DPU編譯應(yīng)用程序的不同方法

  您在說明書中常常看到“去喝杯咖啡”嗎?作為一名開發(fā)人員,我很早就發(fā)現(xiàn)這種令人生厭的俏皮話是我生活中的禍根。無論持續(xù)時間長短,進(jìn)程切換(Context Switches)在應(yīng)用程序開發(fā)周期中都是一項(xiàng)高昂的成本。在所有需要您離開的步驟中,等待應(yīng)用程序
的頭像 發(fā)表于 04-25 11:51 ?1331次閱讀

使用 Microsoft Azure Stack HCI 和 NVIDIA BlueField DPU 加速企業(yè)應(yīng)用程序

DPU(數(shù)據(jù)處理器)是一個加速的數(shù)據(jù)中心基礎(chǔ)設(shè)施平臺,可釋放應(yīng)用程序性能和系統(tǒng)效率。NVIDIA BlueField DPU 幫助有
的頭像 發(fā)表于 11-22 19:45 ?817次閱讀

如何實(shí)現(xiàn)DPU加速數(shù)據(jù)包轉(zhuǎn)向邏輯呢?

NVIDIA DOCA 框架旨在簡化 NVIDIA BlueField DPU 和 ConnectX 智能網(wǎng)卡的編程和應(yīng)用程序開發(fā)。
的頭像 發(fā)表于 09-19 10:00 ?831次閱讀
如何實(shí)現(xiàn)<b class='flag-5'>DPU</b>加速數(shù)據(jù)包轉(zhuǎn)向邏輯呢?

linux驅(qū)動程序編譯方法是什么

Linux驅(qū)動程序編譯方法主要包括兩種: 與內(nèi)核一起編譯編譯成獨(dú)立的內(nèi)核模塊 。以下是對這兩種
的頭像 發(fā)表于 08-30 14:46 ?992次閱讀
主站蜘蛛池模板: 纯肉宠文高h一对一 | www.伊人网| 国产乱人精品视频AV麻豆 | 欧美日韩免费播放一区二区 | 欧美精品华人在线 | 一天不停的插BB十几次 | 亚洲视频中文字幕 | 99青草青草久热精品视频 | 国产3级在线| 久久yy99re66| 肉动漫无码无删减在线观看 | 91国偷自产一区二区三区 | 欧美精品九九99久久在免费线 | 国产视频这里只有精品 | 午夜理伦大片一级 | AAA级精品无码久久久国片 | 中文字幕人成人乱码亚洲影视 | 麻豆免费观看高清完整视频在线 | 牛牛在线国产精品 | 六月婷婷国产精品综合 | 黑人寄宿羽月希产后奶水 | 调教椅上的调教SM总裁被调教 | 高h浪荡文辣文神奇宝贝 | 黄色网址在线播放 | yellow免费影视大全 | 韩国电影real在线观看完整版 | 久久高清一本无码 | 曰曰夜夜在线影院视 | 欧美日韩精品一区二区三区高清视频 | 67194在线入口免费 | qvod电影资源| 黑人开嫩苞 | 亚洲日本一区二区三区在线不卡 | 日本伦子欲 | 久久精品亚洲AV中文2区金莲 | 久久精品国产久精国产果冻传媒 | 亚洲成A人片在线观看中文L | 18禁黄无遮挡禁游戏在线下载 | 青青国产在线观看视频 | 伊人久久大香线蕉综合电影网 | 无码任你躁久久久久久久 |

電子發(fā)燒友

中國電子工程師最喜歡的網(wǎng)站

  • 2931785位工程師會員交流學(xué)習(xí)
  • 獲取您個性化的科技前沿技術(shù)信息
  • 參加活動獲取豐厚的禮品