I2C控制lP在成像系統中的應用
1 IP的硬件結構及寄存器
本文引用地址:http://dyxdggzs.com/article/151684.htm1.1 IP硬件結構
IP內部結構如圖1所示。主要由波特率時(shí)鐘寄存器、寄存器組控制器、并行I/O接口、I2C可編程接口、I2C接口引擎5個(gè)模塊組成。
波特率時(shí)鐘產(chǎn)生器用來(lái)產(chǎn)生I2C IP工作的基本時(shí)鐘頻率;寄存器組控制器用來(lái)對寄存器進(jìn)行設置,設置數據通過(guò)并行I/O接口傳送到該模塊中;并行I/O接口模塊用來(lái)處理可編程接口模塊傳送過(guò)來(lái)的命令;I2C可編程接口模塊用來(lái)設置IP各個(gè)寄存器的地址;I2C接口引擎模塊執行I2C總線(xiàn)上數據的傳輸。
1.2 寄存器結構
I2C控制IP主要由6個(gè)寄存器構成,如表1所列。通過(guò)對寄存器的讀寫(xiě)可以方便地控制I2C總線(xiàn)數據的傳輸,從而實(shí)現NiosII處理器與設備之間的通信。數據寄存器用來(lái)存放I2C總線(xiàn)上要傳送的數據;波特率產(chǎn)生模塊,波特率時(shí)鐘寄存器和時(shí)鐘寄存器共同決定I2C總線(xiàn)上SCL的頻率。SCL的計算公式為其中System_clk是系統時(shí)鐘;Value是時(shí)鐘寄存器的值;divider是波特率時(shí)鐘寄存器的值所對應的分頻數(寄存器的值與分頻數相差為1,如寄存器設置為0,則分頻數為1;寄存器設置為1,則分頻數值為2)。
本地地址寄存器、控制寄存器、狀態(tài)寄存器的詳細介紹略――編者注。
在成像系統中,CMOS傳感器應用非常普遍。這些傳感器大多數都自帶I2C串行通信接口,本文以MT9M011為例介紹I2C控制IP在成像系統中的應用。MT9M011傳感器根據讀寫(xiě)位數可分為兩種方式:16位數據讀寫(xiě)方式和8位數據讀寫(xiě)方式。這里選用曝光寄存器,采用16位讀寫(xiě)方式進(jìn)行操作,時(shí)序如圖2所示。
從設備地址(寫(xiě)模式)與從設備地址(讀模式)高7位為從器件地址,第8位是讀寫(xiě)控制位(R/W),它控制數據的傳輸方向。
向曝光寄存器0x09寫(xiě)入數據:主器件啟動(dòng)傳輸,然后發(fā)送它所要尋址的從設備地址(寫(xiě)模式)。MT9M011監視總線(xiàn),當其地址與傳送的從器件地址相符時(shí),響應一位應答信號,接著(zhù)主器件發(fā)送曝光寄存器地址,MT9M011再次應答,在向曝光寄存器中寫(xiě)入16位數據后主器件停止寫(xiě)數據。每傳送8位數據,從器件MT9M011都會(huì )產(chǎn)生一位應答信號。
評論