DS1621在Linux下的IIC接口驅(qū)動(dòng)設(shè)計(jì)
出處:左撇子 發(fā)布于:2011-03-23 10:13:07
摘要: 針對(duì)目前IIC總線以及具有IIC接口的芯片在嵌入式系統(tǒng)中的廣泛應(yīng)用,設(shè)計(jì)了一種基于ARM9平臺(tái)S3C2440的, Linux操作系統(tǒng)下的IIC接口設(shè)備驅(qū)動(dòng)程序。通過(guò)IIC總線協(xié)議,驅(qū)動(dòng)程序?qū)崿F(xiàn)了在內(nèi)核狀態(tài)下對(duì)數(shù)字溫度傳感器DS1621的配置和獲取其溫度信息,并將其傳回用戶空間并打印顯示。實(shí)驗(yàn)結(jié)果表明,工作時(shí)典型數(shù)據(jù)更新時(shí)間為1 s,為小數(shù)點(diǎn)后一位。且利用多片DS1621可擴(kuò)展一個(gè)低電壓、低功耗的多點(diǎn)數(shù)字測(cè)溫系統(tǒng),在嵌入式設(shè)備的溫度監(jiān)測(cè)方面將有著廣泛應(yīng)用。
IIC總線作為一種申行傳輸總線,其使用連線少,結(jié)構(gòu)簡(jiǎn)單,是一種應(yīng)用廣泛的高性能總線方式。而Linux作為一個(gè)源代碼公開、易于裁剪的操作系統(tǒng),非常適合于嵌入式系統(tǒng)的應(yīng)用。Linux操作系統(tǒng)下的嵌入式設(shè)備驅(qū)動(dòng),通過(guò)IIC總線,實(shí)現(xiàn)ARM與外圍模塊間的協(xié)同工作,有著廣泛的應(yīng)用。
1 IIC總線協(xié)議以及選用芯片功能
1.1 IIC總線的特點(diǎn)以及工作協(xié)議
IIC串行總線由兩根信號(hào)線組成:一根雙向傳輸?shù)臄?shù)據(jù)線SDA;另一根是時(shí)鐘線SCL。IIC總線通過(guò)簡(jiǎn)單的結(jié)構(gòu)即能實(shí)現(xiàn)半雙工的同步數(shù)據(jù)傳輸。
IIC總線采用一主多從的運(yùn)行機(jī)制,在同一時(shí)間只能有一臺(tái)設(shè)備作為主設(shè)備,總線的運(yùn)行由主設(shè)備控制,主設(shè)備控制數(shù)據(jù)的傳送起始信號(hào)、發(fā)出時(shí)鐘信號(hào)、從機(jī)地址信號(hào)、數(shù)據(jù)信號(hào),由接收數(shù)據(jù)方在傳送結(jié)束時(shí)發(fā)出應(yīng)答信號(hào),每個(gè)IIC總線上的設(shè)備都有一個(gè)的地址,和主設(shè)備進(jìn)行通信。
IIC總線時(shí)序如圖1所示,在IIC總線使用過(guò)程中,傳輸開始和停止的條件如下:當(dāng)SCL持續(xù)為“1”而SDA從“1”變?yōu)椤?”時(shí)表示將要開始發(fā)送數(shù)據(jù);而當(dāng)SCL持續(xù)為“1”而SDA從“0”變?yōu)椤?”表示停止發(fā)送數(shù)據(jù)。其中SDA線上的數(shù)據(jù)在時(shí)鐘線SCL為“1”期間必須是穩(wěn)定的,只有當(dāng)SCL線上的時(shí)鐘信號(hào)為低時(shí)數(shù)據(jù)線上的狀態(tài)才能改變。

