S3C2440-IIC
s3c2440內(nèi)部有一個IIC總線接口,因此為我們連接帶有IIC通信模塊的外圍設備提供了便利。它具有四種操作模式:主設備發(fā)送模式、主設備接收模式、從設備發(fā)送模式和從設備接收模式。在這里我們只把s3c2440當做IIC總線的主設備來使用,因此只介紹前兩種操作模式。在主設備發(fā)送模式下,它的工作流程為:首先配置IIC模式,然后把從設備地址寫入接收發(fā)送數(shù)據(jù)移位寄存器IICDS中,再把0xF0寫入控制狀態(tài)寄存器IICSTAT中,這時等待從設備發(fā)送應答信號,如果想要繼續(xù)發(fā)送數(shù)據(jù),那么在接收到應答信號后,再把待發(fā)送的數(shù)據(jù)寫入寄存器IICDS中,清除中斷標志后,再次等待應答信號;如果不想再發(fā)送數(shù)據(jù)了,那么把0x90寫入寄存器IICSTAT中,清除中斷標志并等待停止條件后,即完成了一次主設備的發(fā)送。在主設備接收模式下,它的工作流程為:首先配置IIC模式,然后把從設備地址寫入接收發(fā)送數(shù)據(jù)移位寄存器IICDS中,再把0xB0寫入控制狀態(tài)寄存器IICSTAT中,這時等待從設備發(fā)送應答信號,如果想要接收數(shù)據(jù),那么在應答信號后,讀取寄存器IICDS,清除中斷標志;如果不想接收數(shù)據(jù)了,那么就向寄存器IICSTAT寫入0x90,清除中斷標志并等待停止條件后,即完成了一次主設備的接收。在完成上述兩個模式時,主要用到了控制寄存器IICCON、控制狀態(tài)寄存器IICSTAT和發(fā)送接收數(shù)據(jù)移位寄存器IICDS。由于我們只把s3c2440當做主設備來用,并且系統(tǒng)的IIC總線上只有這么一個主設備,因此用來設置從設備地址的地址寄存器IICADD,和用于仲裁總線的多主設備線路控制寄存器IICLC都無需配置。寄存器IICCON的第6位和低4位用于設置IIC的時鐘頻率,因為IIC的時鐘線SCL都是由主設備提供的。s3c2440的IIC時鐘源為PCLK,當系統(tǒng)的PCLK為50MHz,而從設備最高需要100kHz時,可以將IICCON的第6位置1,IICCON的低4位全為0即可。寄存器IICCON的第7位用于設置是否發(fā)出應答信號,第5位用于是否使能發(fā)送和接收中斷,第4位用于中斷的標志,當接收或發(fā)送數(shù)據(jù)后一定要對該位進行清零,以清除中斷標志。寄存器IICSTAT的高2位用于設置是哪種操作模式,當向第5位寫0或?qū)?時,則表示結(jié)束IIC或開始IIC通訊,第4位用于是否使能接收/發(fā)送數(shù)據(jù)。
#include "2440addr.h"
#define U32 unsigned int
unsigned char iic_buffer[8];
U32 length;
unsigned char add, word;
int cmd, flag, count, command;
void delay(int a)
{
int k;
for(k=0;k<a;k++)
;
}
void __irq UART0_ISR(void){
char ch;
rSRCPND |= (0x1<<28);
rINTPND |= (0x1<<28);
rSUBSRCPND |= 0x1<<0;
if(rUTRSTAT0 & 0x1){
ch = rURXH0;
while(!(rUTRSTAT0&0x4));
rUTXH0 = ch;
if(count == 0)
command = ch;
if(command == 0xa1){
if(count == 1){
add = ch;
}
else
if(count == 2){
word = ch;
}
else
if(count == 3){
length = ch;
}
else if(count >= 4)
{
iic_buffer[count-4] = ch;
if(count == length+3){
count = -1;
cmd = 0x01;
}
}
count++;
}
else if(command == 0xa2)
{
if(count == 1)
add = ch;
else
if(count == 2)
word = ch;
else
if(count == 3){
length = ch;
count = -1;
cmd = 0x02;
}
count++;
}
}
關(guān)鍵詞:
S3C2440IIC串行總
評論