3.6. scull 的內(nèi)存使用

2018-02-24 15:49 更新

3.6.?scull 的內(nèi)存使用

在介紹讀寫操作前, 我們最好看看如何以及為什么 scull 進(jìn)行內(nèi)存分配. "如何"是需要全面理解代碼, "為什么"演示了驅(qū)動編寫者需要做的選擇, 盡管 scull 明確地不是典型設(shè)備.

本節(jié)只處理 scull 中的內(nèi)存分配策略, 不展示給你編寫真正驅(qū)動需要的硬件管理技能. 這些技能在第 9 章和第 10 章介紹. 因此, 你可跳過本章, 如果你不感興趣于理解面向內(nèi)存的 scull 驅(qū)動的內(nèi)部工作.

scull 使用的內(nèi)存區(qū), 也稱為一個設(shè)備, 長度可變. 你寫的越多, 它增長越多; 通過使用一個短文件覆蓋設(shè)備來進(jìn)行修整.

scull 驅(qū)動引入 2 個核心函數(shù)來管理 Linux 內(nèi)核中的內(nèi)存. 這些函數(shù), 定義在 <linux/slab.h>, 是:


void *kmalloc(size_t size, int flags); 
void kfree(void *ptr);

對 kmalloc 的調(diào)用試圖分配 size 字節(jié)的內(nèi)存; 返回值是指向那個內(nèi)存的指針或者如果分配失敗為NULL. flags 參數(shù)用來描述內(nèi)存應(yīng)當(dāng)如何分配; 我們在第 8 章詳細(xì)查看這些標(biāo)志. 對于現(xiàn)在, 我們一直使用 GFP_KERNEL. 分配的內(nèi)存應(yīng)當(dāng)用 kfree 來釋放. 你應(yīng)當(dāng)從不傳遞任何不是從 kmalloc 獲得的東西給 kfree. 但是, 傳遞一個 NULL 指針給 kfree 是合法的.

kmalloc 不是最有效的分配大內(nèi)存區(qū)的方法(見第 8 章), 所以挑選給 scull 的實(shí)現(xiàn)不是一個特別巧妙的. 一個巧妙的源碼實(shí)現(xiàn)可能更難閱讀, 而本節(jié)的目標(biāo)是展示讀和寫, 不是內(nèi)存管理. 這是為什么代碼只是使用 kmalloc 和 kfree 而不依靠整頁的分配, 盡管這個方法會更有效.

在 flip 一邊, 我們不想限制"設(shè)備"區(qū)的大小, 由于理論上的和實(shí)踐上的理由. 理論上, 給在被管理的數(shù)據(jù)項(xiàng)施加武斷的限制總是個壞想法. 實(shí)踐上, scull 可用來暫時地吃光你系統(tǒng)中的內(nèi)存, 以便運(yùn)行在低內(nèi)存條件下的測試. 運(yùn)行這樣的測試可能會幫助你理解系統(tǒng)的內(nèi)部. 你可以使用命令 cp /dev/zero /dev/scull0 來用 scull 吃掉所有的真實(shí) RAM, 并且你可以使用 dd 工具來選擇貝多少數(shù)據(jù)給 scull 設(shè)備.

在 scull, 每個設(shè)備是一個指針鏈表, 每個都指向一個 scull_dev 結(jié)構(gòu). 每個這樣的結(jié)構(gòu), 缺省地, 指向最多 4 兆字節(jié), 通過一個中間指針數(shù)組. 發(fā)行代碼使用一個 1000 個指針的數(shù)組指向每個 4000 字節(jié)的區(qū)域. 我們稱每個內(nèi)存區(qū)域?yàn)橐粋€量子, 數(shù)組(或者它的長度) 為一個量子集. 一個 scull 設(shè)備和它的內(nèi)存區(qū)如圖一個 scull 設(shè)備的布局所示.

圖?3.1.?一個 scull 設(shè)備的布局

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號