當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]IIC是Philips推出的芯片間串行傳輸總線,它以二根連線實(shí)現(xiàn)完善的全雙工同步數(shù)據(jù)傳送,可以極方便地構(gòu)成多機(jī)系統(tǒng)和外圍器件擴(kuò)展系統(tǒng)。由于其接口簡(jiǎn)單靈活,很多外圍器件均提供了IIC接口,如手機(jī)、平板常用的重力傳感器

IIC是Philips推出的芯片間串行傳輸總線,它以二根連線實(shí)現(xiàn)完善的全雙工同步數(shù)據(jù)傳送,可以極方便地構(gòu)成多機(jī)系統(tǒng)和外圍器件擴(kuò)展系統(tǒng)。由于其接口簡(jiǎn)單靈活,很多外圍器件均提供了IIC接口,如手機(jī)、平板常用的重力傳感器、地磁感應(yīng)、陀螺儀、電容屏接口等均是采用IIC接口的。這些器件采用IIC接口可減少芯片封裝的引腳,使之更小型化,同時(shí)也可以降低布線難度,這對(duì)于手機(jī)、平板這些PCB芯片集成度相當(dāng)高的產(chǎn)品來(lái)說(shuō)是很有必要的。筆者此處就s3c2416的IIC接口應(yīng)用作一個(gè)簡(jiǎn)單的介紹。

1. IIC總線概述

IIC總線物理上包括兩條總線線路,一條串行數(shù)據(jù)線SDA,一條串行時(shí)鐘線SCL。為了使各個(gè)IIC設(shè)備線與相連在總線上,IIC總線接口均采用開集電極或開漏輸出。因此,在IIC總線中是必須接上拉電阻的,上拉電阻的大小通常為1k~10k。上拉電阻小了,則IIC總線功耗增加,上拉電阻大了,負(fù)載能力弱,并且影響總線的允許傳輸速率。

IIC總線可構(gòu)成多主和主從系統(tǒng),在多主系統(tǒng)結(jié)構(gòu)中,系統(tǒng)通過(guò)硬件或軟件仲裁獲得總線控制使用權(quán)。應(yīng)用系統(tǒng)中IIC總線多采用主從結(jié)構(gòu),即總線上只有一個(gè)主控節(jié)點(diǎn),總線上的其他設(shè)備都作為從設(shè)備。由于IIC通信使用7比特地址空間和16個(gè)保留地址,因此理論上同一總線能夠支持的最大通信結(jié)點(diǎn)數(shù)為112個(gè)。但實(shí)際應(yīng)用時(shí),應(yīng)盡可能地減小總線上的通信結(jié)點(diǎn)數(shù),以增強(qiáng)總線的穩(wěn)定性。因?yàn)橥ㄐ沤Y(jié)點(diǎn)的引入,同時(shí)也會(huì)引入寄生電容,而IIC總線結(jié)點(diǎn)數(shù)量受到總線最大電容400pF的限制??偩€的傳輸速率為100Kbit/s(標(biāo)準(zhǔn)模式),400Kbit/s(快速模式),1Mbit/s(快速附加模式),3.4Mbit/s(高速模式)。

其它的總線時(shí)序等請(qǐng)參考相關(guān)的IIC總線標(biāo)準(zhǔn),筆者在此不再詳述。

2. IIC驅(qū)動(dòng)實(shí)現(xiàn)

s3c2416具有一路多主IIC串行接口,可作為主機(jī),也可作為從機(jī)。對(duì)于IIC的操作,s3c2416的spec給出了非常詳細(xì)的編程步驟,見下圖:

圖2-1 主機(jī)發(fā)送操作



圖2-2 主機(jī)接收操作


圖2-3 從機(jī)發(fā)送操作



圖2-4 從機(jī)接收操作

此處主要介紹s3c2416 IIC外設(shè)作為主機(jī)的編程實(shí)現(xiàn)。IIC外設(shè)首先應(yīng)進(jìn)行初始化,包括引腳配置成IIC功能引腳,設(shè)置IIC的時(shí)鐘等。對(duì)于外設(shè)通信,推薦用中斷的方式進(jìn)行收發(fā)數(shù)據(jù),因?yàn)橥庠O(shè)通信相對(duì)于cpu執(zhí)行速度都是極其慢的,用查詢的方法會(huì)讓cpu進(jìn)入空等狀態(tài),在大量數(shù)據(jù)要通過(guò)外設(shè)收發(fā)時(shí),將造成cpu效率及其低下。一方面其它任務(wù)需要cpu執(zhí)行,另一方面cpu在空等外設(shè)收發(fā)數(shù)據(jù)的完成。因此筆者采用的是中斷方式進(jìn)行IIC通信,需要在初始化函數(shù)中注冊(cè)相應(yīng)的IIC中斷處理函數(shù),并開啟中斷。異常處理在啟動(dòng)代碼中的Exception.c統(tǒng)一處理,把IIC中斷處理函數(shù)注冊(cè)進(jìn)中斷向量表中,并編寫IIC中斷處理即可。在有操作系統(tǒng)應(yīng)用中,用中斷的方式讓cpu等待或接收信號(hào)量來(lái)完成IIC的通信,可以讓cpu資源得到充分的利用。

