I2C設(shè)備驅(qū)動介紹_第1頁
I2C設(shè)備驅(qū)動介紹_第2頁
I2C設(shè)備驅(qū)動介紹_第3頁
I2C設(shè)備驅(qū)動介紹_第4頁
I2C設(shè)備驅(qū)動介紹_第5頁
已閱讀5頁,還剩21頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

ShanghaiInfoTMMicroelectronicsCo.,Ltd.

I2C設(shè)備驅(qū)動介紹Jiawen.Liang目錄

盈量而知芯,方行天下I2C總線I2C子系統(tǒng)I2C設(shè)備驅(qū)動I2C總線

盈量而知芯,方行天下I2C總線I2C總線I2C總線I2C總線

盈量而知芯,方行天下I2C(Inter-IntegratedCircuit)總線是由PHILIPS公司開發(fā)的兩線式串行總線,用于連接微控制器及其外圍設(shè)備,是微電子通信控制領(lǐng)域廣泛采用的一種總線標(biāo)準(zhǔn)。它是同步通信的一種特殊形式,具有接口線少,控制方式簡單,器件封裝形式小,通信速率較高等優(yōu)點(diǎn)。I2C總線支持任何IC生產(chǎn)過程(NMOSCMOS、雙極性)。兩線――串行數(shù)據(jù)(SDA)和串行時鐘(SCL)線在連接到總線的器件間傳遞信息。每個器件都有一個唯一的地址識別(無論是微控制器——MCU、LCD驅(qū)動器、存儲器或鍵盤接口),而且都可以作為一個發(fā)送器或接收器(由器件的功能決定)。很明顯,LCD驅(qū)動器只是一個接收器,而存儲器則既可以接收又可以發(fā)送數(shù)據(jù)。主機(jī)是初始化總線的數(shù)據(jù)傳輸并產(chǎn)生允許傳輸?shù)臅r鐘信號的器件;MCU一般作為主機(jī),而其他與其連接的外設(shè)都被認(rèn)為是從機(jī)。I2C總線

盈量而知芯,方行天下I2C總線

盈量而知芯,方行天下I2C總線

盈量而知芯,方行天下I2C總線

盈量而知芯,方行天下I2C子系統(tǒng)

盈量而知芯,方行天下I2C子系統(tǒng)I2C子系統(tǒng)

盈量而知芯,方行天下為了方便i2c設(shè)備驅(qū)動的開發(fā),避免因?yàn)镮2C控制器的硬件差異而導(dǎo)致設(shè)備驅(qū)動的差異性,linux對I2C總線進(jìn)行了封裝。為I2C設(shè)備、控制器、及驅(qū)動提供了統(tǒng)一的注冊平臺,同時為數(shù)據(jù)傳輸提供了統(tǒng)一的接口。I2C總線作為一類抽象的總線模型,具體的通信由總線控制器i2c_adapter所提供的總線驅(qū)動算法i2c_algorithm來完成。與用戶空間的交互由設(shè)備驅(qū)動完成,由i2c-dev結(jié)構(gòu)維護(hù)。i2c_driver結(jié)構(gòu)維護(hù)了一類設(shè)備的驅(qū)動方法,i2c_client結(jié)構(gòu)維護(hù)i2c子系統(tǒng)中獨(dú)立的i2c設(shè)備。另外,設(shè)備只完成與I2C-core的數(shù)據(jù)交互,不能與適配器直接通信,真正數(shù)據(jù)的傳輸由i2c-core調(diào)用相應(yīng)的i2c控制器完成。

I2C子系統(tǒng)

盈量而知芯,方行天下Linux的I2C體系結(jié)構(gòu)分為3個組成部分:

?

I2C核心

I2C

核心提供了I2C總線驅(qū)動和設(shè)備驅(qū)動的注冊、注銷方法,I2C通信方法(即“algorithm”)上層的、與具體適配器無關(guān)的代碼以及探測設(shè)備、檢測設(shè)備地址的上層代碼等。

?

I2C總線驅(qū)動

I2C總線驅(qū)動是對I2C硬件體系結(jié)構(gòu)中適配器端的實(shí)現(xiàn),適配器可由CPU控制,甚至直接集成在CPU內(nèi)部。I2C總線驅(qū)動主要包含了I2C適配器數(shù)據(jù)結(jié)構(gòu)i2c_adapter、I2C適配器的algorithm數(shù)據(jù)結(jié)構(gòu)i2c_algorithm和控制I2C適配器產(chǎn)生通信信號的函數(shù)。

