一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

轉(zhuǎn):Linux I2C 驅(qū)動(dòng)分析

 langhuayipian 2010-09-13
最近在看Linux 2.6.21內(nèi)核的I2C驅(qū)動(dòng),也在網(wǎng)上查了一下資料,有錯(cuò)也有對(duì),有些心得,記錄下來(lái)吧。里面認(rèn)識(shí)或許多有不當(dāng)之處,還懇請(qǐng)指正。
 
1. I2C 協(xié)議
 
 1.1  I2C總線工作原理
      I2C總線是由數(shù)據(jù)線SDA和時(shí)鐘SCL構(gòu)成的串行總線,各種被控制器件均并聯(lián)在這條總線上,每個(gè)器件都有一個(gè)唯一的地址識(shí)別,可以作為總線上的一個(gè)發(fā)送器件或接收器件(具體由器件的功能決定)
1.2  I2C總線的幾種信號(hào)狀態(tài)

      1.  空閑狀態(tài):SDASCL都為高電平。

      2.  開始條件(S)SCL為高電平時(shí),SDA由高電平向低電平跳變,開始傳送數(shù)據(jù)。

      3.  結(jié)束條件(P)SCL為低電平時(shí),SDA由低電平向高電平跳變,結(jié)束傳送數(shù)據(jù)。

      4.  數(shù)據(jù)有效:在SCL的高電平期間, SDA保持穩(wěn)定,數(shù)據(jù)有效。SDA的改變只能發(fā)生在SCL的底電平期間。 

      5.  ACK信號(hào): 數(shù)據(jù)傳輸?shù)倪^(guò)程中,接收器件每接收一個(gè)字節(jié)數(shù)據(jù)要產(chǎn)生一個(gè)ACK信號(hào),向發(fā)送器件發(fā)出特定的低電平脈沖,表示已經(jīng)收到數(shù)據(jù)。

1.3  I2C總線基本操作

      I2C總線必須由主器件(通常為微控制器)控制,主器件產(chǎn)生串行時(shí)鐘(SCL),同時(shí)控制總線的傳輸方向,并產(chǎn)生開始和停止條件。

      數(shù)據(jù)傳輸中,首先主器件產(chǎn)生開始條件,隨后是器件的控制字節(jié)(前七位是從器件的地址,最后一位為讀寫位 )。接下來(lái)是讀寫操作的數(shù)據(jù),以及 ACK響應(yīng)信號(hào)。數(shù)據(jù)傳輸結(jié)束時(shí),主器件產(chǎn)生停止條件

 

2. Linux I2C 結(jié)構(gòu)分析

2.1 層次分析

1. I2C Core

 I2C Core用于維護(hù)Linux的I2C核心部分,其中維護(hù)了兩個(gè)靜態(tài)的List,分別記錄系統(tǒng)中的I2C driver結(jié)構(gòu)和I2C adapter結(jié)構(gòu)。

static LIST_HEAD(adapters);

static LIST_HEAD(drivers);

I2C core提供接口函數(shù),允許一個(gè)I2C adatperI2C driverI2C client初始化時(shí)在I2C core中進(jìn)行注冊(cè),以及退出時(shí)進(jìn)行注銷。具體可以參見i2c_core.c代碼。

同時(shí)還提供了I2C總線讀寫訪問的一般接口(具體的實(shí)現(xiàn)在與I2C控制器相關(guān)的I2C adapter中實(shí)現(xiàn)),主要應(yīng)用在I2C設(shè)備驅(qū)動(dòng)中。

常用的主要是

i2c_master_send()

i2c_master_recv()

i2c_transfer()

 

2. I2C bus driver

總線驅(qū)動(dòng)的職責(zé),是為系統(tǒng)中每個(gè)I2C總線增加相應(yīng)的讀寫方法。但是總線驅(qū)動(dòng)本身并不會(huì)進(jìn)行任何的通訊,它只是存在在那里,等待設(shè)備驅(qū)動(dòng)調(diào)用其函數(shù)。

