IIC總線作為一種申行傳輸總線,其使用連線少,結(jié)構(gòu)簡(jiǎn)單,是一種應(yīng)用廣泛的高性能總線方式。而Linux作為一個(gè)源代碼公開、易于裁剪的操作系統(tǒng),非常適合于嵌入式系統(tǒng)的應(yīng)用。Linux操作系統(tǒng)下的嵌入式設(shè)備驅(qū)動(dòng),通過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總線通過簡(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總線使用過程中,傳輸開始和停止的條件如下:當(dāng)SCL持續(xù)為“1”而SDA從“1”變?yōu)?ldquo;0”時(shí)表示將要開始發(fā)送數(shù)據(jù);而當(dāng)SCL持續(xù)為“1”而SDA從“0”變?yōu)?ldquo;1”表示停止發(fā)送數(shù)據(jù)。其中SDA線上的數(shù)據(jù)在時(shí)鐘線SCL為“1”期間必須是穩(wěn)定的,只有當(dāng)SCL線上的時(shí)鐘信號(hào)為低時(shí)數(shù)據(jù)線上的狀態(tài)才能改變。
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ú)使用,也可通過2線接口在ARM的控制下完成溫度的測(cè)量及計(jì)算??梢酝ㄟ^寄存器設(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腳相接,通過對(duì)DS1621的A2、A1、A0腳(5、6、7腳)組合輸入不同的片選信號(hào),可以確定其在IIC總線下工作的從機(jī)地址。因?yàn)镮IC從設(shè)備一般都是MOS工藝,所以總線都有上拉電阻。工作時(shí),通過IIC總線將DS1621設(shè)置為溫度傳感器功能和逐次獲取數(shù)據(jù)的工作方式,電路的原理圖設(shè)計(jì)如圖2所示。
3 驅(qū)動(dòng)程序設(shè)計(jì)
在Linux下的驅(qū)動(dòng)程序?qū)⑺性O(shè)備看作文件,驅(qū)動(dòng)程序則為應(yīng)用程序和硬件設(shè)備之間提供了操作訪問的接口,使應(yīng)用程序可以像操作普通文件一樣對(duì)硬件設(shè)備操作訪問。Linux內(nèi)核把驅(qū)動(dòng)程序劃分為3種類型:字符設(shè)備、塊設(shè)備和網(wǎng)絡(luò)設(shè)備。其中,字符設(shè)備和塊設(shè)備可以像文件一樣被訪問。DS1621的IIC驅(qū)動(dòng)屬于字符設(shè)備。
開始工作時(shí),DS1621的工作方式是由片上的設(shè)置/狀態(tài)寄存器來(lái)決定的:1)當(dāng)通過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)超過TH預(yù)置值或低于TL預(yù)置值時(shí)被置為1;4)1SHOT為一次模式位,該位為1時(shí)每次收到溫度轉(zhuǎn)換命令就執(zhí)行一次溫度轉(zhuǎn)換,為0時(shí)將執(zhí)行連續(xù)溫度轉(zhuǎn)換。DS1621寄存器配置如圖3所示。
在調(diào)試過程中發(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通過IIC總線對(duì)DS1621的控制寄存器進(jìn)行配置;S3C2440讀取DS1621寄存器內(nèi)的溫度數(shù)據(jù),通過接口函數(shù),將數(shù)據(jù)從內(nèi)核空間發(fā)送到用戶空間。驅(qū)動(dòng)程序設(shè)計(jì)流程圖如圖4所示。
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,表示傳輸過程中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)通過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所示。
其中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)換的過程中,如果是,則拋棄該數(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)過動(dòng)態(tài)編譯后,得到目標(biāo)文件iic.o、1621.o以及應(yīng)用程序1621_iic_test,將文件下載到S3C2440中,通過#insmodiic.o、#insmod 1621.o加載模塊,#./1621_iic_test運(yùn)行測(cè)試程序,如圖6所示。
5 結(jié)論
本文以ARM920T內(nèi)核的S3C2440為MCU與數(shù)字溫度傳感器模塊DS1621搭建成多點(diǎn)數(shù)字測(cè)溫電路。MCU通過IIC總線與DS1621進(jìn)行通信,通過編寫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,具備較高的精度,且自身工作功耗小。通過增加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è)備通信。