經(jīng)由I2C總線驅(qū)動的代碼,我們可以控制I2C適配器以主控方式產(chǎn)生開始位、停止位、讀寫周期,以及以從設(shè)備方式被讀寫、產(chǎn)生ACK等。

?

I2C設(shè)備驅(qū)動

I2C設(shè)備驅(qū)動是對I2C硬件體系結(jié)構(gòu)中設(shè)備端的實(shí)現(xiàn),設(shè)備一般掛接在受CPU控制的I2C適配器上,通過I2C適配器與CPU交換數(shù)據(jù)。

I2C設(shè)備驅(qū)動主要包含了數(shù)據(jù)結(jié)構(gòu)i2c_driver和i2c_client,我們需要根據(jù)具體設(shè)備實(shí)現(xiàn)其中的成員函數(shù)。

I2C子系統(tǒng)

盈量而知芯,方行天下I2C子系統(tǒng)

盈量而知芯,方行天下在Linux內(nèi)核源代碼中的drivers目錄下包含一個i2c目錄,而在i2c目錄下又包含如下文件和文件夾:

?

i2c-core.c:這個文件實(shí)現(xiàn)了I2C核心的功能以及/proc/bus/i2c*接口。

?

i2c-dev.c:實(shí)現(xiàn)了I2C適配器設(shè)備文件的功能,每一個I2C適配器都被分配一個設(shè)備。通過適配器訪問設(shè)備時的主設(shè)備號都為89,次設(shè)備號為0~255。應(yīng)用程序通過

“i2c-%d”(i2c-0,i2c-1,...,i2c-10,...)文件名并使用文件操作接口open()、write()、read()、ioctl()和close()等來訪問這個設(shè)備。i2c-dev.c并沒有針對特定的設(shè)備而設(shè)計,只是提供了通用的read()、write()和ioctl()等接口,應(yīng)用層可以借用這些接口訪問掛接在適配器上的I2C設(shè)備的存儲空間或寄存器并控制I2C設(shè)備的工作方式。

?

chips文件夾

:這個目錄中包含了一些特定的I2C設(shè)備驅(qū)動,如Dallas公司的DS1337實(shí)時鐘芯片、EPSON公司的RTC8564實(shí)時鐘芯片和I2C接口的EEPROM驅(qū)動等。

?

busses文件夾:這個文件中包含了一些I2C總線的驅(qū)動,如S3C2410的I2C控制器驅(qū)動為i2c-s3c2410.c。

?

algos文件夾:實(shí)現(xiàn)了一些I2C總線適配器的algorithm。此外,內(nèi)核中的i2c.h這個頭文件對i2c_driver、i2c_client、i2c_adapter和i2c_algorithm這4個數(shù)據(jù)結(jié)構(gòu)進(jìn)行了定義。理解這4個結(jié)構(gòu)體的作用十分關(guān)鍵,分別給出了它們的定義。I2C子系統(tǒng)

盈量而知芯,方行天下structi2c_adapter{structmodule*owner;unsignedintid;

unsignedintclass;/*classestoallowprobingfor*/

conststructi2c_algorithm*algo;/*thealgorithmtoaccessthebus*/void*algo_data;/*datafieldsthatarevalidforalldevices*/structrt_mutexbus_lock;inttimeout;/*injiffies*/intretries;

structdevicedev;/*theadapterdevice*/intnr;charname[48];structcompletiondev_released;structlist_headuserspace_clients;};I2C子系統(tǒng)

盈量而知芯,方行天下structi2c_algorithm{/*Ifanadapteralgorithmcan'tdoI2C-levelaccess,setmaster_xfertoNULL.IfanadapteralgorithmcandoSMBusaccess,setsmbus_xfer.IfsettoNULL,theSMBusprotocolissimulatedusingcommonI2Cmessages*//*master_xfershouldreturnthenumberofmessagessuccessfullyprocessed,oranegativevalueonerror*/

int(*master_xfer)(structi2c_adapter*adap,structi2c_msg*msgs,intnum);

int(*smbus_xfer)(structi2c_adapter*adap,u16addr,unsignedshortflags,charread_write,u8command,intsize,unioni2c_smbus_data*data);/*Todeterminewhattheadaptersupports*/u32(*functionality)(structi2c_adapter*);};I2C子系統(tǒng)