在系統(tǒng)開機(jī)時(shí),首先裝載的是I2C總線驅(qū)動(dòng)。一個(gè)總線驅(qū)動(dòng)用于支持一條特定的I2C總線的讀寫。一個(gè)總線驅(qū)動(dòng)通常需要兩個(gè)模塊,一個(gè)struct i2c_adapter和一個(gè)struct i2c_algorithm來(lái)描述:

在 buses目錄下的i2c-pxa.c中實(shí)現(xiàn)了PXA的I2C總線適配器,I2C adapter 構(gòu)造一個(gè)對(duì)I2C core層接口的數(shù)據(jù)結(jié)構(gòu),并通過(guò)接口函數(shù)向I2C core注冊(cè)一個(gè)控制器。I2C adapter主要實(shí)現(xiàn)對(duì)I2C總線訪問的算法,iic_xfer() 函數(shù)就是I2C adapter底層對(duì)I2C總線讀寫方法的實(shí)現(xiàn)。同時(shí)I2C adpter 中還實(shí)現(xiàn)了對(duì)I2C控制器中斷的處理函數(shù)。

1) i2c-pxa.c定義了i2c_algorithm,并且實(shí)現(xiàn)了master的發(fā)送函數(shù)i2c_pxa_xfer(),以及設(shè)備查詢總線的模式的函數(shù)i2c_pxa_functionality()

static const struct i2c_algorithm i2c_pxa_algorithm = {
 .master_xfer = i2c_pxa_xfer,
 .functionality = i2c_pxa_functionality,
};

2) i2c-pxa.c中,實(shí)現(xiàn)了i2c_adapter,主要是在定義pxa-i2c時(shí)進(jìn)行初始化,并且i2c_pxa_probe()中進(jìn)行填充parent指針,并且調(diào)用

ret = i2c_add_adapter(&i2c->adap);

進(jìn)行添加。

static struct pxa_i2c i2c_pxa = {
 .lock = SPIN_LOCK_UNLOCKED,
 .adap = {
  .owner  = THIS_MODULE,
  .algo  = &i2c_pxa_algorithm,
  .name  = "pxa2xx-i2c.0",
  .retries = 5,
 },
};

總的來(lái)說(shuō),在i2c-pxa中,使用platform驅(qū)動(dòng)模型,完成了i2c的總線兩種模塊struct i2c_adapterstruct i2c_algorithm

 

3. I2C device driver

I2C只有總線驅(qū)動(dòng)是不夠的,必須有設(shè)備才能工作。這就是I2C device driver的必要性。I2C的device是有兩個(gè)模塊來(lái)描述的,struct i2c_driverstruct i2c_client。

在介紹chips目錄下的device driver前有必要介紹一下i2c-dev.c文件。

      i2c-dev.c中提供了一個(gè)通用的I2C設(shè)備的驅(qū)動(dòng)程序,實(shí)現(xiàn)了字符類 型設(shè)備的訪問接口,對(duì)設(shè)備的具體訪問是通過(guò)I2C adapter來(lái)實(shí)現(xiàn)的。構(gòu)造一個(gè)對(duì)I2C core層接口的數(shù)據(jù)結(jié)構(gòu),通過(guò)接口函數(shù)向 I2C Core注冊(cè)一個(gè)I2C設(shè)備驅(qū)動(dòng)。同時(shí)構(gòu)造一個(gè)對(duì)用戶層接口的數(shù)據(jù)結(jié)構(gòu),并通過(guò)接口函數(shù)向內(nèi)核注冊(cè)為一個(gè)主設(shè)備號(hào)為89的字符類型設(shè)備。

static struct i2c_driver i2cdev_driver = {
 .driver = {
  .name = "dev_driver",
 },
 .id  = I2C_DRIVERID_I2CDEV,
 .attach_adapter = i2cdev_attach_adapter,
 .detach_adapter = i2cdev_detach_adapter,
 .detach_client = i2cdev_detach_client,
};

struct i2c_dev {
 struct list_head list;
 struct i2c_adapter *adap;
 struct device *dev;
};

