IIC總線作為一種申行傳輸總線,其使用連線少,結構簡單,是一種應用廣泛的高性能總線方式。而Linux作為一個源代碼公開、易于裁剪的操作系統,非常適合于嵌入式系統的應用。Linux操作系統下的嵌入式設備驅動,通過IIC總線,實現ARM與外圍模塊間的協同工作,有著廣泛的應用。
1 IIC總線協議以及選用芯片功能
1.1 IIC總線的特點以及工作協議
IIC串行總線由兩根信號線組成:一根雙向傳輸的數據線SDA;另一根是時鐘線SCL。IIC總線通過簡單的結構即能實現半雙工的同步數據傳輸。
IIC總線采用一主多從的運行機制,在同一時間只能有一臺設備作為主設備,總線的運行由主設備控制,主設備控制數據的傳送起始信號、發出時鐘信號、從機地址信號、數據信號,由接收數據方在傳送結束時發出應答信號,每個IIC總線上的設備都有一個唯一的地址,和主設備進行通信。
IIC總線時序如圖1所示,在IIC總線使用過程中,傳輸開始和停止的條件如下:當SCL持續為“1”而SDA從“1”變為“0”時表示將要開始發送數據;而當SCL持續為“1”而SDA從“0”變為“1”表示停止發送數據。其中SDA線上的數據在時鐘線SCL為“1”期間必須是穩定的,只有當SCL線上的時鐘信號為低時數據線上的狀態才能改變。
圖1 IIC總線時序圖
SDA線上的每個字節必須為8位,每次傳輸的字節數不限制,每發送1個字節都有1個ACK應答位。
1.2 選用ARM9芯片功能介紹
MCU采用某公司的S3C2440芯片,S3C2440A是某公司的一款基于ARM920T內核的16/32位RISC嵌入式微處理器,主要面向手持設備以及高性價比、低功耗的應用,且集成了1個IIC總線控制器,能夠方便的與帶有IIC接口外設的通信。
1.3 數字溫度傳感器DS1621的芯片功能介紹
DS1621是DALLAS公司生產的一種功能強大的數字式溫度傳感器和恒溫控制器。接口與IIC總線兼容,一片控制器控制可控制多達8片的DS1621,工作電壓為2.7~5.5 V,適用于低功耗應用系統。
DS1621可作為恒溫控制器單獨使用,也可通過2線接口在ARM的控制下完成溫度的測量及計算。可以通過寄存器設置調整。DS1621無需外圍元件即可測量溫度,結果以9位數字量(兩字節)給出,測量范圍為-55~+155℃,精度為0.5℃:典型轉換時間為1 s。
2 電路結構設計
設計采用了S3C2440作為電路中的主設備,控制IIC總線上從器件,由主設備控制IIC總線上的時鐘信號以及各種數據信號。采用2片DS16 21作為IIC總線上的從設備,由于DS1621具備IIC總線接口,可直接與S3C2440的SDA和SCL腳相接,通過對DS1621的A2、A1、A0腳(5、6、7腳)組合輸入不同的片選信號,可以確定其在IIC總線下工作的從機地址。因為IIC從設備一般都是MOS工藝,所以總線都有上拉電阻。工作時,通過IIC總線將DS1621設置為溫度傳感器功能和逐次獲取數據的工作方式,電路的原理圖設計如圖2所示。
圖2 電路的原理圖
3 驅動程序設計
在Linux下的驅動程序將所有設備看作文件,驅動程序則為應用程序和硬件設備之間提供了操作訪問的接口,使應用程序可以像操作普通文件一樣對硬件設備操作訪問。Linux內核把驅動程序劃分為3種類型:字符設備、塊設備和網絡設備。其中,字符設備和塊設備可以像文件一樣被訪問。DS1621的IIC驅動屬于字符設備。
開始工作時,DS1621的工作方式是由片上的設置/狀態寄存器來決定的:1)當通過IIC總線向DS1621寫入讀寫設置命令ACh之后ARM發出的一字節將設置DS1621的工作方式,然后發出溫度轉換命令EEh,讀溫度命令AAh;2)DONE比特位表示工作在測溫功能時,溫度數據已轉換完畢,保存在非易失性寄存器中;3)THF、TLF是DS1621作為恒溫器時的狀態標識位,當超過TH預置值或低于TL預置值時被置為1;4)1SHOT為一次模式位,該位為1時每次收到溫度轉換命令就執行一次溫度轉換,為0時將執行連續溫度轉換。DS1621寄存器配置如圖3所示。
圖3 DS1621寄存器配置
在調試過程中發現,若使用連續轉換模式時,在極少數情況下出現數據明顯不正確,故采用了逐次讀取數據模式,即逐次配置DS1621的溫度轉換,逐次獲取數據,并每次判斷DS1621工作狀態、數據范圍和精度,從而獲得了更加穩定、精確的實驗結果。
驅動程序的功能包括:初始化以及釋放硬件設備;S3C2440通過IIC總線對DS1621的控制寄存器進行配置;S3C2440讀取DS1621寄存器內的溫度數據,通過接口函數,將數據從內核空間發送到用戶空間。驅動程序設計流程圖如圖4所示。
圖4 驅動程序設計流程圖
3.1 設備驅動的主要函數
對于字符設備,Linux內核對這些操作進行了統一的抽象,把它們定義在結構體file-operation中。通常,字符設備提供給應用程序的是一個流控制接口,主要包括open、release、read、ioctl等。
3.2 從器件,設備DS1621的初始化代碼
3.3 IIC總線的初始化
對S3C2440的IIC控制器進行配置時需要用到的寄存器有:IICCON、IICSTAT、IICDS、IICADD。
IICCON:IIC總線控制寄存器;IICSTAT:IIC總線控制狀態寄存器;HCDS:IIC總線接收/發送數據移位寄存器;IICADD:IIC總線地址寄存器。
1)S3C2440的GPE15為HCSDA,是串行數據線端口,GPE14為IICSCL,是串行時鐘線;
2)將IICCON設置為:0xA7,表示傳輸過程中ACK應答使能,IIC的工作時鐘為:HCCLK=fpclk/512,IlC總線中斷使能,數據傳輸的時鐘為:Tx clock=IICCLK/(IICCON[3:O]+1),約為400 k/s;
3)將IICSTAT置為:0x10,即使用從器件接收數據模式,數據輸出/接收使能。
3.4 主器件從HC總線讀數據
對于DS1621的寄存器配置,當通過IIC讀取從器件DS1621的數據時,需要切換數據收發的方向,S3C2440先在主機發送數據模式下,向從器件DS1621發送從地址、DS1621內部寄存器的子地址和寫信號位,然后在主機接收數據模式下,再次向從器件發送從地址和讀信號位,并將子地址內的數據讀回,其讀數據操作如圖5所示。
圖5 IIC總線讀數據操作
其中S為發送開始標志START,W為寫信號位,R為讀信號位,A為ACK應答信號,RS為重復開始信號REPEATED START,NA為主機收回數據后發送的NACK信號,P為停止信號STOP。
3.5 主器件向IIC總線寫數據
3.6 S3C2440從DS1621獲得溫度數據,保存在內核空間并傳送到用戶空間
4 驅動的加載以及測試
應用程序將驅動從內核空間獲得的數據保存下來,首先根據傳回的DONE比特位判斷溫度傳感器是否正在數據轉換的過程中,如果是,則拋棄該數據,并打印數據不可用的信息;如果否,則接下來根據精度位判斷小數點后的數據值,并將結果打印出來。
最后將驅動程序編譯成模塊,可以動態地加載、卸載設備驅動,不用重新啟動系統就能查看驅動程序結果,方便了驅動的編寫與調試工作。
經過動態編譯后,得到目標文件iic.o、1621.o以及應用程序1621_iic_test,將文件下載到S3C2440中,通過#insmodiic.o、#insmod 1621.o加載模塊,#./1621_iic_test運行測試程序,如圖6所示。
圖6 運行測試程序并打印信息
5 結論
本文以ARM920T內核的S3C2440為MCU與數字溫度傳感器模塊DS1621搭建成多點數字測溫電路。MCU通過IIC總線與DS1621進行通信,通過編寫linux2.4版本下的IIC驅動程序,完成了S3C2440與帶有IIC接口的外圍芯片的通信,并實現了DS1621的配置和測溫工作,正常工作中DS1621的典型溫度轉化時間為1 s,數據精度為0.5℃,典型的工作電壓和電流值僅為3 V、10μA,具備較高的精度,且自身工作功耗小。通過增加DS1621的使用片數,還可擴展為一個低電壓、低功耗的多點數字測溫系統,可以廣泛地應用在各種嵌入式系統中。驅動程序可使用于其他具有IlC接口的外圍芯片的工作,也可將驅動應用于其他具有IIC接口的外圍設備通信。