當(dāng)前位置:首頁 > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]NiosII的I2C控制IP及其在成像系統(tǒng)中的應(yīng)用

摘要:詳細(xì)介紹一種I2C控制IP的工作原理及其可編程寄存器,給出該IP在CMOS數(shù)字成像中的應(yīng)用實(shí)例。該實(shí)例基于可編程片上系統(tǒng)(SOPC)技術(shù)設(shè)計(jì),在NioslI IDE中通過編寫程序來實(shí)現(xiàn)系統(tǒng)功能,并通過QuartusII軟件自帶的SignaITapII進(jìn)行驗(yàn)證。結(jié)果表明,在CMOS成像領(lǐng)域選用該IP核,系統(tǒng)能充分利用SOPC技術(shù)的優(yōu)勢(shì),具有擴(kuò)展性好、控制靈活、開發(fā)周期短等特點(diǎn)。
關(guān)鍵詞:SOPC;I2C控制IP;CMOS

1 IP的硬件結(jié)構(gòu)及寄存器
1.1 IP硬件結(jié)構(gòu)
    IP內(nèi)部結(jié)構(gòu)如圖1所示。主要由波特率時(shí)鐘寄存器、寄存器組控制器、并行I/O接口、I2C可編程接口、I2C接口引擎5個(gè)模塊組成。波特率時(shí)鐘產(chǎn)生器用來產(chǎn)生I2C IP工作的基本時(shí)鐘頻率;寄存器組控制器用來對(duì)寄存器進(jìn)行設(shè)置,設(shè)置數(shù)據(jù)通過并行I/O接口傳送到該模塊中;并行I/0接口模塊用來處理可編程接口模塊傳送過來的命令;I2C可編程接口模塊用來設(shè)置IP各個(gè)寄存器的地址;I2C接口引擎模塊執(zhí)行I2C總線上數(shù)據(jù)的傳輸。


1.2 寄存器結(jié)構(gòu)
    I2C控制IP主要由6個(gè)寄存器構(gòu)成,如表1所列。通過對(duì)寄存器的讀寫可以方便地控制I2C總線數(shù)據(jù)的傳輸,從而實(shí)現(xiàn)NioslI處理器與設(shè)備之間的通信。數(shù)據(jù)寄存器用來存放I2C總線上要傳送的數(shù)據(jù);波特率產(chǎn)生模塊,波特率時(shí)鐘寄存器和時(shí)鐘寄存器共同決定I2C總線上SCL的頻率。SCL的計(jì)算公式為。其中System_clk是系統(tǒng)時(shí)鐘;Value是時(shí)鐘寄存器的值;divider是波特率時(shí)鐘寄存器的值所對(duì)應(yīng)的分頻數(shù)(寄存器的值與分頻數(shù)相差為1,如寄存器設(shè)置為O,則分頻數(shù)為1;寄存器設(shè)置為1,則分頻數(shù)值為2)。本地地址寄存器、控制寄存器、狀態(tài)寄存器的詳細(xì)介紹略——編者注。

[!--empirenews.page--]

2 I2C控制IP在成像系統(tǒng)中的應(yīng)用
    在成像系統(tǒng)中,CMOS傳感器應(yīng)用非常普遍。這些傳感器大多數(shù)都自帶I2C串行通信接口,本文以MT9M011為例介紹I2C控制IP在成像系統(tǒng)中的應(yīng)用。MT9M011傳感器根據(jù)讀寫位數(shù)可分為兩種方式:16位數(shù)據(jù)讀寫方式和8位數(shù)據(jù)讀寫方式。這里選用曝光寄存器,采用16位讀寫方式進(jìn)行操作,時(shí)序如圖2所示。


    從設(shè)備地址(寫模式)與從設(shè)備地址(讀模式)高7位為從器件地址,第8位是讀寫控制位(R/W),它控制數(shù)據(jù)的傳輸方向。
    向曝光寄存器Ox09寫入數(shù)據(jù):主器件啟動(dòng)傳輸,然后發(fā)送它所要尋址的從設(shè)備地址(寫模式)。MT9M011監(jiān)視總線,當(dāng)其地址與傳送的從器件地址相符時(shí),響應(yīng)一位應(yīng)答信號(hào),接著主器件發(fā)送曝光寄存器地址,MT9M011再次應(yīng)答,在向曝光寄存器中寫入16位數(shù)據(jù)后主器件停止寫數(shù)據(jù)。每傳送8位數(shù)據(jù),從器件MT9M011都會(huì)產(chǎn)生一位應(yīng)答信號(hào)。
    從曝光寄存器0x09讀出數(shù)據(jù):開始部分與寫數(shù)據(jù)時(shí)序是相同的,當(dāng)主器件發(fā)送完從設(shè)備地址(寫模式)和寄存器地址后,需要重新啟動(dòng),并發(fā)送從設(shè)備地址(讀模式),然后才能從寄存器中讀出數(shù)據(jù)。每讀完1字節(jié)數(shù)據(jù),主器件都會(huì)產(chǎn)生1位應(yīng)答信號(hào)。當(dāng)16位數(shù)據(jù)被讀出后,主器件發(fā)送1位非應(yīng)答信號(hào),傳輸結(jié)束。