該 文件提供了用戶層對(duì)I2C設(shè)備的訪問,包括open,read,write,ioctl,release等常規(guī)文件操作,我們可以通過(guò)open函數(shù)打開 I2C的設(shè)備文件,通過(guò)ioctl函數(shù)設(shè)定要訪問從設(shè)備的地址,然后就可以通過(guò) read和write函數(shù)完成對(duì)I2C設(shè)備的讀寫操作。

static const struct file_operations i2cdev_fops = {
 .owner  = THIS_MODULE,
 .llseek  = no_llseek,
 .read  = i2cdev_read,
 .write  = i2cdev_write,
 .ioctl  = i2cdev_ioctl,
 .open  = i2cdev_open,
 .release = i2cdev_release,
};

      注:通過(guò)I2C driver提供的通用方法可以訪問任何一個(gè)I2C的設(shè)備,但是其中實(shí)現(xiàn)的read,write及ioctl等功能完全是基于一般設(shè)備的實(shí)現(xiàn),所有的操作 數(shù)據(jù)都是基于字節(jié)流,沒有明確的格式和意義。為了更方便和有效地使用I2C設(shè)備,我們可以為一個(gè)具體的I2C設(shè)備開發(fā)特定的I2C設(shè)備驅(qū)動(dòng)程序,在驅(qū)動(dòng)中 完成對(duì)特定的數(shù)據(jù)格式的解釋以及實(shí)現(xiàn)一些專用的功能。

在chips目錄下包含著各種device 的driver,完成各種從設(shè)備的注冊(cè)。作為一般的I2C設(shè)備,使用i2c-dev.c里的操作足夠完成操作了。

當(dāng)然如果不能完成,則需要獨(dú)立完成該驅(qū)動(dòng),這就是chips目錄下的代碼。 因?yàn)閕2c-dev.c已經(jīng)實(shí)現(xiàn)了I2C設(shè)備的文件操作接口,所以只要實(shí)現(xiàn)struct i2c_driver就可以了。對(duì)于某些特殊的操作,可以使用command接口進(jìn)行控制。 當(dāng)然,對(duì)于i2接口的fm芯片,則將struct i2c_driver放在i2c的chips目錄下,而將另外fm操作相關(guān)的代碼放在了/media/radio目錄下了。在這個(gè)目錄下需要完成讀寫接口 的完成,這個(gè)大部分使用V4L2架構(gòu)。

繼續(xù)分析中……

posted on 2008-08-23 11:01 lfc 閱讀(2813) 評(píng)論(2)  編輯 收藏 引用

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多

    欧美韩国日本精品在线| 熟女乱一区二区三区四区| 欧美一级内射一色桃子| 99久久国产精品免费| 国产精品欧美一级免费| 国产国产精品精品在线| 国产精品大秀视频日韩精品| 亚洲黑人精品一区二区欧美| 国产精品人妻熟女毛片av久| 不卡中文字幕在线免费看| 国产亚洲欧美一区二区| 中文字幕乱码免费人妻av| 成人精品日韩专区在线观看| 国产亚洲欧美一区二区| 香蕉网尹人综合在线观看 | 成人免费视频免费观看| 国产又粗又硬又大又爽的视频| 欧美日韩校园春色激情偷拍| 蜜桃传媒视频麻豆第一区| 免费观看在线午夜视频| 中国一区二区三区人妻| 欧美日韩国产午夜福利| 欧美欧美欧美欧美一区| 麻豆印象传媒在线观看| 国产盗摄精品一区二区视频| 老司机这里只有精品视频| 国产欧美日韩视频91| 日韩欧美国产精品自拍| 欧美黄色黑人一区二区| 亚洲欧美日韩国产成人| 国产精品国产亚洲看不卡| 日韩夫妻午夜性生活视频| 中文字幕91在线观看| 日韩美成人免费在线视频| 国产超碰在线观看免费| 开心五月激情综合婷婷色| 欧美日韩国产精品自在自线| 国产一区麻豆水好多高潮| 精品日韩国产高清毛片| 日韩精品一区二区三区含羞含羞草| 欧美一区二区三区性视频 |