日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

XIO内核架构分析

發(fā)布時間:2023/12/18 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 XIO内核架构分析 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

xio也就是accelio是一個開源融合網(wǎng)絡(luò)加速接口。有幸被安排分析該軟件并有了一定階段性成果,先上個架構(gòu)圖,后續(xù)再陳述其用途。

以下是其內(nèi)核部分的架構(gòu)。


xio_core模塊:提供xio內(nèi)部的基礎(chǔ)服務(wù),同時對外提供API。其中黑色線條框的模塊提供用戶態(tài)和內(nèi)核態(tài)的通用特性。
xio_connection:msg管理的載體,一個特定session在一個線程上的連接實例。一個session在一個特定線程上只能有一個連接實例,不同的session可以有多個不同的connection。同一個線程上的connection指向到同一個uri時,共享nexus。
xio_session:session管理,分別實現(xiàn)服務(wù)端和客戶端的session管理,session是一組connection的集合。session管理提供session對象的創(chuàng)建、修改、查詢、刪除,以及session事件處理的框架。
xio_ctx:上下文管理模塊,負(fù)責(zé)xio的事件分發(fā),每個線程僅一個。
xio_option:配置設(shè)置與獲取

xio_nexus:一個具體的傳輸連接。管理task,從connection接收msg并轉(zhuǎn)換成task提交到傳輸層。
xio_ev_loop:事件處理相關(guān)的功能,提供xio私有的事件處理方法,以及用戶定義的事件處理方法的初始化。內(nèi)核態(tài)支持ctx創(chuàng)建時指定事件引擎運(yùn)行在當(dāng)前線程。
xio_idr:負(fù)責(zé)xio的對象記錄,主要用于對象創(chuàng)建、刪除時的合法性校驗
xio_observer:觀察者模式基礎(chǔ)庫
xio_mempool:內(nèi)存管理,通用的內(nèi)存塊申請、釋放接口
xio_task:task管理,主要使用傳輸層的方法實現(xiàn)task的管理
xio_transport:負(fù)責(zé)抽象的傳輸層方法管理(傳輸層方法的注冊、注銷),每種傳輸層實現(xiàn)一種連接類型的任務(wù)管理,連接打開、連接、監(jiān)聽、接收、發(fā)包、配置、修改、查詢、銷毀的方法。
xio_workqueue:處理xio非緊急任務(wù)、異常的工作隊列。
xio_sg:抽象了3種類型的sg(內(nèi)核態(tài)只有一種),每種提供自己的一系列sg操作方法。通過這種方式來實現(xiàn)不同sg間的互操作


rdma-datapath:負(fù)責(zé)數(shù)據(jù)收發(fā)
rdma_management:負(fù)責(zé)模塊加載卸載,基于xio_core對傳輸層的抽象,實現(xiàn)rdma的傳輸方法,rdma鏈接管理,完成事件管理。負(fù)責(zé)注冊ib_client來操作ib_dev,并接收ib_dev的異常事件。
rdma_memory:負(fù)責(zé)內(nèi)存注冊,收發(fā)內(nèi)存的映射。內(nèi)核態(tài)使用的是dma_mr,在模塊加載時注冊,后續(xù)內(nèi)存使用只需要映射后即可提交給網(wǎng)卡使用。
other:一些宏轉(zhuǎn)字符串的功能


tcp_datapath:負(fù)責(zé)數(shù)據(jù)收發(fā)
tcp_management:負(fù)責(zé)模塊加載卸載,基于xio_core對傳輸層的抽象,實現(xiàn)tcp的傳輸方法

總結(jié)

以上是生活随笔為你收集整理的XIO内核架构分析的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。