基于Linux的MISC類設(shè)備AD7859L的驅(qū)動程序開發(fā)
1 引言
本文引用地址:http://2s4d.com/article/151386.htm在嵌入式系統(tǒng)中基于ARM微核的嵌入式處理器已經(jīng)成為市場主流。隨著ARM技術(shù)的廣泛應(yīng)用,建立面向ARM構(gòu)架的嵌入式操作系統(tǒng)成為測量行業(yè)的熱點問題。在LINUX操作系統(tǒng)中添加新的外部設(shè)備時,只需為其添加對應(yīng)的驅(qū)動程序即可。介紹另一種驅(qū)動程序的編寫方式,即采用MISC類設(shè)備。其實質(zhì)也是一個字符設(shè)備??蓪⒂脩舾鞣N不同的驅(qū)動設(shè)備類型合成到一種類型中,共用一個主設(shè)備號,通過不同的次設(shè)備號和設(shè)備節(jié)點名來區(qū)分。可方便管理這些驅(qū)動模塊。字符型的驅(qū)動設(shè)備模塊在掛載時都要分配主設(shè)備號、次設(shè)備號和創(chuàng)建設(shè)備節(jié)點名,在卸載驅(qū)動設(shè)備時還必須同時刪掉設(shè)備節(jié)點名。通過采用MISC類設(shè)備,在掛載設(shè)備驅(qū)動時無須再用到mknod命令分配主設(shè)備號、次設(shè)備號和創(chuàng)建設(shè)備節(jié)點名,在insmodl掛載之后,只須mdev—s就能自動裝配/dev目錄下的設(shè)備文件。
2 AD7859L的引腳功能描述和寄存器
AD7859L的引腳功能描述如表1所示。
AD7859L包含一個控制寄存器,A/D轉(zhuǎn)換輸出寄存器,狀態(tài)寄存器,測試寄存器和10位校正寄存器??刂萍拇嫫髦荒軐懭?,A/D轉(zhuǎn)換輸出寄存器和狀態(tài)寄存器只能讀取,測試寄存器和校正寄存器是可讀可寫的。
向AD7859L寫入數(shù)據(jù)時,數(shù)據(jù)寬度必須是16位。16位數(shù)據(jù)寫入AD7859L時,既可作為一個16位字,也可作為2個8位字節(jié),取決于引腳W/B上的邏輯電平。當(dāng)W/B接高電平時,16位數(shù)據(jù)從DB0傳輸?shù)紻Bl5,DB0為最低位,DBl5為最高位。當(dāng)W/B接低電平時,引腳DB8/HBEN作為高字節(jié)使能,2個8位字節(jié)的數(shù)據(jù)從DB0傳輸?shù)紻B7,DB0為最低位,DB7為最高位。當(dāng)以2個8位字節(jié)寫入數(shù)據(jù)時,必須先寫低字節(jié),再寫高字節(jié)。16位數(shù)據(jù)的最高2位ADDRl、ADDR0,通過編碼決定訪問哪一個寄存器,后面的14位數(shù)據(jù)寫入該寄存器。表2為編碼分布。
讀寄存器時必須先設(shè)置控制寄存器的DB6和DB7位,即RDSLTO和RDSLTl。這2位通過編碼決定訪問哪一個寄存器。上電時這2位初始值是00,因此讀取操作訪問的寄存器是A/D轉(zhuǎn)換輸出寄存器。同寫寄存器一樣,字模式或者字節(jié)模式均可以。當(dāng)以字節(jié)模式讀校正寄存器時,必須先讀低字節(jié)。
3 AD7859L驅(qū)動程序
操作系統(tǒng)一般提供設(shè)備驅(qū)動程序完成對特定硬件的控制,以建立應(yīng)用程序和設(shè)備之間的抽象接口,而不是應(yīng)用程序直接操作硬件。設(shè)備驅(qū)動程序?qū)嶋H上是操作硬件的軟件,是內(nèi)核中具有最高特權(quán)級的、駐留內(nèi)存的、可共享的底層硬件處理例程。
采用MISC類設(shè)備來添加AD7859L驅(qū)動。AD7859L的結(jié)構(gòu)體定義語句如下:
評論