文章插圖

文章插圖
自己學習記錄用,有些亂,
1、IIC,eeprom24c02驅動配置
本實驗是基于EEPROM的24C02驅動配置的編程,主要記錄一些編程的重點節點的理解:
1、IIC驅動配置:精準的時鐘配置,計算每一步所需要的指令周期,相加是10us 。
void i2cStart(void) //開始時序{SDA=1;SCL=1;_delay(2); //延時2μsSDA=0;_delay(2);SCL=0;}void i2cStop(void) //結束時序{SDA=0;_delay(2);SCL=1;_delay(2);SDA=1;}void i2cAck_MCU(void) //應答時序{SDA=0;_delay(2);SCL=1;_delay(2);SCL=0;_delay(2);SDA=1;_delay(4);}void i2cNoAck_MCU(void) //非應答時序{SDA=1;_delay(2);SCL=1;_delay(2);SCL=0;_delay(2);}
24C02/16存儲空間大小
24C02就是有2Kbit = 2000/8 = 250個字節,24C16就是有16kbit = 2000個字節,24C02一頁最多可以寫入8個字節,因此可以分成32頁,24C16一頁最多可以寫入16個字節,因此可以分成128頁 。1、字節寫操作
void WriteByte_24LC16B(unsigned char input)
{
unsigned char bit_count;
for(bit_count=8;bit_count!=0;bit_count–)
{
_delay(2);
SDA=(_Bool)(input&0x80);
_delay(2);
SCL=1;
_delay(2);
SCL=0;
input=input<<1;
_delay(2);
}
SDA=1;
SDA_CTRL=1;//這里需要看自己使用的芯片設置SDA的IO口為輸入狀態,我用的是HT45F67芯片,SDA端口設置為輸入狀態,用于判斷SDA是否接到主機的應答信號
_delay(2);
SCL=1;
_delay(2);
if(SDA == 1)
ack = 0;
else
ack = 1;
SCL=0;
SDA_CTRL=0; //此處根據自己所使用的芯片將SDA所在的Io口設置為輸出狀態
}
void Write_24LC16B(unsigned char Wdata,unsigned int RomAddress)
{
unsigned char block;
WriteDeviceAddress=0B10100000;
block=RomAddress/256;
RomAddress=RomAddress%256;
WriteDeviceAddress=WriteDeviceAddress|(block<<1);
i2cStart();
WriteByte_24LC16B(WriteDeviceAddress);
WriteByte_24LC16B((unsigned char)RomAddress);
WriteByte_24LC16B(Wdata);
i2cStop();
_delay(5500);
}
2、字節讀操作
unsigned char ReadByte_24LC16B()
{
unsigned char bit_count,rbyte=0;
SDA=1;
SDA_CTRL=1;
_delay(10);
for(bit_count=8;bit_count!=0;bit_count–)
{
rbyte=rbyte<<1;
_delay(2);
SCL=1;
rbyte=rbyte|((unsigned char)(SDA));
_delay(2);
SCL=0;
_delay(2);
}
SDA_CTRL=0;
return(rbyte);
}
unsigned char Read_24LC16B(unsigned int RomAddress)
{
unsigned char output,block;
ReadDeviceAddress=0B10100001;
WriteDeviceAddress=0B10100000;
block=RomAddress/256;
RomAddress=RomAddress%256;
WriteDeviceAddress=WriteDeviceAddress|(block<<1);
ReadDeviceAddress=ReadDeviceAddress|(block<<1);
i2cStart();
WriteByte_24LC16B(WriteDeviceAddress);
WriteByte_24LC16B((unsigned char)RomAddress);
i2cStart();
WriteByte_24LC16B(ReadDeviceAddress);
output=ReadByte_24LC16B();
i2cNoAck_MCU();
i2cStop();
_delay(2000);
return(output);
}
3、頁寫操作
Wdata為輸入數組的首地址,RomAddress為需要進行存儲的地址,范圍在0~2047之間,cnt為一次需要寫入的字節個數,建議采用8的倍數的cnt,因為本函數不采用自動分頁,不是8的倍數會在超出頁寫入最多的字節數之后覆蓋掉原來的數 。
void WritePage_24LC16B(unsigned char *Wdata,unsigned int RomAddress,unsigned char cnt)
{
unsigned char block;
WriteDeviceAddress=0B10100000;
block=RomAddress/256;
RomAddress=RomAddress%256;
WriteDeviceAddress=WriteDeviceAddress|(block<<1);
i2cStart();
WriteByte_24LC16B(WriteDeviceAddress);
WriteByte_24LC16B((unsigned char)RomAddress);
while(cnt–)
{
WriteByte_24LC16B(*Wdata++);
}
i2cStop();
}
注意:連續進行多頁寫操作,需要在WritePage_24LC16B函數后添加150μs以上的延遲,這段時間,24C02內部需要將數據存儲到芯片內部 。
例子:
D_buffer[8] = {1,2,3,4,5,6,7,8};
WritePage_24LC16B(D_buffer,0,8);
_delay(150); //延遲150μs以及以上
WritePage_24LC16B(D_buffer,8,8);
4、頁讀操作void ReadPage_24LC16B(unsigned char *Rdata,unsigned int RomAddress,unsigned char cnt)
{
unsigned char block;
ReadDeviceAddress=0B10100001;
WriteDeviceAddress=0B10100000;
block=RomAddress/256;
RomAddress=RomAddress%256;
WriteDeviceAddress=WriteDeviceAddress|(block<<1);
ReadDeviceAddress=ReadDeviceAddress|(block<<1);
i2cStart();
WriteByte_24LC16B(WriteDeviceAddress);
WriteByte_24LC16B((unsigned char)RomAddress);
i2cStart();
WriteByte_24LC16B(ReadDeviceAddress);
while(cnt>1)
{
*Rdata++ = ReadByte_24LC16B();
cnt–;
i2cAck_MCU();//發送完讀地址后,需要應答一下
}
*Rdata = http://www.mnbkw.com/jxjc/187709/ReadByte_24LC16B();
i2cNoAck_MCU();//讀取最后一個字節需要非應答
i2cStop();
【c51單片機編程入門 c51單片機技術教程】_delay(2000);
- 編程入門自學軟件 零基礎如何自學軟件編程
- 學電腦編程要多久時間 自學計算機編程要多久
- 編程漏洞是什么 漏洞利用原理
- 怎樣自學編程入門 編程入門自學軟件
- 樹莓派程序用什么語言編寫 樹莓派怎么用c語言編程
- 編程軟件scratch教程大魚吃小魚 編程軟件scratch教程下載
- 在線c語言編程網站國內 C語言在線編程網站
- 單片機用c語言開發比匯編語言開發的優點 c語言對單片機重要嗎
- 跨平臺軟件開發語言 跨平臺的編程語言有哪些
- vb簡單編程代碼 vb初學者編程代碼基礎