圖1 IIC總線時(shí)序圖
SDA線上的每個(gè)字節(jié)必須為8位,每次傳輸?shù)淖止?jié)數(shù)不限制,每發(fā)送1個(gè)字節(jié)都有1個(gè)ACK應(yīng)答位。
1.2 選用ARM9芯片功能介紹
MCU采用某公司的S3C2440芯片,S3C2440A是某公司的一款基于ARM920T內(nèi)核的16/32位RISC嵌入式微處理器,主要面向手持設(shè)備以及高性價(jià)比、低功耗的應(yīng)用,且集成了1個(gè)IIC總線控制器,能夠方便的與帶有IIC接口外設(shè)的通信。
1.3 數(shù)字溫度傳感器DS1621的芯片功能介紹
DS1621是DALLAS公司生產(chǎn)的一種功能強(qiáng)大的數(shù)字式溫度傳感器和恒溫控制器。接口與IIC總線兼容,一片控制器控制可控制多達(dá)8片的DS1621,工作電壓為2.7~5.5 V,適用于低功耗應(yīng)用系統(tǒng)。
DS1621可作為恒溫控制器單獨(dú)使用,也可通過(guò)2線接口在ARM的控制下完成溫度的測(cè)量及計(jì)算。可以通過(guò)寄存器設(shè)置調(diào)整。DS1621無(wú)需外圍元件即可測(cè)量溫度,結(jié)果以9位數(shù)字量(兩字節(jié))給出,測(cè)量范圍為-55~+155℃,為0.5℃:典型轉(zhuǎn)換時(shí)間為1 s。
2 電路結(jié)構(gòu)設(shè)計(jì)
設(shè)計(jì)采用了S3C2440作為電路中的主設(shè)備,控制IIC總線上從器件,由主設(shè)備控制IIC總線上的時(shí)鐘信號(hào)以及各種數(shù)據(jù)信號(hào)。采用2片DS16 21作為IIC總線上的從設(shè)備,由于DS1621具備IIC總線接口,可直接與S3C2440的SDA和SCL腳相接,通過(guò)對(duì)DS1621的A2、A1、A0腳(5、6、7腳)組合輸入不同的片選信號(hào),可以確定其在IIC總線下工作的從機(jī)地址。因?yàn)镮IC從設(shè)備一般都是MOS工藝,所以總線都有上拉電阻。工作時(shí),通過(guò)IIC總線將DS1621設(shè)置為溫度傳感器功能和逐次獲取數(shù)據(jù)的工作方式,電路的原理圖設(shè)計(jì)如圖2所示。

圖2 電路的原理圖
3 驅(qū)動(dòng)程序設(shè)計(jì)
在Linux下的驅(qū)動(dòng)程序?qū)⑺性O(shè)備看作文件,驅(qū)動(dòng)程序則為應(yīng)用程序和硬件設(shè)備之間提供了操作訪問(wèn)的接口,使應(yīng)用程序可以像操作普通文件一樣對(duì)硬件設(shè)備操作訪問(wèn)。Linux內(nèi)核把驅(qū)動(dòng)程序劃分為3種類型:字符設(shè)備、塊設(shè)備和網(wǎng)絡(luò)設(shè)備。其中,字符設(shè)備和塊設(shè)備可以像文件一樣被訪問(wèn)。DS1621的IIC驅(qū)動(dòng)屬于字符設(shè)備。
開始工作時(shí),DS1621的工作方式是由片上的設(shè)置/狀態(tài)寄存器來(lái)決定的:1)當(dāng)通過(guò)IIC總線向DS1621寫入讀寫設(shè)置命令A(yù)Ch之后ARM發(fā)出的一字節(jié)將設(shè)置DS1621的工作方式,然后發(fā)出溫度轉(zhuǎn)換命令EEh,讀溫度命令A(yù)Ah;2)DONE比特位表示工作在測(cè)溫功能時(shí),溫度數(shù)據(jù)已轉(zhuǎn)換完畢,保存在非易失性寄存器中;3)THF、TLF是DS1621作為恒溫器時(shí)的狀態(tài)標(biāo)識(shí)位,當(dāng)超過(guò)TH預(yù)置值或低于TL預(yù)置值時(shí)被置為1;4)1SHOT為模式位,該位為1時(shí)每次收到溫度轉(zhuǎn)換命令就執(zhí)行溫度轉(zhuǎn)換,為0時(shí)將執(zhí)行連續(xù)溫度轉(zhuǎn)換。DS1621寄存器配置如圖3所示。