盈量而知芯,方行天下structi2c_driver{unsignedintclass;int(*attach_adapter)(structi2c_adapter*);int(*detach_adapter)(structi2c_adapter*);/*Standarddrivermodelinterfaces*/

int(*probe)(structi2c_client*,conststructi2c_device_id*);

int(*remove)(structi2c_client*);/*drivermodelinterfacesthatdon'trelatetoenumeration*/void(*shutdown)(structi2c_client*);

int(*suspend)(structi2c_client*,pm_message_tmesg);

int(*resume)(structi2c_client*);void(*alert)(structi2c_client*,unsignedintdata);int(*command)(structi2c_client*client,unsignedintcmd,void*arg);structdevice_driverdriver;conststructi2c_device_id*id_table;/*Devicedetectioncallbackforautomaticdevicecreation*/int(*detect)(structi2c_client*,structi2c_board_info*);constunsignedshort*address_list;structlist_headclients;};I2C子系統(tǒng)

盈量而知芯,方行天下structi2c_client{unsignedshortflags;/*div.,seebelow*/

unsignedshortaddr;/*chipaddress-NOTE:7bit*//*addressesarestoredinthe*//*_LOWER_7bits*/

charname[I2C_NAME_SIZE];

structi2c_adapter*adapter;/*theadapterwesiton*/

structi2c_driver*driver;/*andouraccessroutines*/structdevicedev;/*thedevicestructure*/intirq;/*irqissuedbydevice*/structlist_headdetected;};I2C設(shè)備驅(qū)動

盈量而知芯,方行天下I2C設(shè)備驅(qū)動I2C設(shè)備驅(qū)動

盈量而知芯,方行天下編寫I2C設(shè)備驅(qū)動有兩種方法。一種是利用系統(tǒng)給i2c-dev.c來實(shí)現(xiàn)一個i2c適配器的設(shè)備文件,然后通過在應(yīng)用層操作i2c適配器來控制i2c設(shè)備。

另一種是為i2c設(shè)備,獨(dú)立編寫一個設(shè)備驅(qū)動。在這種情況下,是不需要使用i2c-dev.c的。通常我們?yōu)閕2c設(shè)備在內(nèi)核層編寫驅(qū)動程序。目前內(nèi)核支持兩種編寫i2c驅(qū)動程序的方式,分別稱這兩種方式為“Adapter方式(LEGACY)”和“Probe方式(newstyle)”。兩者流程上基本相似,而前者屬于舊式驅(qū)動開發(fā)方式,就不作討論。這里關(guān)注現(xiàn)在流行使用的Probe方式。I2C設(shè)備驅(qū)動

盈量而知芯,方行天下●

構(gòu)建i2c_driverstaticstructi2c_driverpca953x_driver={.driver={.name="pca953x",},.probe=pca953x_probe,//當(dāng)有i2c_client和i2c_driver匹配時調(diào)用

.remove=pca953x_remove,//注銷時調(diào)用

.id_table=pca953x_id,//匹配規(guī)則

};●注冊i2c_driverstaticint__initpca953x_init(void){returni2c_add_driver(&pca953x_driver);}module_init(pca953x_init);I2C設(shè)備驅(qū)動

盈量而知芯,方行天下在注冊i2c_driver的過程中,是將driver注冊到了i2c_bus_type的總線上。此總線的匹配規(guī)則是:staticconststructi2c_device_id*i2c_match_id(conststructi2c_device_id*id,conststructi2c_client*client){while(id->name[0]){if(strcmp(client->name,id->name)==0)returnid;id++;}returnNULL;}可以看出是利用i2c_client的名稱和id_table中的名稱做匹配的。本驅(qū)動中的id_table為:staticconststructi2c_device_idpca953x_id[]={{"pca9534",0,},{}};I2C設(shè)備驅(qū)動

盈量而知芯,方行天下●

注冊i2c_board_info

對于Probe模式,通常在平臺代碼中要完成i2c_board_info的注冊。方法如下:staticstructi2c_board_info__initdatatest_i2c_devices[]={{I2C_BOARD_INFO("pca9534",0x27),//pca9534為芯片名稱,0x27為芯片地址

.platform_data=&pca9534_data,};i2c_register_board_info(0,test_i2c_devices,ARRAY_SIZE(test_i2c_devices));//注冊●

字符驅(qū)動注冊在Probe方式下,添加字符驅(qū)動的位置在pca953x_probe中。staticint__devinitpca953x_probe(structi2c_client*client,conststructi2c_device_id*id){……

溫馨提示

  • 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論