24c02讀寫程序(已通過測試),24C02 read / write process
關(guān)鍵字:24c02讀寫程序(已通過測試)
24c02讀寫程序(已通過測試)
24c02讀寫程序(已通過測試)#ifndef _24C02_H
#define _24C02_H
// 腳定義
sbit SCL = P3^7; //24c02 SCL
sbit SDA = P3^6; //24c02 SDA
// 功能函數(shù)
void x24c02_delay(char x)
{
int i;
for(i=0;i}
void x24c02_start()
{
SDA = 1;
SCL = 1;
SDA = 0;
SCL = 0;
}
void x24c02_stop()
{
SDA=0;
SCL=1;
SDA=1;
}
void x24c02_writex(char j)
{
char i,temp;
temp=j;
for (i=0;i<8;i++)
{
temp=temp<<1;
SCL=0;
SDA=CY;
SCL=1;
}
SCL=0;
SDA=1;
}
char x24c02_readx()
{
char i,j,k=0;
SCL=0;
SDA=1;
for (i=0;i<8;i++)
{
SCL=1;
if (SDA==1) j=1;
else j=0;
k=(k<<1)|j;
SCL=0;
}
return(k);
}
void x24c02_clock()
{
char i=0;
SCL=1;
while ((SDA==1)&&(i<255))i++;
SCL=0;
}
void x24c02_init()
{
SCL = 1;
SDA = 1;
}
char x24c02_read(char address)
{
char i;
x24c02_start();
x24c02_writex(0xa0);
x24c02_clock();
x24c02_writex(address);
x24c02_clock();
x24c02_start();
x24c02_writex(0xa1);
x24c02_clock();
i=x24c02_readx();
x24c02_stop();
x24c02_delay(10);
return(i);
}
void x24c02_write(char address, char info)
{
EA=0;
x24c02_start();
x24c02_writex(0xa0);
x24c02_clock();
x24c02_writex(address);
x24c02_clock();
x24c02_writex(info);
x24c02_clock();
x24c02_stop();
EA=1;
x24c02_delay(50);
}
void x24c02_writestr(char address, unsigned char *wdata, unsigned char wlen)
{
unsigned char k=0;
do
{
x24c02_write(address+k, *(wdata + k));
k++;
} while(k < wlen);
}
void x24c02_readstr(char address, unsigned char *rdata, unsigned char rlen)
{
unsigned char k=0;
do
{
rdata[k] = x24c02_read(address+k);
k++;
} while(k < rlen);
}
#endif
#define _24C02_H
// 腳定義
sbit SCL = P3^7; //24c02 SCL
sbit SDA = P3^6; //24c02 SDA
// 功能函數(shù)
void x24c02_delay(char x)
{
int i;
for(i=0;i
void x24c02_start()
{
SDA = 1;
SCL = 1;
SDA = 0;
SCL = 0;
}
void x24c02_stop()
{
SDA=0;
SCL=1;
SDA=1;
}
void x24c02_writex(char j)
{
char i,temp;
temp=j;
for (i=0;i<8;i++)
{
temp=temp<<1;
SCL=0;
SDA=CY;
SCL=1;
}
SCL=0;
SDA=1;
}
char x24c02_readx()
{
char i,j,k=0;
SCL=0;
SDA=1;
for (i=0;i<8;i++)
{
SCL=1;
if (SDA==1) j=1;
else j=0;
k=(k<<1)|j;
SCL=0;
}
return(k);
}
void x24c02_clock()
{
char i=0;
SCL=1;
while ((SDA==1)&&(i<255))i++;
SCL=0;
}
void x24c02_init()
{
SCL = 1;
SDA = 1;
}
char x24c02_read(char address)
{
char i;
x24c02_start();
x24c02_writex(0xa0);
x24c02_clock();
x24c02_writex(address);
x24c02_clock();
x24c02_start();
x24c02_writex(0xa1);
x24c02_clock();
i=x24c02_readx();
x24c02_stop();
x24c02_delay(10);
return(i);
}
void x24c02_write(char address, char info)
{
EA=0;
x24c02_start();
x24c02_writex(0xa0);
x24c02_clock();
x24c02_writex(address);
x24c02_clock();
x24c02_writex(info);
x24c02_clock();
x24c02_stop();
EA=1;
x24c02_delay(50);
}
void x24c02_writestr(char address, unsigned char *wdata, unsigned char wlen)
{
unsigned char k=0;
do
{
x24c02_write(address+k, *(wdata + k));
k++;
} while(k < wlen);
}
void x24c02_readstr(char address, unsigned char *rdata, unsigned char rlen)
{
unsigned char k=0;
do
{
rdata[k] = x24c02_read(address+k);
k++;
} while(k < rlen);
}
#endif
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報(bào)投訴
發(fā)布評論請先 登錄
相關(guān)推薦
英銳芯AD24C02_16-Byte(中性)
AD24C02是一款串行電可擦除編程只讀存儲器(EEPROM)。存儲器可存儲256個(gè)字節(jié)數(shù)據(jù),分為16頁 每頁16字節(jié),隨機(jī)字尋址需要8位數(shù)據(jù)字地址,具有低功耗CMOS技術(shù),自定時(shí)編程周期
發(fā)表于 09-09 15:08
?0次下載
STM8S103F3讀24C02硬件I2C可以連續(xù)讀,模擬I2C只能讀一個(gè),第二個(gè)是0x00為什么?
讀24C02硬件I2C可以連續(xù)讀,模擬I2C只能讀一個(gè)。第二個(gè)是0x00,求助大神指點(diǎn)
發(fā)表于 05-06 07:22
STM32F103用普通IO口驅(qū)動24C02,讀寫不正確的原因?
以下24C02的驅(qū)動好像不穩(wěn)定,不更換24C02時(shí),讀寫都正確,但是更換一個(gè)24C02,數(shù)據(jù)就讀寫不正確,在把之前的正常的
發(fā)表于 04-19 06:12
通過STM32F103的I2C讀寫24LC024,超過16個(gè)以后讀回來的地址上的數(shù)不對是怎么回事?
通過STM32F103的I2C讀寫24LC024,現(xiàn)在問題是一次讀寫16個(gè)及以內(nèi)的數(shù)據(jù)完全正常 ,超過16個(gè)以后讀回來的地址上的數(shù)不對,想問
發(fā)表于 04-18 06:37
24LC024超過16字節(jié)讀寫就不正常怎么解決?
。主控制器用的STM32F103。讀寫控制代碼如下:#defineADDR_24LC02_Write0xA0
#defineADDR_24LC02_Read0xA1
#defineBufferSize
發(fā)表于 04-15 06:21
24C02/04/08/16/32/64應(yīng)用介紹
電子發(fā)燒友網(wǎng)站提供《24C02/04/08/16/32/64應(yīng)用介紹.pdf》資料免費(fèi)下載
發(fā)表于 12-07 10:38
?2次下載
單片機(jī)IIC總線及AT24C02的應(yīng)用
電子發(fā)燒友網(wǎng)站提供《單片機(jī)IIC總線及AT24C02的應(yīng)用.doc》資料免費(fèi)下載
發(fā)表于 11-16 09:24
?2次下載
通過IIC總線讀寫AT24C512存儲器
今天要講的是通過IIC總線來讀寫AT24C512存儲。我們在開發(fā)一些項(xiàng)目的時(shí)候,如果要求對有些參數(shù)進(jìn)行存儲,且掉電不丟失的話,我們就需要一些外部存儲器件,比如說今天要講的AT24C51
STM32基礎(chǔ)知識:IIC總線操作EEPROM存儲模塊AT24C02
本文是IIC總線的實(shí)際應(yīng)用,將帶領(lǐng)讀者一步一步閱讀AT24C02數(shù)據(jù)手冊,看時(shí)序圖了解如何使用IIC接口EEPROM存儲模塊AT24C02,并編寫代碼使用STM32驅(qū)動這個(gè)模塊。
STM32速成筆記(11)—EEPROM(AT24C02)
AT24C01/02/04/08/16...是一個(gè)1K/2K/4K/8K/16K位電可擦除PROM,內(nèi)部含有128/256/512/1024/2048個(gè)8位字節(jié),AT24C01有一個(gè)8字節(jié)頁寫緩沖器,AT
對24C02寫或讀數(shù)據(jù)的時(shí)候從機(jī)不回ACK是什么情況?
各位高手是否有碰到過對24C02寫或讀數(shù)據(jù)的時(shí)候從機(jī)不回ACK
就是我對24C02發(fā)送寫數(shù)據(jù)0xa0或發(fā)讀0xa0 但從機(jī)不回ACK信號那是什么情況?
發(fā)表于 10-18 06:30
用IIC實(shí)現(xiàn)與at24c32通信,代碼一直卡在檢測at24c32部分的原因?
//檢查AT24CXX是否正常
//這里用了24XX的最后一個(gè)地址來存儲標(biāo)志字.24C02是25524C512是65535 24C512是6
發(fā)表于 10-07 08:19
請問24cxx系列的驅(qū)動可以通用嗎?
24cxx系列的驅(qū)動可以通用嗎?
現(xiàn)在手頭有個(gè)24c02的驅(qū)動,可以直接用在24c256上面嗎?我只需要使用前2k的字節(jié)就好了,主要是板子上焊接的就是24c256,其實(shí)用不著那么大的空
發(fā)表于 09-26 07:29
24c02能讀不能寫是怎么回事?
) //SCL
#define IIC_SDA PCout(14) //SDA
#define READ_SDAPCin(14)//ê #228;è #235;SDA
發(fā)表于 09-26 06:18
評論