圖3 DS1621寄存器配置
在調(diào)試過(guò)程中發(fā)現(xiàn),若使用連續(xù)轉(zhuǎn)換模式時(shí),在極少數(shù)情況下出現(xiàn)數(shù)據(jù)明顯不正確,故采用了逐次讀取數(shù)據(jù)模式,即逐次配置DS1621的溫度轉(zhuǎn)換,逐次獲取數(shù)據(jù),并每次判斷DS1621工作狀態(tài)、數(shù)據(jù)范圍和,從而獲得了更加穩(wěn)定、的實(shí)驗(yàn)結(jié)果。
驅(qū)動(dòng)程序的功能包括:初始化以及釋放硬件設(shè)備;S3C2440通過(guò)IIC總線對(duì)DS1621的控制寄存器進(jìn)行配置;S3C2440讀取DS1621寄存器內(nèi)的溫度數(shù)據(jù),通過(guò)接口函數(shù),將數(shù)據(jù)從內(nèi)核空間發(fā)送到用戶空間。驅(qū)動(dòng)程序設(shè)計(jì)流程圖如圖4所示。

圖4 驅(qū)動(dòng)程序設(shè)計(jì)流程圖
3.1 設(shè)備驅(qū)動(dòng)的主要函數(shù)
對(duì)于字符設(shè)備,Linux內(nèi)核對(duì)這些操作進(jìn)行了統(tǒng)一的抽象,把它們定義在結(jié)構(gòu)體file-operation中。通常,字符設(shè)備提供給應(yīng)用程序的是一個(gè)流控制接口,主要包括open、release、read、ioctl等。

3.2 從器件,設(shè)備DS1621的初始化代碼

3.3 IIC總線的初始化
對(duì)S3C2440的IIC控制器進(jìn)行配置時(shí)需要用到的寄存器有:IICCON、IICSTAT、IICDS、IICADD。
IICCON:IIC總線控制寄存器;IICSTAT:IIC總線控制狀態(tài)寄存器;HCDS:IIC總線接收/發(fā)送數(shù)據(jù)移位寄存器;IICADD:IIC總線地址寄存器。
1)S3C2440的GPE15為HCSDA,是串行數(shù)據(jù)線端口,GPE14為IICSCL,是串行時(shí)鐘線;
2)將IICCON設(shè)置為:0xA7,表示傳輸過(guò)程中ACK應(yīng)答使能,IIC的工作時(shí)鐘為:HCCLK=fpclk/512,IlC總線中斷使能,數(shù)據(jù)傳輸?shù)臅r(shí)鐘為:Tx clock=IICCLK/(IICCON[3:O]+1),約為400 k/s;
3)將IICSTAT置為:0x10,即使用從器件接收數(shù)據(jù)模式,數(shù)據(jù)輸出/接收使能。

3.4 主器件從HC總線讀數(shù)據(jù)
對(duì)于DS1621的寄存器配置,當(dāng)通過(guò)IIC讀取從器件DS1621的數(shù)據(jù)時(shí),需要切換數(shù)據(jù)收發(fā)的方向,S3C2440先在主機(jī)發(fā)送數(shù)據(jù)模式下,向從器件DS1621發(fā)送從地址、DS1621內(nèi)部寄存器的子地址和寫信號(hào)位,然后在主機(jī)接收數(shù)據(jù)模式下,再次向從器件發(fā)送從地址和讀信號(hào)位,并將子地址內(nèi)的數(shù)據(jù)讀回,其讀數(shù)據(jù)操作如圖5所示。

圖5 IIC總線讀數(shù)據(jù)操作
其中S為發(fā)送開始標(biāo)志START,W為寫信號(hào)位,R為讀信號(hào)位,A為ACK應(yīng)答信號(hào),RS為重復(fù)開始信號(hào)REPEATED START,NA為主機(jī)收回?cái)?shù)據(jù)后發(fā)送的NACK信號(hào),P為停止信號(hào)STOP。

3.5 主器件向IIC總線寫數(shù)據(jù)

3.6 S3C2440從DS1621獲得溫度數(shù)據(jù),保存在內(nèi)核空間并傳送到用戶空間

4 驅(qū)動(dòng)的加載以及測(cè)試
應(yīng)用程序?qū)Ⅱ?qū)動(dòng)從內(nèi)核空間獲得的數(shù)據(jù)保存下來(lái),首先根據(jù)傳回的DONE比特位判斷溫度傳感器是否正在數(shù)據(jù)轉(zhuǎn)換的過(guò)程中,如果是,則拋棄該數(shù)據(jù),并打印數(shù)據(jù)不可用的信息;如果否,則接下來(lái)根據(jù)位判斷小數(shù)點(diǎn)后的數(shù)據(jù)值,并將結(jié)果打印出來(lái)。

