DPDK編程指南(翻譯)( 二十一)

21.內(nèi)核網(wǎng)絡(luò)接口卡接口

DPDK Kernel NIC Interface(KNI)允許用戶空間應(yīng)用程序訪問Linux *控制面帮毁。

使用DPDK KNI的好處是:

  • 比現(xiàn)有的Linux TUN / TAP接口更快(通過消除系統(tǒng)調(diào)用和copy_to_user()/copy_from_user()操作)。
  • 允許使用標(biāo)準(zhǔn)Linux網(wǎng)絡(luò)工具(如ethtool黔牵,ifconfig和tcpdump)管理DPDK端口爷肝。
  • 允許與內(nèi)核網(wǎng)絡(luò)堆棧的接口。

使用DPDK內(nèi)核NIC接口的應(yīng)用程序的組件如圖所示金赦。

Figure 21-1 Components of a DPDK KNI Application

21.1.DPDK KNI內(nèi)核模塊

KNI內(nèi)核可加載模塊支持兩種類型的設(shè)備:

  • 其他設(shè)備:
    • 創(chuàng)建網(wǎng)絡(luò)設(shè)備(通過ioctl調(diào)用)牧愁。
    • 維護(hù)所有KNI實例共享的內(nèi)核線程上下文(模擬網(wǎng)絡(luò)驅(qū)動程序的RX端)猪半。
    • 對于單內(nèi)核線程模式偷线,維護(hù)所有KNI實例共享的內(nèi)核線程上下文(模擬網(wǎng)絡(luò)驅(qū)動程序的RX端)。
    • 對于多個內(nèi)核線程模式声邦,為每個KNI實例(模擬新驅(qū)動程序的RX側(cè))維護(hù)一個內(nèi)核線程上下文亥曹。
  • 網(wǎng)絡(luò)設(shè)備:
    • 通過實現(xiàn)由struct net_device定義的諸如netdev_ops,header_ops媳瞪,ethtool_ops之類的幾個操作提供的Net功能蛇受,包括支持DPDK mbufs和FIFO。
    • 接口名稱由用戶空間提供。
    • MAC地址可以是真正的NIC MAC地址或隨機(jī)的剂碴。

21.2. KNI創(chuàng)建及刪除
KNI接口由DPDK應(yīng)用程序動態(tài)創(chuàng)建轻专。接口名稱和FIFO詳細(xì)信息由應(yīng)用程序通過ioctl調(diào)用使用rte_kni_device_info結(jié)構(gòu)提供,該結(jié)構(gòu)包含:

  • 接口名稱洪碳。
  • 相關(guān)FIFO的相應(yīng)存儲器的物理地址叼屠。
  • Mbuf mempool詳細(xì)信息,包括物理和虛擬(計算mbuf指針的偏移量)嫂侍。
  • PCI信息荚坞。
  • Core。

有關(guān)詳細(xì)信息各淀,請參閱DPDK源代碼中的rte_kni_common.h诡挂。

物理地址將重新映射到內(nèi)核地址空間,并存儲在單獨(dú)的KNI上下文中奴璃。

內(nèi)核RX線程(單線程和多線程模式)的親和力由force_bind和core_id配置參數(shù)控制城豁。

創(chuàng)建后,DPDK應(yīng)用程序可以動態(tài)刪除KNI接口雳旅。此外间聊,所有未刪除的KNI接口將在雜項設(shè)備(DPDK應(yīng)用程序關(guān)閉時)的釋放操作中被刪除。

21.3.DPDK緩沖區(qū)流

為了最小化在內(nèi)核空間中運(yùn)行的DPDK代碼的數(shù)量甸饱,mbuf mempool僅在用戶空間中進(jìn)行管理。內(nèi)核模塊可以感知mbufs偷遗,但是所有mbuf分配和釋放操作將僅由DPDK應(yīng)用程序處理。

Figure 21-2 Packet Flow via mbufs in the DPDK KNI

21.4.用例: Ingress

在DPDK RX側(cè)喉酌,mbuf由PMD在RX線程上下文中分配泪电。該線程將mbuf入隊到rx_q FIFO中纪铺。 KNI線程將輪詢所有KNI活動設(shè)備。如果mbuf出隊突诬,它將被轉(zhuǎn)換為sk_buff芜繁,并通過netif_rx()發(fā)送到網(wǎng)絡(luò)協(xié)議棧。必須釋放出隊的mbuf骏令,將指針返回到free_q FIFO中榔袋。

RX線程在相同的主循環(huán)中輪詢該FIFO,并在出隊之后釋放mbuf摘昌。

21.5.用例: Egress

對于數(shù)據(jù)包出口聪黎,DPDK應(yīng)用程序必須首先入隊幾個mbufs才能在內(nèi)核端創(chuàng)建一個mbuf緩存备恤。

通過調(diào)用kni_net_tx()回調(diào),從Linux網(wǎng)絡(luò)堆棧接收數(shù)據(jù)包露泊。mbuf出隊(因為使用緩存惭笑,所以無需等待)生真,并填充了來自sk_buff的數(shù)據(jù)捺宗。然后釋放sk_buff,并將mbuf發(fā)送到tx_q FIFO长已。

