XIO内核架构分析
xio也就是accelio是一個開源融合網絡加速接口。有幸被安排分析該軟件并有了一定階段性成果,先上個架構圖,后續再陳述其用途。
以下是其內核部分的架構。
xio_core模塊:提供xio內部的基礎服務,同時對外提供API。其中黑色線條框的模塊提供用戶態和內核態的通用特性。
xio_connection:msg管理的載體,一個特定session在一個線程上的連接實例。一個session在一個特定線程上只能有一個連接實例,不同的session可以有多個不同的connection。同一個線程上的connection指向到同一個uri時,共享nexus。
xio_session:session管理,分別實現服務端和客戶端的session管理,session是一組connection的集合。session管理提供session對象的創建、修改、查詢、刪除,以及session事件處理的框架。
xio_ctx:上下文管理模塊,負責xio的事件分發,每個線程僅一個。
xio_option:配置設置與獲取
xio_nexus:一個具體的傳輸連接。管理task,從connection接收msg并轉換成task提交到傳輸層。
xio_ev_loop:事件處理相關的功能,提供xio私有的事件處理方法,以及用戶定義的事件處理方法的初始化。內核態支持ctx創建時指定事件引擎運行在當前線程。
xio_idr:負責xio的對象記錄,主要用于對象創建、刪除時的合法性校驗
xio_observer:觀察者模式基礎庫
xio_mempool:內存管理,通用的內存塊申請、釋放接口
xio_task:task管理,主要使用傳輸層的方法實現task的管理
xio_transport:負責抽象的傳輸層方法管理(傳輸層方法的注冊、注銷),每種傳輸層實現一種連接類型的任務管理,連接打開、連接、監聽、接收、發包、配置、修改、查詢、銷毀的方法。
xio_workqueue:處理xio非緊急任務、異常的工作隊列。
xio_sg:抽象了3種類型的sg(內核態只有一種),每種提供自己的一系列sg操作方法。通過這種方式來實現不同sg間的互操作
rdma-datapath:負責數據收發
rdma_management:負責模塊加載卸載,基于xio_core對傳輸層的抽象,實現rdma的傳輸方法,rdma鏈接管理,完成事件管理。負責注冊ib_client來操作ib_dev,并接收ib_dev的異常事件。
rdma_memory:負責內存注冊,收發內存的映射。內核態使用的是dma_mr,在模塊加載時注冊,后續內存使用只需要映射后即可提交給網卡使用。
other:一些宏轉字符串的功能
tcp_datapath:負責數據收發
tcp_management:負責模塊加載卸載,基于xio_core對傳輸層的抽象,實現tcp的傳輸方法
總結
- 上一篇: You may need an appr
- 下一篇: vm8网卡原理及应用