將驅(qū)動(dòng)程序編譯成模塊,可以動(dòng)態(tài)地加載、卸載設(shè)備驅(qū)動(dòng),不用重新啟動(dòng)系統(tǒng)就能查看驅(qū)動(dòng)程序結(jié)果,方便了驅(qū)動(dòng)的編寫與調(diào)試工作。
經(jīng)過(guò)動(dòng)態(tài)編譯后,得到目標(biāo)文件iic.o、1621.o以及應(yīng)用程序1621_iic_test,將文件到S3C2440中,通過(guò)#insmodiic.o、#insmod 1621.o加載模塊,#./1621_iic_test運(yùn)行測(cè)試程序,如圖6所示。

圖6 運(yùn)行測(cè)試程序并打印信息
5 結(jié)論
本文以ARM920T內(nèi)核的S3C2440為MCU與數(shù)字溫度傳感器模塊DS1621搭建成多點(diǎn)數(shù)字測(cè)溫電路。MCU通過(guò)IIC總線與DS1621進(jìn)行通信,通過(guò)編寫linux2.4版本下的IIC驅(qū)動(dòng)程序,完成了S3C2440與帶有IIC接口的外圍芯片的通信,并實(shí)現(xiàn)了DS1621的配置和測(cè)溫工作,正常工作中DS1621的典型溫度轉(zhuǎn)化時(shí)間為1 s,數(shù)據(jù)為0.5℃,典型的工作電壓和電流值僅為3 V、10μA,具備較高的,且自身工作功耗小。通過(guò)增加DS1621的使用片數(shù),還可擴(kuò)展為一個(gè)低電壓、低功耗的多點(diǎn)數(shù)字測(cè)溫系統(tǒng),可以廣泛地應(yīng)用在各種嵌入式系統(tǒng)中。驅(qū)動(dòng)程序可使用于其他具有IlC接口的外圍芯片的工作,也可將驅(qū)動(dòng)應(yīng)用于其他具有IIC接口的外圍設(shè)備通信。
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫(kù)電子市場(chǎng)網(wǎng)”的所有作品,版權(quán)均屬于維庫(kù)電子市場(chǎng)網(wǎng),轉(zhuǎn)載請(qǐng)必須注明維庫(kù)電子市場(chǎng)網(wǎng),http://www.hbjingang.com,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點(diǎn)或證實(shí)其內(nèi)容的真實(shí)性,不承擔(dān)此類作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個(gè)人從本網(wǎng)轉(zhuǎn)載時(shí),必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問(wèn)題,請(qǐng)?jiān)谧髌钒l(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- ARM技術(shù)架構(gòu)與應(yīng)用開發(fā)實(shí)踐指南2026/1/6 10:40:19
- 嵌入式實(shí)時(shí)操作系統(tǒng)(RTOS)選型與移植技術(shù)指南2025/12/31 10:42:31
- 工業(yè)嵌入式系統(tǒng):通信接口技術(shù)選型與抗干擾設(shè)計(jì)實(shí)踐2025/12/15 14:36:53
- 深入解析嵌入式 OPENAMP 框架:開啟異核通信新時(shí)代2025/7/22 16:27:29
- 一文快速了解OPENWRT基礎(chǔ)知識(shí)2025/7/14 16:59:04
- PCB焊盤與過(guò)孔設(shè)計(jì)核心實(shí)操規(guī)范(含可焊性與可靠性保障)
- 汽車電子常用電子元器件選型指南
- MOSFET驅(qū)動(dòng)與隔離方案設(shè)計(jì)
- 高溫環(huán)境下電源IC選型建議
- 安防監(jiān)控設(shè)備連接器應(yīng)用分析
- 高速PCB信號(hào)完整性(SI)設(shè)計(jì)核心實(shí)操規(guī)范
- 鎖相環(huán)(PLL)中的環(huán)路濾波器:參數(shù)計(jì)算與穩(wěn)定性分析
- MOSFET反向恢復(fù)特性對(duì)系統(tǒng)的影響
- 電源IC在惡劣環(huán)境中的防護(hù)設(shè)計(jì)
- 連接器耐腐蝕性能測(cè)試方法