IIC模塊中應(yīng)提供最基本的底層IIC讀和IIC寫這兩個(gè)功能函數(shù)實(shí)現(xiàn),以供上層調(diào)用。IIC_WriteBytes用來(lái)向某一從機(jī)(SlaveAdd)中相應(yīng)內(nèi)部地址(WriteAddr)進(jìn)行寫數(shù)據(jù),待寫數(shù)據(jù)在pData中,寫入長(zhǎng)度為L(zhǎng)ength。函數(shù)原型如下:

intIIC_WriteBytes(unsigned char SlaveAddr, unsignedchar WriteAddr, unsigned char *pData, int Length)

IIC_ReadBytes用來(lái)從某一從機(jī)(SlaveAdd)中相應(yīng)內(nèi)部地址(ReadAddr)進(jìn)行讀數(shù)據(jù),讀取的數(shù)據(jù)存放在pData中,讀取長(zhǎng)度為L(zhǎng)ength。函數(shù)原型如下:

intIIC_ReadBytes(unsigned char SlaveAddr, unsignedchar ReadAddr, unsigned char *pData, intLength)

IIC模塊實(shí)現(xiàn)IIC.c內(nèi)容如下:

#include"s3c2416.h"

#include"IIC.h"

#include"Exception.h"

#define IIC_ReadMode 1 // 連續(xù)讀數(shù)據(jù)模式

#define IIC_WriteMode 2 // 連續(xù)寫數(shù)據(jù)模式

#defineIIC_ReadSlaveMode 3 // 讀從機(jī)地址模式

#defineIIC_WriteSlaveMode 4 // 寫從機(jī)地址模式

// IIC狀態(tài),記錄總線接口出錯(cuò)的信息

static volatile intIIC_Status;

// 跟蹤IIC的狀態(tài)轉(zhuǎn)移,在中斷中需確定IIC的狀態(tài),確定寫或讀

static volatile intIIC_Mode;

// 上層應(yīng)用請(qǐng)求通過(guò)IIC接口發(fā)送或接收的數(shù)據(jù)長(zhǎng)度計(jì)數(shù)

static volatile intIIC_DataCount;

// 數(shù)據(jù)發(fā)送或接收的存放位置

static volatile unsigned char *pIIC_Data;

static void Delay_us(unsigned int nCount)

{

//延時(shí)1us,共延時(shí)nCount(R0) us

__asm__ __volatile__ (

"Delay1:nt"

"LDR R1, =100nt" // Arm clock為400M

"Delay2:nt"

"SUBS R1, R1, #1nt" // 一個(gè)Arm clock

"BNE Delay2nt" // 跳轉(zhuǎn)會(huì)清流水線,3個(gè)Arm clock

"SUBS R0, R0, #1nt" // 調(diào)用者確保nCount不為0

"BNE Delay1nt"

"BX LRnt"

);

}

static void IIC_IRQ()

{

unsigned char Status;

Status = rIICSTAT;

if (Status & (1<<3)) {

// bus arbitration is failed

IIC_Status "= ArbitrationFailed;

}

if (Status & (1<<2)) {

// a slave address is matched withIICADD

IIC_Status |= AddressMatche;

}

if (Status & (1<<1)) {

// a slave address is 0000000b

IIC_Status |= AddressZeros;

}

if (Status & (1<<0)) {

// ACK isn't received

IIC_Status |= NoAck;

}

switch (IIC_Mode) {

case IIC_ReadMode:

IIC_DataCount--;// 讀了一字節(jié),讀計(jì)數(shù)減1

if (IIC_DataCount == 1) {

// 讀最后一個(gè)數(shù)據(jù),主機(jī)不應(yīng)應(yīng)答,不然從機(jī)再發(fā)送數(shù)據(jù),應(yīng)直接停止總線

*pIIC_Data = rIICDS;

pIIC_Data++;

rIICCON &= ~(1 <<7); // 讀最后一字節(jié)禁止主機(jī)應(yīng)答

rIICCON &= ~(1<< 4); // 恢復(fù)操作,讀下一個(gè)數(shù)據(jù)

} else if(IIC_DataCount == 0) {

*pIIC_Data =rIICDS; // 所有數(shù)據(jù)接收完

// 若有操作系統(tǒng),應(yīng)用在數(shù)據(jù)等待發(fā)送完時(shí)通過(guò)信號(hào)量

// 或標(biāo)志等待而掛起OSSemPend(ucos),這樣不會(huì)讓cpu查詢

// 等待,極大提高效率。發(fā)送信號(hào)量或標(biāo)志,喚醒等待的

// 應(yīng)用OSSemPost(ucos)

} else { // 數(shù)據(jù)未接收完

*pIIC_Data = rIICDS;

pIIC_Data++;

rIICCON &= ~(1<< 4);// 恢復(fù)操作,連續(xù)讀下一個(gè)數(shù)據(jù)

}

break;

case IIC_WriteMode:

IIC_DataCount--;// 寫了一字節(jié),寫計(jì)數(shù)減1

if (IIC_DataCount != 0){

pIIC_Data++; // 數(shù)據(jù)未寫完,寫下一數(shù)據(jù)

rIICDS =*pIIC_Data;

rIICCON &= ~(1<< 4); // 恢復(fù)操作,連續(xù)下一個(gè)數(shù)據(jù)

} els

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