版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
于PCI9656設(shè)備驅(qū)動程序的Linux2.6內(nèi)核研究
1引言Linux操作系統(tǒng)因?yàn)槠涓咝А踩?、可動態(tài)加載及源代碼開放等特點(diǎn),深受設(shè)備驅(qū)動程序開發(fā)人員的喜愛。系統(tǒng)內(nèi)核大部分獨(dú)立于底層硬件運(yùn)行,用戶無需關(guān)心硬件問題,而用戶操作是通過一組標(biāo)準(zhǔn)化的調(diào)用來完成。設(shè)備驅(qū)動程序的任務(wù)是將這些調(diào)用映射到作用于實(shí)際硬件設(shè)備的特定操作上,該編程接口能夠使得驅(qū)動程序獨(dú)立于內(nèi)核的其他部分來搭建,在需要時才動態(tài)加載到內(nèi)核。這種模塊化的特點(diǎn),使得Linux設(shè)備驅(qū)動程序的編寫過程變得清晰簡單。目前,為滿足日益龐大的數(shù)據(jù)處理需要,基于64位PCI總線接口設(shè)備的研究開發(fā)顯得尤為重要。因而本文將基于PLX公司推出的PCI總線接口芯片PCI9656,設(shè)計開發(fā)在Linux2.6內(nèi)核下的設(shè)備驅(qū)動程序,進(jìn)而對2.6內(nèi)核的內(nèi)存和中斷管理機(jī)制進(jìn)行分析研究。2Linux2.6與2.4內(nèi)核的比較2.1系統(tǒng)穩(wěn)定性為了徹底防止對正在被使用的內(nèi)核模塊進(jìn)行錯誤操作,2.6內(nèi)核在加載和導(dǎo)出內(nèi)核模塊方面都較2.4內(nèi)核進(jìn)行了改進(jìn),避免了用戶執(zhí)行將導(dǎo)致系統(tǒng)崩潰的操作,例如強(qiáng)制刪除模塊等。同時,當(dāng)驅(qū)動程序需要在多個文件中包含<linux/module.h>頭文件時,不必定義宏__NO_VERSION__來檢查內(nèi)核的版本。2.2統(tǒng)一設(shè)備模型統(tǒng)一設(shè)備模型的創(chuàng)建是2.6內(nèi)核最重要的變化之一。它促進(jìn)了模塊接口的標(biāo)準(zhǔn)化,其目的是更好地控制和管理設(shè)備,主要包括:更準(zhǔn)確地確定系統(tǒng)設(shè)備,更高效的進(jìn)行電源管理以及改進(jìn)的系統(tǒng)總線結(jié)構(gòu)管理。2.3內(nèi)核基礎(chǔ)設(shè)施2.6內(nèi)核為了區(qū)別以.o為擴(kuò)展名的常規(guī)對象文件,將內(nèi)核模塊的擴(kuò)展名改為.ko。相對于2.4內(nèi)核下系統(tǒng)所支持的RAM為4GB而言,2.6內(nèi)核下系統(tǒng)支持更大數(shù)量的RAM,在分頁模式下最高可達(dá)64GB。同時,2.6內(nèi)核優(yōu)化了I/O調(diào)度器,確保不會有進(jìn)程駐留在隊(duì)列中過長時間等待輸入/輸出操作,使得I/O操作的響應(yīng)更為迅速。2.4外部設(shè)備在2.4內(nèi)核中有約束大型系統(tǒng)的限制,比如支持的每一類設(shè)備的最大數(shù)量為256。而2.6內(nèi)核則徹底地打破了這些限制,可以支持4095種主要的設(shè)備類型,每一個單獨(dú)的類型又可以支持超過一百萬個的子設(shè)備。3Linux2.6內(nèi)核下PCI設(shè)備驅(qū)動程序的設(shè)計3.1PCI設(shè)備驅(qū)動程序中核心數(shù)據(jù)結(jié)構(gòu)在2.6內(nèi)核下使用file_operations數(shù)據(jù)結(jié)構(gòu),來建立設(shè)備驅(qū)動程序中的函數(shù)與主設(shè)備號(majornumber)之間的對應(yīng)關(guān)系。該數(shù)據(jù)結(jié)構(gòu)中包含了指向驅(qū)動程序內(nèi)部大多數(shù)函數(shù)的指針,描述了虛擬文件系統(tǒng)如何操作一個打開的外圍設(shè)備。因而file_operations結(jié)構(gòu)是驅(qū)動程序向內(nèi)核其他部分提供的一個統(tǒng)一的標(biāo)準(zhǔn)設(shè)備接口。file結(jié)構(gòu)是設(shè)備驅(qū)動程序使用的另一個重要的數(shù)據(jù)結(jié)構(gòu),指示當(dāng)前系統(tǒng)中已打開的文件。它在C語言庫中定義,在調(diào)用內(nèi)核open函數(shù)時創(chuàng)建,并傳遞給在該設(shè)備上進(jìn)行操作的所有函數(shù),直到最后的close函數(shù)。file結(jié)構(gòu)中還包含了指向它所擁有的file_operations結(jié)構(gòu)的指針。inode結(jié)構(gòu)由內(nèi)核自動生成,代表已打開文件的描述符,與每個打開的文件一一對應(yīng)。它包含了兩個重要的結(jié)構(gòu)成員:dev_t擴(kuò)展到32位,其中12位主設(shè)備號,20位從設(shè)備號,而cdev用于存儲一個指向字符設(shè)備文件的指針。3.2驅(qū)動程序與內(nèi)核和外部設(shè)備間的關(guān)系(1)通過Linux提供的系統(tǒng)調(diào)用函數(shù)(例如init_module等)進(jìn)入內(nèi)核,這些函數(shù)在2.6內(nèi)核版本下總共有兩百多個,提供了幾乎所有應(yīng)用程序進(jìn)入內(nèi)核所需要執(zhí)行的操作。(2)系統(tǒng)的內(nèi)核函數(shù)都有“sys_”前綴(例如函數(shù)sys_init_module),應(yīng)用程序通過訪問設(shè)備文件系統(tǒng)來調(diào)用這些函數(shù)。這一層主要是“devfs”(devicefilesystem)文件管理機(jī)制,它是從普通文件和設(shè)備文件抽象出來的一個文件系統(tǒng)層,完成進(jìn)入具體的設(shè)備文件操作之前的準(zhǔn)備工作。(3)由設(shè)備驅(qū)動程序提供具體的函數(shù),來完成對硬件設(shè)備的各種操作。特別的對于PCI9656來說,就是通過PCI接口對設(shè)備的寄存器和存儲器進(jìn)行訪問操作,例如調(diào)用register_chrdev等函數(shù)來初始化芯片內(nèi)部的狀態(tài)寄存器和配置寄存器。3.3PCI9656芯片的操作流程4.Linux2.6內(nèi)核下內(nèi)存和中斷管理的研究2.6內(nèi)核應(yīng)用了許多新技術(shù)來實(shí)現(xiàn)對各類外部設(shè)備驅(qū)動程序的更好支持。下面結(jié)合PCI9656驅(qū)動程序中的內(nèi)存和中斷管理,進(jìn)一步分析和研究2.6內(nèi)核對內(nèi)存和中斷進(jìn)行的改進(jìn)和優(yōu)化。4.1內(nèi)存管理在Linux內(nèi)存管理器中,頁表保持對進(jìn)程使用的內(nèi)存物理頁的追蹤,它將虛擬頁映射到物理頁上。系統(tǒng)必須找到映射到該頁的每一個進(jìn)程,將使用較少的頁置換出去,這樣進(jìn)程中相應(yīng)頁的頁表?xiàng)l目才能被更新。隨著在系統(tǒng)中運(yùn)行的進(jìn)程數(shù)量的增加,將這些頁置換出去的工作量也會急劇增加。為解決此問題,2.6內(nèi)核引入了反向映射機(jī)制(reversemapping),內(nèi)存管理器為每一個物理頁建立一個鏈表,包含指向當(dāng)前映射頁的每個進(jìn)程的頁表?xiàng)l目(tableentry)的指針。該鏈表叫PTE鏈,它極大地提高了找到那些映射某個頁的進(jìn)程的速度,如圖2所示。驅(qū)動程序調(diào)用下列內(nèi)核函數(shù)來為PCI9656分配內(nèi)存空間。get_free_page(GFP_NOIO,PGD_ORDER);alloc_pages(gfp_mask,size);//查找并為PCI9656分配空閑內(nèi)存物理頁mempool_alloc(pool,gfp_mask);request_mem_region(pdx->Pci9656);remap_page_range(*mem_area,PCI9656,kernel_address,mem_size,prot);//請求分配內(nèi)存空間,實(shí)現(xiàn)PCI9656物理地址到內(nèi)存地址的映射mempool_free(*element,pool);//釋放內(nèi)存2.6內(nèi)核中將頭文件malloc.h改為slab.h,分配標(biāo)志GFP_BUFFER改為GFP_NOIO和GFP_NOFS,并新增了文件mempool.h。這些變化一起促生了2.6內(nèi)核中的內(nèi)存管理器,其設(shè)計目標(biāo)是更高的性能、效率和穩(wěn)定性。另一方面,使用反向映射獲得性能的提高也要付出代價,即系統(tǒng)不得不占用一些低端內(nèi)存來保持對所有反向映射的追蹤,這勢必在32位硬件上成為內(nèi)存空間的瓶頸。因此2.6內(nèi)核引入了高端內(nèi)存頁表(HighmemPTE)機(jī)制,讓頁表?xiàng)l目存放在高端內(nèi)存中,釋放出更多的低端內(nèi)存區(qū)給必須放在這里的內(nèi)核數(shù)據(jù)結(jié)構(gòu)。同時,較以前版本的內(nèi)核而言,2.6內(nèi)核重新構(gòu)建了一個更為簡單的內(nèi)存管理器,提高了整個系統(tǒng)的穩(wěn)定性。4.2中斷處理Linux處理中斷的方式很大程度上與它在用戶空間處理信號的方式一樣,驅(qū)動程序只需為設(shè)備所對應(yīng)的中斷注冊一個處理程序,并在中斷到達(dá)時進(jìn)行正確的處理。在2.4內(nèi)核之前,Linux系統(tǒng)一直采用cli和sti函數(shù)來禁用和啟用中斷,然而對于任意某個例程,想要知道在它被調(diào)用時中斷是否被啟用,已變得越來越困難。因而2.6內(nèi)核定義了函數(shù)local_irq_enable和local_irq_disable,用來使能和無效處理器控制的所有中斷,定義函數(shù)local_irq_save來將當(dāng)前中斷的狀態(tài)存入flags變量,避免了查詢中斷的狀態(tài)信息。中斷處理程序的作用就是將有關(guān)中斷接收的信息反饋給設(shè)備,并根據(jù)正在服務(wù)的中斷的不同含義對數(shù)據(jù)進(jìn)行相應(yīng)的讀或?qū)?。由于PC機(jī)只有0-15的中斷號,設(shè)備都是以共享的形式申請中斷號,2.6內(nèi)核改進(jìn)了PCI設(shè)備中斷請求隊(duì)列的組織方式,通過設(shè)置flags變量中的SA_SHIRQ標(biāo)志位,并保證內(nèi)核中所有中斷號(dev_id)的唯一性,來實(shí)現(xiàn)中斷的共享。if(!(inb(card->iobase+CODEC_CMD_INT_STATUS)&0x80000000))return;//識別中斷類型request_irq(irq,*handler,flags,PCI9656,*dev_id);//向系統(tǒng)注冊PCI9656的中斷如果中斷注冊成功,則返回值IRQ_RETVAL為0,這時在/proc/interrupts文件中可以看申請成功的中斷。在2.6內(nèi)核下,request_irq和free_irq從sched.h改到了interrupt.h中定義。synchronize_irq(irq);//中斷同步if(wait_event_interruptible(waitqueue,condition)>0)return;//判斷中斷等待使能outb(intstat&card->iobase+CODEC_CMD_INT_HLDCLR+2);//使能并行端口的中斷報告//系統(tǒng)響應(yīng)PCI9656的中斷,執(zhí)行數(shù)據(jù)讀寫、寄存器訪問等操作free_irq(irq,*dev_id);//釋放設(shè)備中斷、I/O資源和緩沖區(qū)5實(shí)驗(yàn)與測試我們設(shè)計了Makefile文件和一個簡單的應(yīng)用程序,在動態(tài)加載驅(qū)動程序后,對PCI9656開發(fā)板進(jìn)行了大批量數(shù)據(jù)的讀寫實(shí)驗(yàn)?;?4位PCI總線和100MHz的時鐘頻率,我們對芯片的數(shù)據(jù)讀寫速率進(jìn)行了采集,實(shí)驗(yàn)結(jié)果統(tǒng)計如圖3所示。從上圖可以看到,在2.6內(nèi)核下應(yīng)用PCI9656作為總線接口芯片,數(shù)據(jù)的讀寫傳輸速率隨著數(shù)據(jù)包的大小有大幅度的提高,這在工程應(yīng)用中有很大的現(xiàn)實(shí)意義。6結(jié)束語本文通過Linux2.6內(nèi)核所提供的一系列標(biāo)準(zhǔn)函數(shù)調(diào)用接口,用C++語言開發(fā)了PCI9656的設(shè)備驅(qū)動程序,并在FedoraCore2平臺下調(diào)試通過,能正確發(fā)送和接收各種大小的數(shù)據(jù)包
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年園林景觀工程施工監(jiān)理合同范本3篇
- 2024年度高端養(yǎng)生浴池租賃合作協(xié)議3篇
- 2024年標(biāo)準(zhǔn)協(xié)議免責(zé)條款模板版B版
- 2024年度文化旅游資源招商引資居間合同3篇
- 2024年度知識產(chǎn)權(quán)交易與評估合同范本3篇
- 2024年度校企合作人才培養(yǎng)與科研項(xiàng)目合作合同范本3篇
- 貴州省前期物業(yè)服務(wù)合同2025
- 定制代加工合同范例
- 火燒店加盟合同范例
- 網(wǎng)店運(yùn)營兼職合同范例
- 春節(jié)期間施工現(xiàn)場安全方案
- 進(jìn)料檢驗(yàn)作業(yè)指導(dǎo)書
- 醫(yī)院關(guān)于成立安全生產(chǎn)領(lǐng)導(dǎo)小組的通知
- 【施工方案】空調(diào)百葉施工方案
- 先張法U型梁施工與管理
- 國家開放大學(xué)電大《可編程控制器應(yīng)用》形考任務(wù)(課程實(shí)驗(yàn))答案
- 基坑開挖-降水
- 施工隊(duì)結(jié)算單
- 死因調(diào)查記錄示例
- 中南大學(xué)電氣工程基礎(chǔ)課程設(shè)計
- 畢業(yè)設(shè)計論文千斤頂液壓缸加工專用機(jī)床電氣控制系統(tǒng)設(shè)計
評論
0/150
提交評論