XIO内核架构分析
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é)
- 上一篇: You may need an appr
- 下一篇: vm8网卡原理及应用