DPDK TX線程執(zhí)行mbuf出隊昼牛,并將其發(fā)送到PMD(通過rte_eth_tx_burst())。 然后將mbuf放回緩存中胞四。

21.6.以太網(wǎng)工具

Ethtool是Linux專用工具伶椿,在內(nèi)核中具有相應(yīng)的支持,每個網(wǎng)絡(luò)設(shè)備必須為支持的操作注冊自己的回調(diào)游昼。目前的實現(xiàn)使用igb / ixgbe修改的Linux驅(qū)動程序進(jìn)行ethtool支持尝蠕。i40e和VM(VF或EM設(shè)備)不支持Ethtool。

21.7.鏈路狀態(tài)及MTU改變

鏈路狀態(tài)和MTU變化是通常通過ifconfig完成的網(wǎng)絡(luò)接口操作廊佩。該請求是從內(nèi)核端(在ifconfig進(jìn)程的上下文中)發(fā)起的靖榕,由用戶空間DPDK應(yīng)用程序處理。應(yīng)用程序輪詢請求料皇,調(diào)用應(yīng)用程序處理程序并將響應(yīng)返回到內(nèi)核空間星压。

應(yīng)用處理程序可以在創(chuàng)建接口時注冊,也可以在運(yùn)行時再注冊/卸載逊脯。這提供了多進(jìn)程方案(其中KNI在primary process中創(chuàng)建竣贪,在secondary process中處理回調(diào))的靈活性巩螃。約束是單個進(jìn)程可以注冊和處理請求匕争。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末汗捡,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子春缕,更是在濱河造成了極大的恐慌艘蹋,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,590評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宅荤,死亡現(xiàn)場離奇詭異浸策,居然都是意外死亡庸汗,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評論 3 399
  • 文/潘曉璐 我一進(jìn)店門改化,熙熙樓的掌柜王于貴愁眉苦臉地迎上來枉昏,“玉大人,你說我怎么就攤上這事句旱∨尘剑” “怎么了稚配?”我有些...
    開封第一講書人閱讀 169,301評論 0 362
  • 文/不壞的土叔 我叫張陵道川,是天一觀的道長立宜。 經(jīng)常有香客問我臊岸,道長,這世上最難降的妖魔是什么灯帮? 我笑而不...
    開封第一講書人閱讀 60,078評論 1 300
  • 正文 為了忘掉前任逻住,我火速辦了婚禮瞎访,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘扒秸。我一直安慰自己伴奥,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,082評論 6 398
  • 文/花漫 我一把揭開白布顶霞。 她就那樣靜靜地躺著锣吼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪古徒。 梳的紋絲不亂的頭發(fā)上读恃,一...
    開封第一講書人閱讀 52,682評論 1 312
  • 那天寺惫,我揣著相機(jī)與錄音,去河邊找鬼西雀。 笑死艇肴,一個胖子當(dāng)著我的面吹牛叁温,可吹牛的內(nèi)容都是我干的核畴。 我是一名探鬼主播,決...
    沈念sama閱讀 41,155評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼跟束,長吁一口氣:“原來是場噩夢啊……” “哼丑孩!你這毒婦竟也來了嚎杨?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,098評論 0 277
  • 序言:老撾萬榮一對情侶失蹤刨肃,失蹤者是張志新(化名)和其女友劉穎箩帚,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體盔然,經(jīng)...
    沈念sama閱讀 46,638評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡是嗜,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,701評論 3 342
  • 正文 我和宋清朗相戀三年鹅搪,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片恢准。...
    茶點故事閱讀 40,852評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡馁筐,死狀恐怖坠非,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤舱卡,帶...
    沈念sama閱讀 36,520評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站矫钓,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏赵辕。R本人自食惡果不足惜概龄,卻給世界環(huán)境...
    茶點故事閱讀 42,181評論 3 335
  • 文/蒙蒙 一私杜、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧锣光,春花似錦、人聲如沸誊爹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至兽赁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間惊科,已是汗流浹背亮钦。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留混卵,地道東北人。 一個月前我還...
    沈念sama閱讀 49,279評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像宿接,于是被迫代替她去往敵國和親赘淮。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,851評論 2 361

推薦閱讀更多精彩內(nèi)容

  • 3. 環(huán)境抽象層 環(huán)境抽象層(Environment Abstraction Layer睦霎,下文簡稱EAL)是對操作...
    希爾哥哥s閱讀 4,646評論 0 1
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,323評論 25 707
  • 3. 環(huán)境抽象層 環(huán)境抽象層(EAL)為底層資源如硬件和存儲空間的訪問提供了接口梢卸。這些接口為上層應(yīng)用程序和庫隱藏了...
    半天妖閱讀 4,611評論 0 10
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)副女,斷路器蛤高,智...
    卡卡羅2017閱讀 134,715評論 18 139
  • 的確,我們每天都有很多事情要做碑幅,在我們的大腦里每天都會冒出很多想法戴陡。而當(dāng)我們的事情沒有被完成時,我們的大腦就會感到...
    滋心潤霖閱讀 243評論 0 0