3 IP應(yīng)用實(shí)例
3.1 硬件設(shè)計(jì)
    本文使用I2C控制IP對(duì)圖像傳感器MT9M01l寄存器進(jìn)行并行配置。硬件設(shè)計(jì)基于SOPC技術(shù),將系統(tǒng)組件庫提供的32位Nios II軟核處理器、SDRAM接口模塊、TIMER定時(shí)器模塊(提供SignaltapII中對(duì)信號(hào)進(jìn)行采樣的頻率)、PI0模塊以及I2C控制IP(配置為主設(shè)備)集成在一塊FPGA內(nèi)。QuartusII頂層原理略——編者注。
3.2 軟件設(shè)計(jì)
    軟件的編寫有兩種方式:一種是對(duì)I2C控制IP應(yīng)用程序編程接口(API)函數(shù)的操作;另一種是利用Altera提供的讀寫函數(shù)對(duì)寄存器進(jìn)行操作。為了提高系統(tǒng)運(yùn)行的速度,采用第二種方法。系統(tǒng)軟件部分是在NiosII IDE中,通過編寫C代碼完成的。
    對(duì)CMOS寄存器的并行配置程序主要包括以下兩個(gè)部分:
    ①IP初始化設(shè)置:包括設(shè)置波特率、設(shè)置本地址寄存器、設(shè)置時(shí)鐘寄存器值。
    ②選擇CMOS1,對(duì)其寄存器進(jìn)行讀寫;選擇CMOS2,對(duì)其寄存器進(jìn)行讀寫。寄存器選擇曝光寄存器。
    關(guān)鍵代碼如下:
   
    
    
    函數(shù)checkBus查詢狀態(tài)寄存器的BB來判斷I2C總線忙/閑狀態(tài),checkProgres函數(shù)查詢狀態(tài)寄存器的PIN來判斷總線數(shù)據(jù)是否傳輸完成。為了便于觀察讀出的數(shù)據(jù)和寫入的數(shù)據(jù)是否一致,通常將程序包含在while語句中。[!--empirenews.page--]

4 實(shí)驗(yàn)驗(yàn)證
    將硬件系統(tǒng)生成的下載文件燒寫到FPGA芯片上并運(yùn)行C代碼程序,用QuartusII自帶的SignaItapII邏輯分析儀對(duì)I2C總線上的數(shù)據(jù)進(jìn)行觀察。圖3為所得到的波形,信號(hào)由上至下分別為CMOS2/CMOS1上的I2C總線信號(hào)m_sclk_2、m_sda_2、m_sclk_1、m_sda_1。前半部分給CMOS1寫入0x06、0X07,然后讀出;后半部分對(duì)CMOS2寫入相同的數(shù)并讀出。此波形滿足MT9M011圖像傳感器時(shí)序讀寫要求。

5 系統(tǒng)擴(kuò)展
    在需要多路CMOS配置的應(yīng)用中,使用該I2C控制IP可以很容易地實(shí)現(xiàn)多路并行CMOS寄存器配置。例如,8路并行CMOS配置系統(tǒng):在電路板上焊接8片CMOS傳感器芯片,通過對(duì)分配器3路信號(hào)的控制將使能并行加載到8塊CMOS芯片,3路控制信號(hào)和使能信號(hào)通過對(duì)SOPC系統(tǒng)的PIO接口模塊的控制來實(shí)現(xiàn),配置數(shù)據(jù)的傳輸則在I2C控制IP的控制下完成。電路板結(jié)構(gòu)簡單,系統(tǒng)容易實(shí)現(xiàn)。

結(jié)語
    本文所介紹的I2C IP可作為自定義組件加載到SOPC系統(tǒng)中,使系統(tǒng)的設(shè)計(jì)更為靈活,功能擴(kuò)展上具有較大的潛力。在采用CMOS圖像傳感器的成像系統(tǒng)中,I2C接口應(yīng)用普遍,本文通過給出該IP應(yīng)用實(shí)例,說明了該IP的使用具有廣闊的前景和較高的應(yīng)用價(jià)值。

本站聲明: 本文章由作者或相關(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日 /美通社/ -- 英國汽車技術(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日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(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中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

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

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

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

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

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

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(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年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

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