51单片机通过IIC向EEPROM存储和读取数据 10C

我用51单片机通过IIC向EEPROM存储数据,然后再把数据读出来,再通过串口发送出去,
再用串口调试工具(eaglecom)查看数据。。。最后发现一次只能发送或者读取12个
字节,大于12个字节之后的数据全是0xff。不知道原因是什么。

```#include
#include "delay.h"
#include "Uart.h"
#define ERROR 0
#define SUCCESS 1
#define MAX 50

sbit SDA = P1^7;
sbit SCK = P1^6;

unsigned char ack = 0;

void IIC_Start()
{
SDA = 1;
SCK = 1;
delay_us(1);
SDA = 0;
delay_us(1);
SCK = 0;
}

void IIC_Stop()
{
SDA = 0;
SCK = 1;
delay_us(1);
SDA = 1;
delay_us(1);
SCK = 0;
}

void IIC_ACK()
{
SDA = 0;
SCK = 1;
delay_us(1);
SCK = 0;
}

void IIC_NOACK()
{
SDA = 1;
SCK = 1;
delay_us(1);
SCK = 0;
}

void IIC_SendByte(unsigned char temp)
{
unsigned char i;
for(i = 0; i < 8; i++)
{
SDA = temp & 0x80;
SCK = 1;
delay_us(1);
SCK = 0;
delay_us(1);
temp <<= 1;
}
SCK = 1;
SDA = 1;
delay_us(1);
if(0 == SDA)
{
ack = 1;
}
else
{
ack = 0;
}

SCK = 0;

}

unsigned char IIC_RecvByte()
{
unsigned char i, temp;

SDA = 1;
for(i = 0; i < 8; i++)
{
    SCK = 0;
    delay_us(1);
    SCK = 1;
    temp <<= 1;
    if(1 == SDA)
    {
        temp = temp + 1;
    }
}
SCK = 0;
return temp;

}

unsigned char AT24C02_SendStr(unsigned char deceviceaddr, unsigned char romaaddr, unsigned char *s, unsigned char num)
{
unsigned char i;

IIC_Start();
IIC_SendByte(deceviceaddr);
if(0 == ack)
{
    return ERROR;
}

IIC_SendByte(romaaddr);
if(0 == ack)
{
    return ERROR;
}

for(i = 0; i < num; i++)
{
    IIC_SendByte(*s);
    if(0 == ack)
    {
        return ERROR;
    }
    s++;
}
IIC_Stop();

return SUCCESS;

}

unsigned char AT24C02_RecvStr(unsigned char deceviceaddr, unsigned char romaaddr, unsigned char *s, unsigned char num)
{
unsigned char i;

IIC_Start();
IIC_SendByte(deceviceaddr);
if(0 == ack)
{
    return ERROR;
}
IIC_SendByte(romaaddr);
if(0 == ack)
{
    return ERROR;
}
IIC_Start();
IIC_SendByte(deceviceaddr + 1);
if(0 == ack)
{
    return ERROR;
}

for(i = 0; i < num - 1; i++)
{
    *s = IIC_RecvByte();
    IIC_ACK();
    s++;
}
*s = IIC_RecvByte();
IIC_NOACK();
IIC_Stop();

return SUCCESS;

}

void main()
{
unsigned char i = 0;
unsigned char temp[MAX + 1];
unsigned char str[2];

Uart_init();

for(i = 0; i < MAX; i++)
{
    temp[i] = 7;
}

if(!AT24C02_SendStr(0xae, 100, temp, MAX))
{
    return;
}
delay_ms(200);

for(i = MAX; i < (MAX + 1) ;i++)
{
    temp[i] = 0;
}
delay_ms(200);

if(!AT24C02_RecvStr(0xae, 100, temp, MAX))
{
    return;
}
delay_ms(200);
Uart_SendStr(temp);

while(1);

}

如果用IICSendByte()和RecvByte(),一个字节一个字节发送和读取的话是不会出错的,但是封装成IICSendStr()和RecvByte()的话,发送或者是接收的字符串长度不能超过12。这是为什么?


2个回答

e2prom写入有个时间tWR要求,一般是5ms,如果写的间隔过小可能写不进去。为留有一定余量,最好设成10ms。

程序上应该没什么问题,你的 Flash 规定一次最多可以写几个数据?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
模拟IIC更改IO口以后,IIC设备读取数据失败

使用的是STM32F!03C8T6,然后用的是ADS1110芯片要读取AD值,IIC通信。之前调试的很稳定,但是因为需要更换IO口(由PB10,PB11换成了PA2,PA3)就没了反应。IIC底层代码使用的正点原子的代码。做了如下更改//IO方向设置//PA2,PA3 #define SDA_IN_2() {GPIOA->CRL&=0XFFFF0FFF;GPIOA->CRL|=8<<12;} #define SDA_OUT_2() {GPIOA->CRL&=0XFFFF0FFF;GPIOA->CRL|=3<<12;} //IO操作函数 #define IIC_SCL_2 PAout(2) //SCL #define IIC_SDA_2 PAout(3) //SDA #define READ_SDA_2 PAin(3) //输入SDA //PB10,PB11 #define SDA_IN() {GPIOB->CRH&=0XFFFF0FFF;GPIOB->CRH|=8<<12;} #define SDA_OUT() {GPIOB->CRH&=0XFFFF0FFF;GPIOB->CRH|=3<<12;} //IO操作函数 #define IIC_SCL PBout(10) //SCL #define IIC_SDA PBout(11) //SDA #define READ_SDA PBin(11) //输入SDA 以下是ADS110代码 void ADS1110_config(void) //配置config寄存器 { IIC_Start(); //控制SCL和SDA线实现IIC通讯的开始; IIC_Send_Byte(0X90); while(IIC_Wait_Ack()) { printf("IICfailed\r\n"); break; } while(IIC_Wait_Ack()) { printf("IICfailed\r\n"); break; } IIC_Stop(); } void write_ads1110(u8 cmd)//写数据 { IIC_Start(); IIC_Send_Byte(0X90); //ADS1110地址 写 while(IIC_Wait_Ack()); IIC_Send_Byte(cmd); while(IIC_Wait_Ack()); IIC_Stop(); } u16 read_ads1110(void) { if((adc_sr&0x80)==0) { IIC_Start(); IIC_Send_Byte(0x91); //ADS1110地址 读 while(IIC_Wait_Ack()); adc_hi = IIC_Read_Byte(1); adc_lo = IIC_Read_Byte(1); IIC_Stop(); adc_lo1=(adc_hi<<8)+adc_lo; if(adc_lo1>65535)adc_lo1-=65535; } return adc_lo1; } u8 read_sr(void) { IIC_Start(); IIC_Send_Byte(0x91); //ADS1110地址 读 while(IIC_Wait_Ack()); adc_hi = IIC_Read_Byte(1); adc_lo = IIC_Read_Byte(1); adc_sr=IIC_Read_Byte(1); IIC_Stop(); return adc_sr; }

dsp28335iic发完要读取的数据地址以后无应答位产生

![图片说明](https://img-ask.csdn.net/upload/201601/20/1453287164_682053.png) ``` ```

求iic总线接口驱动程序

51单片机驱动128x64iic总线驱动显示,实际应用中,由于我是新手所以不知道该如何运作。 单片机型号stc15w4k56s4

iic中主机读取一个字节的时候,从机怎么知道什么时候给主机发送数据呢

![图片说明](https://img-ask.csdn.net/upload/201509/13/1442142144_524199.png)如果是主机发送数据的话,我们可以控制SCL和SDA,在SCL为高电平期间,可以是SDA为稳定状态,但是主机接收时,要从机发送数据,从机怎么知道什么时候可以发送呢 比如图中的程序,从机发送数据只能是在SCL_L和SCL_H之间了,从机是怎么知道的呢

STM32F030硬件IIC低温测试异常

最近在使用STM32F030的硬件IIC操作EEPROM时,发现一个问题: 在常温下,STM32F030的硬件IIC工作正常,时序正常,在低温箱(零下40度)里工作约2个小时后,硬件IIC工作异常,且时序也乱了. 异常时序表现为:不论是读还是写,仅从机地址+读写地址所对应的时序正常,之后,SCK一直保持低电平,一段时间后,SCK时钟输出正常,但SDA数据异常.整始位及结束位正常,具体时序图如下: ![图片说明](https://img-ask.csdn.net/upload/201807/02/1530525152_3794.jpg) 由于软件模拟IIC太耗时了,只能使用硬件IIC. 不知道有没有哪位高人能够指点一下,感激不尽.

IIC总线读写IIC芯片问题求教

IIC读写时序可以正常读写总线上的一个IICGPIO扩展芯片,但读IICg-sensor芯片时候读出的数据总是和第一个读出的数据一样

关于51单片机的1602液晶结合AT24C02显示时钟程序的相关问题

我在郭天祥的单片机书上看到关于1602液晶显示时钟的程序,然后我把对照这个模板写, 发现程序出现一个警告, 板子无法正常在1602上显示。 求各位大佬讲解。 //main.c// #include<reg52.h> #include"IIC.H" #include<intrins.h> #define uchar unsigned char uchar count,keynum; char sec,min,hour; sbit lcden=P1^2; //液晶使能端 sbit lcdrs=P2^0; sbit buzz=P0^6; sbit key1=P3^0; sbit key2=P3^1; sbit key3=P3^2; uchar code table[]="2017-06-07"; void Delay5ms() //@11.0592MHz { unsigned char i, j; i = 54; j = 199; do { while (--j); } while (--i); } void di() { P2=0XA0; buzz=1; Delay5ms(); P2=0x00; } void write_com(unsigned char date) { lcdrs=0; lcden=1; P0=date; Delay5ms(); lcden=0; } void write_data(unsigned char date) { lcdrs=1; lcden=1; P0=date; Delay5ms(); lcden=0; } void write_sfm(uchar add, uchar date) { uchar shi,ge; shi=date/10; ge=date%10; write_com(0x80+0x40+add); write_data(0x30+ge); write_data(0x30+shi); } void init1() { uchar num; sec=0; min=0; hour=0; keynum=0; count=0; init_24c02(); write_com(0x38); //模式 write_com(0x0c); //开显示,显示光标,不闪烁 write_com(0x06); //指针加1 write_com(0x01); //清屏 for(num=0;num<12;num++) { write_data(table[num]); } sec=read_add(1); min=read_add(2); hour=read_add(3); TMOD=0X01; TH0=(65536-50000)/256; TL0=(65536-50000)%256; EA=1; ET0=1; TR0=1; write_com(0x80+0x40+6); write_data(':'); Delay5ms(); write_com(0x80+0x40+9); write_data(':'); Delay5ms(); } void key_scan() { if(key1) { TR0=0; Delay5ms(); if(key1) { while(!key1); di(); keynum++; if(keynum==1) { write_com(0x80+0x40+10); write_data(0x0f); } if(keynum==2) { write_com(0x80+0x40+7); } if(keynum==3) { write_com(0x80+0x40+4); } if(keynum==4) { keynum=0; write_com(0x0c); TR0=1; } } if(!keynum) { if(key2) { Delay5ms(); if(key2) { while(!key3); di(); if(keynum==1) { sec++; if(sec==60) { sec=0; } write_sfm(10,sec); write_com(0x80+0x40+10); write_add(1,sec); } if(keynum==2) { min++; if(min==60) { min=0; } write_sfm(7,min); write_com(0x80+0x40+7); write_add(2,min); } if(keynum==3) { hour++; if(hour==60) { hour=0; } write_sfm(4,hour); write_com(0x80+0x40+4); write_add(3,hour); } } } if(key3) { Delay5ms(); if(key3) { while(!key3); di(); if(keynum==1) { sec--; if(sec==-1) { sec=60; } write_sfm(10,sec); write_com(0x80+0x40+10); write_add(1,sec); } if(keynum==2) { min--; if(min==0) { min=60; } write_sfm(7,min); write_com(0x80+0x40+7); write_add(2,min); } if(keynum==3) { hour--; if(hour==0) { hour=60; } write_sfm(4,hour); write_com(0x80+0x40+4); write_add(3,hour); } } } } } } void main() { init1(); while(1) { key_scan(); } } void timer0() interrupt 1 { TH0=(65536-50000)/256; TL0=(65536-50000)%256; count++; if(count==20) { count=0; sec++; if(sec==60) { sec=0; min++; if(min==60) { min=0; hour++; if(hour==60) { hour=0; } write_sfm(4,hour); write_add(3,hour); } write_sfm(7,min); write_add(2,min); } write_sfm(10,sec); write_add(1,sec); } } //IIC.c// #include <reg52.h> #include "IIC.H" #include<intrins.h> void delay0() { ;;} void Delay5us() { unsigned char i; _nop_(); _nop_(); i = 12; while (--i); } //开始信号 void start() { SDA=1; Delay5us(); SCL=1; Delay5us(); SDA=0; Delay5us(); SCL=0; Delay5us(); } //停止信号 void stop() { SDA=0; Delay5us(); SCL=1; Delay5us(); SDA=1; Delay5us(); } //主机应答反映 void send_renspons(bit date) { SDA=date; SCL=1; Delay5us(); SCL=0; Delay5us(); } //从机应答信号 bit re_renspons() { bit temp; SDA=1; Delay5us(); SCL=1; Delay5us(); if(SDA==1) temp=0; else temp=1; SCL=0; Delay5us(); return temp; } void init_24c02() { SDA=1; delay0(); SCL=1; delay0(); } //写数据_字节 void write_date(unsigned char date) { unsigned char i; for (i=0;i<8;i++) { if ((date<<i)&0x80) SDA=1; else SDA=0; SCL=1; Delay5us(); SCL=0; Delay5us(); } re_renspons(); } //读数据——字节 unsigned char read_date() { unsigned char i,temp; SDA=1; Delay5us(); for (i=0;i<8;i++) { temp<<=1; SCL=1; Delay5us(); if(SDA==1) temp=temp+1; SCL=0; Delay5us(); } return temp; } //写一个字节 void write_add(unsigned char addr,unsigned char date) { start(); write_date(0xa0); write_date(addr); write_date(date); stop(); } //读一个字节 unsigned char read_add(unsigned char addr) { unsigned char temp; start(); write_date(0xa0); write_date(addr); start(); write_date(0xa1); temp=read_date(); send_renspons(1); stop(); return temp; } //IIC.H// #ifndef _IIC_H_ #define _IIC_H_ sbit SCL=P2^0; sbit SDA=P2^1; void write_add(unsigned char addr,unsigned char date); unsigned char read_add(unsigned char addr); void init_24c02(); #endif ![图片说明](https://img-ask.csdn.net/upload/201706/08/1496855360_216038.png)

AXDL345怎么读取最新数据

现在能读出三轴加速度数据,方法是IIC读取0x33-0x37数据寄存器。 但我的目的是读数时,能读出最新更新的加速度数据。 我在datasheet上看到写入数据寄存器的为最早数据,而FIFO里可以存储32组数据。 也就是说我读取的是一开始测量时的数据,而不是最新数据吗? 那我是否需要读取32组数据,取最后的一组呢?

DHT11温湿度测量和iic协议怎么建起来的联系。

来自一个单片机小白的提问 有个作业是叫运用iic协议来测量温湿度,好像不用协议也可以的吧??但是要用的话怎么弄呢,那个协议我已经看好久了,看了好多帖子还是那几句话,似懂非懂的。求带

单片机中AT24C02问题,初学者,希望大家帮帮我

#include "reg52.h"#include "intrins.h"sbit SDA=P2^1;//总线连接口定义sbit SCL=P2^0;//总线连接口定义sbit duan=P2^2;sbit wei=P2^3;typedef unsigned char uchar;uchar duanma[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};uchar weima[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};uchar t[8];void delay(uchar m)//us延时作用{ while(--m);}void delays(uchar t)//ms延时作用{ while(t--) { delay(245); delay(245); }}/*void display(uchar firstbit,uchar weishu){ static unsigned char i; P0=0; duan=1; duan=0; P0=weima[firstbit+i]; wei=1; wei=0; P0=t[i]; duan=1; duan=0; i++; if(i==weishu) i=0;}*//*void time_0()interrupt 1{ TH0=(65536-2000)/256; TL0=(65536-2000)%256; display(0,8);}*/void iic_start()//开始通知芯片读写开始。{ SDA=1;//上来先让数据线置高电平 SCL=1;//接着让时钟线置高电平 delay(5);//SDA和SCL同时为高电平保持4.7us以上 _nop_();//1.805us,共5.78us,下面SDA=0;是下降沿,不能计算在延时时间中 SDA=0;//在时钟线为高电平,而数据线由高电平到低电平的过程读写芯片开始进行.//下降沿 delay(5);//SDA低电平保持4us以上,这里是4.34us满足要求。 //注意开始后SCL为1,SDA为0; }void iic_inti()//总线初始化{ SCL=1;//=-----————————————————————>>>>>>>>>>>>>让时钟线和数据线都为高电平 SDA=1;//------——————————————————>>>>>>>>>>>>让时钟线和数据线都为高电平 delay(5);}void iic_stop(){ SDA=0; _nop_();//准备状态 SCL=1; //————————————————————————>>>>>>>>结束信号是时钟线为高电平,而数据线由低电平到高电平的过程 delay(5);//该稳态需要保持时间为4us以上。 SDA=1;//SCL高电平期间,SDA来一个上升沿, delay(5);//SDA保持4US以上,4.34加上函数返回时间大于4.7us; //注意结束时SCL和SDA都为1;}void iic_sendbyte(uchar bytedate)//发送一个字节{ uchar i,temp; temp=bytedate; for(i=0;i<8;i++) { temp=temp<<1;//移动后最高位到了PSW寄存器的CY位中。 SCL=0;//准备发送阶段 _nop_();//稳定一下 SDA=CY;//将发送的数据一位位的发送到CY位的SDA上 _nop_();//稳定一下 SCL=1;//每一个高电平期间,IC器件都会将数据取走 _nop_();//稳定一下 } SCL=0;//如果写成SCL=1,SDA=1;就是停止信号了,所以不能那样写 _nop_(); SDA=1;//释放总线,数据总线不用时要释放 _nop_();}uchar iic_readbyte(){ uchar i,temp; SCL=0;//准备读数据 _nop_(); SDA=1;//释放总线 _nop_(); for(i=0;i<8;i++) { SCL=1;//MCU开始取数据 delay(5);//SCL为高电平后,IC器件就会将一位数据送到SDA上, //总共用时不会大于4.34us的,然后就可以让MCU度SDA了 temp=(temp<<1)|SDA;//读一位,保存到temp中。 SCL=0; delay(5); } return temp;}bit iic_checkACK()//处理信号{ uchar errcount=255;//定义超时量为255次 SCL=1; _nop_(); while(SDA) { //在一段时间内检测到SDA=0的话认为是应答信号 if(0==errcount) { SCL=0;//钳住总线 _nop_(); return 0;//没有应答信号 } errcount--; } SCL=0;//钳住总线,为下一次通信做准备 _nop_(); return 1;//成功处理应答信号}void iic_sendACK(bit b_ACK)//发送应答或非应答信号{ SCL=0;//准备 _nop_(); if(b_ACK)//ACK { SDA=0; } else //UACK { SDA=1; } _nop_(); SCL=1; delay(5);//大于4us的延时 SCL=0;// 钳住SCL,以便接受数据. _nop_();}void AT24c02_writebyte(unsigned char addr,unsigned char byte)//向24c02写一个字节数据{ iic_start(); iic_sendbyte(0xa0);//MCU写控制字,前四位固定1010,后三位地址0,末位0是写数据的模式 iic_checkACK();//MCU 处理应答信号 iic_sendbyte(addr);// 准备在指定的地址写入 iic_checkACK(); iic_sendbyte(byte);//写数据 iic_checkACK(); iic_stop(); delays(2);//按字节写入时,24c02在接收到停止信号后,将数据擦写到内部,这需要时间 //并且在这段时间内不会响应总线上的任何请求,固让MCU有2毫秒以上的等待 } void AT24c02_writeData(unsigned char address,unsigned char numbytes,unsigned char *buf)//写入任意长度数据 { while(numbytes--) { AT24c02_writebyte(address++,*buf++); }} void AT24c02_readData(unsigned char beignAddr,unsigned char dataSize,unsigned char *buf)//读取任意长度字节 { iic_start();//起始信号 iic_sendbyte(0xa0);//控制字,写的模式//控制字,读的模式//1010(固定模式)000,地址;最后一位是控制读或写的模式,1为读,0为写 iic_checkACK();//处理应答信号 iic_sendbyte(beignAddr);//发送地址 iic_checkACK();//处理应答信号 iic_start();//发送起始信号 iic_sendbyte(0xa1);//控制字,读的模式//1010(固定模式)000,地址;最后一位是控制读或写的模式,1为读,0为写 iic_checkACK();//处理应答信号 while(dataSize--) { *buf++=iic_readbyte();//读取一个个字节并保存到缓冲区buf中, iic_sendACK(dataSize);//发送应答,当dataSize为0时发送非应答 } iic_stop();//发送停止信号}unsigned char dat[]={0x7f,0xbf,0xdf,0xef, 0xf7,0xfb,0xfd,0xfe, 0xff,0xff,0x00,0x00, 0x55,0x55,0xaa,0xaa };//ram允许情况可以无限添加i;void main(){ uchar i; iic_inti(); AT24c02_writeData(0xae,16,dat); //写入24c02 //第一个数据0xae,代表大地址,第二个1,代表小弟指,一个24c02的小地址的范围是0--250, //第三个是代表数据的地址 delays(1); for(i=0;i<16;i++) dat[i]=0; AT24c02_readData(0xae,16,dat); //从24c02读数据 //第一个数据0xae,代表大地址,第二个1,代表小弟指,一个24c02的小地址的范围是0--250, //第三个是代表数据的地址 while(1) { for(i=0;i<16;i++) //查表 { delays(200); P1=dat[i]; } }} 这个程序为什么只有插上数据线和时钟线才能出现跑马灯效果,不插为什么led灯不亮呢。

mpu9250读取磁力计数据不变

我用stm32读取mpu9250中的磁力计数据,但是发现其数值一直不会改变。我进行了一下尝试:1.将scl和sda线的GPIO口改为开漏输出 2.每读一次磁力计数据都经过如下流程(先开启bypass,再开启单次测量模式,然后读磁力计数据,再关闭bypass) 3.在开启bypass和开启单次测量模式后都加上了延时。 但是,试过了以上做法,读出来的磁力计数据还是不会改变,我实在不知道该怎么做了,不知道有没有大佬能指导一下 这是我读取mpu9250原始数据的程序 ``` void data_to_computer(void) //上位机版本:4.34 { uint8_t accbuf[6],grobuf[6],data_to_send[18]; uint8_t magbuf[6]; MPU_Read_Len(MPU9250_ADDR,MPU_ACCEL_XOUTH_REG,6,accbuf); MPU_Read_Len(MPU9250_ADDR,MPU_GYRO_XOUTH_REG,6,grobuf); //开通bypass MPU_Write_Byte(MPU9250_ADDR,MPU_INTBP_CFG_REG,0X82); delay_ms(6); //AK8963每次读完以后都需要重新设置为单次测量模式 MPU_Write_Byte(AK8963_ADDR,MAG_CNTL1,0X11); delay_ms(6); MPU_Read_Len(AK8963_ADDR,MAG_XOUT_L,6,magbuf); mpu_set_bypass(0); delay_ms(6); data_to_send[0] = accbuf[0]; data_to_send[1] = accbuf[1]; data_to_send[2] = accbuf[2]; data_to_send[3] = accbuf[3]; data_to_send[4] = accbuf[4]; data_to_send[5] = accbuf[5]; data_to_send[6] = grobuf[0];//取data[0]数据的高字节, data_to_send[7] = grobuf[1]; data_to_send[8] = grobuf[2]; data_to_send[9] = grobuf[3]; data_to_send[10] = grobuf[4]; data_to_send[11] = grobuf[5]; data_to_send[12] = magbuf[0]; data_to_send[13] = magbuf[1]; data_to_send[14] = magbuf[2]; data_to_send[15] = magbuf[3]; data_to_send[16] = magbuf[4]; data_to_send[17] = magbuf[5]; for(int i = 0; i < 18; i ++) { Usart_SendByte(USART1,data_to_send[i]); //发送18个u8数据 } } ``` 这是初始化的代码 ``` u8 MPU9250_Init(void) { u8 res=0; //IIC_Init(); MPU_Write_Byte(MPU9250_ADDR,MPU_PWR_MGMT1_REG,0X80); //复位MPU9250 delay_ms(100); MPU_Write_Byte(MPU9250_ADDR,MPU_PWR_MGMT1_REG,0X00); //唤醒MPU9250 MPU_Set_Gyro_Fsr(3); //陀螺仪传感器,±2000dps (人体姿态捕捉最好设置为2000dps,8g) MPU_Set_Accel_Fsr(2); //加速度传感器,±8g MPU_Set_Rate(500); //设置采样率500Hz MPU_Write_Byte(MPU9250_ADDR,MPU_INT_EN_REG,0X00); //关闭所有中断 MPU_Write_Byte(MPU9250_ADDR,MPU_USER_CTRL_REG,0X00); //I2C主模式关闭 delay_ms(2); MPU_Write_Byte(MPU9250_ADDR,MPU_FIFO_EN_REG,0X00); //关闭FIFO MPU_Write_Byte(MPU9250_ADDR,MPU_INTBP_CFG_REG,0X82); //INT引脚低电平有效,开启bypass模式,可以直接读取磁力计 delay_ms(2); res=MPU_Read_Byte(MPU9250_ADDR,MPU_DEVICE_ID_REG); //读取MPU6500的ID if(res==MPU6500_ID) //器件ID正确 { MPU_Write_Byte(MPU9250_ADDR,MPU_PWR_MGMT1_REG,0X01); //设置CLKSEL,PLL X轴为参考 MPU_Write_Byte(MPU9250_ADDR,MPU_PWR_MGMT2_REG,0X00); //加速度与陀螺仪都工作 MPU_Set_Rate(500); //设置采样率为500Hz }else return 1; res=MPU_Read_Byte(AK8963_ADDR,MAG_WIA); //读取AK8963 ID if(res==AK8963_ID) { MPU_Write_Byte(AK8963_ADDR,MAG_CNTL1,0X11); //设置AK8963为单次测量模式 delay_ms(2); }else return 1; return 0; } ``` 反正现在就是除了磁力计其他数据都是好的,还恳请大佬指点一下

单片机关于I2C的ack问题

**uchar I2C_SendByte(uchar dat, uchar ack)**函数其中与ack相关的部分是 **while(I2C_SDA && (ack == 1))**//等待应答,也就是等待从设备把I2C_SDA拉低 **{ b++; if(b > 200) ** //如果超过200us没有应答发送失败,或者为非应答,表示接收结束 **{ I2C_SCL = 0; I2C_Delay10us(); return 0; } }** I2C_SCL = 0; I2C_Delay10us(); 在main中有 **I2C_SendByte(0xa0, 1)**;//发送写器件地址 _**I2C_SendByte(addr, 1**_);//发送要写入内存地址 **I2C_SendByte(dat, 0)**_; //发送数据 为什么发送数据时 ack为0了不为1,以及这个ack代表什么意义,ack不是从机将sda下拉的信号吗?

IIC 同时挂接AT24C08和MPU6050读写问题?

STM32 模拟IIC 。当总线上只有AT24C08且往AT24C08读写数据,没问题! 当总线上只有MPU6050且读MPU6050设备地址 OK! 当2个设备同时挂在IIC时,有趣的事来了,AT24C08读数据和MPU6050读设备地址没问题 ,往AT24C08写数据写不进去??拔掉6050的SCL线,AT24C08能正常读写,6050的SDA线拔插都不影响。。。

关于这个IIC的应答位画的位置是不是不太对啊,在scl位高电平期间,sda不是要稳定的吗

![图片说明](https://img-ask.csdn.net/upload/201508/26/1440589029_951163.png)如果在scl为高期间,sda变化的话不是有变成start和stop了吗

用串口调试助手给单片机以字符串的形式发送数据时,结尾是不默认添加'\0'的

这个你们知道吗?如果我今天才知道,说明什么,你们是通过什么途径知道的,

LTC2943 为什么读取电压一直为0x7f00

我使用软件 IIC读取LTC2943芯片中所测得电压数据,但低位一直为0,高位一直为0x7f,有人知道是怎么回事吗? 或者谁用软件IIC驱动过LTC2943芯片的,发一下驱动代码和硬件连接图? 另外,我能读取到LTC2943的状态寄存器和所测的电流寄存器值。

LTC2944 模拟IIC 驱动一直没成功

1.我用的是STM32模拟IIC驱动,代码从官网移植过来的,不过官网用的是arduino硬件IIC驱动的,我只是改成STM32模拟IIC,但是在测试的时候,IIC总线一直没有应答,硬件端的S+接的充电器,s-接的电池,IIC接口接STM3的IO口,下面是while循环,ltc2944和ltc2943的区别应该不大吧 ``` LTC2943_read_16_bits(LTC2943_I2C_ADDRESS, LTC2943_ACCUM_CHARGE_MSB_REG, &charge_code); LTC2943_read_16_bits(LTC2943_I2C_ADDRESS, LTC2943_VOLTAGE_MSB_REG, &voltage_code); LTC2943_read_16_bits(LTC2943_I2C_ADDRESS, LTC2943_CURRENT_MSB_REG, &current_code); //! Read MSB and LSB Current Registers for 16 bit current code LTC2943_read_16_bits(LTC2943_I2C_ADDRESS, LTC2943_TEMPERATURE_MSB_REG, &temperature_code); //! Read MSB and LSB Temperature Registers for 16 bit temperature code LTC2943_read(LTC2943_I2C_ADDRESS, LTC2943_STATUS_REG, &status_code); //! Read Status Register for 8 bit status code charge = LTC2943_code_to_mAh(charge_code, resistor, prescalarValue); //! Convert charge code to mAh if mAh units are desired. current = LTC2943_code_to_current(current_code, resistor); //! Convert current code to Amperes voltage = LTC2943_code_to_voltage(voltage_code); //! Convert voltage code to Volts temperature = LTC2943_code_to_celcius_temperature(temperature_code); //! Convert temperature code to celcius ``` 请问有人驱动成功的吗?

AT24Cxx 读写问题 写出现不明白的问题

我用的是AT24C512来存储数据,但写地址的时候,写完16位的地址,然后再写一个8位数据; 在读出来的时候,读到的是高8位地址所指向的地址的数据,且数据等于地址的低8位,怎么也读不到16位地址所指向地址的数据。 //向指定地址写一个字节数据 Write_IIC(0x00,0x00,0x10); //向0x0000地址写数据0x10 Delay(5); Write_IIC(0x01,0x01,0x11); //向0x0101地址写数据0x11 Delay(5); Write_IIC(0x02,0x02,0x12); //向0x0202地址写数据0x12 Delay(5); Write_IIC(0x03,0x03,0x13); //向0x0303地址写数据0x13 Delay(5); Write_IIC(0x04,0x04,0x14); //向0x0404地址写数据0x14 Delay(5); //读指定地址的数据 Send_Data(Read_ICC(0x00,0x00)); //读0x0000地址的数据 Delay(1); Send_Data(Read_ICC(0x01,0x01)); //读0x0101地址的数据 Delay(1); Send_Data(Read_ICC(0x02,0x02)); //读0x0202地址的数据 Delay(1); Send_Data(Read_ICC(0x03,0x03)); //读0x0303地址的数据 Delay(1); Send_Data(Read_ICC(0x04,0x04)); //读0x0404地址的数据 Delay(1); 我是从串口接收数据,读出来的数据为: 01 02 03 04 14 证明只有最后一次写,才把0x14写到0x0404里面;或者最后一次是往地址0x04写了一次0x04,然后再写0x14,0x14把0x04覆盖了。 第一次往0x0000写0x10不成功,第二次把地址的低8位0x01写到高8位地址0x01里去了,第三次,第四次与第二次一样。 为什么会这样 uchar Read_ICC(uchar ADD_H,uchar ADD_L) { uchar dat; I2C_Start(); Send_Byte(0xa0); //发器件地址,并通知准备发送地址 Response(); //应答 Send_Byte(ADD_H); //发器件内部存储器地址高位 Response(); //应答 Send_Byte(ADD_L); //发器件内部存储器地址低位 Response(); //应答 I2C_Start(); Send_Byte(0xa1); //发器件地址,并通知准备读取数据 Response(); //应答 dat=Rcv_Byte(); //读取数据 I2C_Stop(); //停止I2C总线 return (dat); } void Write_ICC(uchar ADD_H,uchar ADD_L,uchar dat) { I2C_Start(); Send_Byte(0xa0); //发器件地址,并通知准备发送地址,要对应芯片地址 Response(); //应答 Send_Byte(ADD_H); //发器件内部存储器地址高位 Response(); //应答 Send_Byte(ADD_L); //发器件内部存储器地址低位 Response(); //应答 Send_Byte(dat); //写入数据 Response(); //应答 I2C_Stop(); //停止I2C总线 }

嵌入式软硬件IIC问题,IO口模拟IIC

MTK平台 使用IO口模拟IIC,能够正确读写总线上的GPIO扩展口芯片,但是当读写同一总线上的g——sensor芯片时(软件器件地址没写错),只能读出CHIP-ID寄存器的正确值,但是当读其它寄存器时候,得出的值不是0就是器件地址的值,请问是什么问题

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

计算机组成原理实验教程

西北工业大学计算机组成原理实验课唐都仪器实验帮助,同实验指导书。分为运算器,存储器,控制器,模型计算机,输入输出系统5个章节

Java 最常见的 200+ 面试题:面试必备

这份面试清单是从我 2015 年做了 TeamLeader 之后开始收集的,一方面是给公司招聘用,另一方面是想用它来挖掘在 Java 技术栈中,还有那些知识点是我不知道的,我想找到这些技术盲点,然后修复它,以此来提高自己的技术水平。虽然我是从 2009 年就开始参加编程工作了,但我依旧觉得自己现在要学的东西很多,并且学习这些知识,让我很有成就感和满足感,那所以何乐而不为呢? 说回面试的事,这份面试...

winfrom中嵌套html,跟html的交互

winfrom中嵌套html,跟html的交互,源码就在里面一看就懂,很简单

玩转Python-Python3基础入门

总课时80+,提供源码和相关资料 本课程从Python零基础到纯Python项目实战。内容详细,案例丰富,覆盖了Python知识的方方面面,学完后不仅对Python知识有个系统化的了解,让你从Python小白变编程大牛! 课程包含: 1.python安装 2.变量、数据类型和运算符 3.选择结构 4.循环结构 5.函数和模块 6.文件读写 7.了解面向对象 8.异常处理

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:itxy41)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

基于VHDL的16位ALU简易设计

基于VHDL的16位ALU简易设计,可完成基本的加减、带进位加减、或、与等运算。

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

利用Verilog实现数字秒表(基本逻辑设计分频器练习)

设置复位开关。当按下复位开关时,秒表清零并做好计时准备。在任何情况下只要按下复位开关,秒表都要无条件地进行复位操作,即使是在计时过程中也要无条件地进行清零操作。 设置启/停开关。当按下启/停开关后,将

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

Python可以这样学(第一季:Python内功修炼)

董付国系列教材《Python程序设计基础》、《Python程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

计算机操作系统 第三版.pdf

计算机操作系统 第三版 本书全面介绍了计算机系统中的一个重要软件——操作系统(OS),本书是第三版,对2001年出版的修订版的各章内容均作了较多的修改,基本上能反映当前操作系统发展的现状,但章节名称基

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

微信公众平台开发入门

本套课程的设计完全是为初学者量身打造,课程内容由浅入深,课程讲解通俗易懂,代码实现简洁清晰。通过本课程的学习,学员能够入门微信公众平台开发,能够胜任企业级的订阅号、服务号、企业号的应用开发工作。 通过本课程的学习,学员能够对微信公众平台有一个清晰的、系统性的认识。例如,公众号是什么,它有什么特点,它能做什么,怎么开发公众号。 其次,通过本课程的学习,学员能够掌握微信公众平台开发的方法、技术和应用实现。例如,开发者文档怎么看,开发环境怎么搭建,基本的消息交互如何实现,常用的方法技巧有哪些,真实应用怎么开发。

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

SEIR课程设计源码与相关城市数据.rar

SEIR结合学报与之前博客结合所做的一些改进,选择其中三个城市进行拟合仿真SEIR结合学报与之前博客结合所做的一些改进,选择其中三个城市进行拟合仿真SEIR结合学报与之前博客结合所做的一些改进,选择其

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

Java面试题大全(2020版)

发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了这套Java面试题大全,希望对大家有帮助哈~ 本套Java面试题大全,全的不能再全,哈哈~ 一、Java 基础 1. JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,java 开发工具包,提供了 java 的开发环境和运行环境。 JRE:Java Runtime Environ...

定量遥感中文版 梁顺林著 范闻捷译

这是梁顺林的定量遥感的中文版,由范闻捷等翻译的,是电子版PDF,解决了大家看英文费时费事的问题,希望大家下载看看,一定会有帮助的

GIS程序设计教程 基于ArcGIS Engine的C#开发实例

张丰,杜震洪,刘仁义编著.GIS程序设计教程 基于ArcGIS Engine的C#开发实例.浙江大学出版社,2012.05

人工智能-计算机视觉实战之路(必备算法+深度学习+项目实战)

系列课程主要分为3大阶段:(1)首先掌握计算机视觉必备算法原理,结合Opencv进行学习与练手,通过实际视项目进行案例应用展示。(2)进军当下最火的深度学习进行视觉任务实战,掌握深度学习中必备算法原理与网络模型架构。(3)结合经典深度学习框架与实战项目进行实战,基于真实数据集展开业务分析与建模实战。整体风格通俗易懂,项目驱动学习与就业面试。 建议同学们按照下列顺序来进行学习:1.Python入门视频课程 2.Opencv计算机视觉实战(Python版) 3.深度学习框架-PyTorch实战/人工智能框架实战精讲:Keras项目 4.Python-深度学习-物体检测实战 5.后续实战课程按照自己喜好选择就可以

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

微信小程序开发实战之番茄时钟开发

微信小程序番茄时钟视频教程,本课程将带着各位学员开发一个小程序初级实战类项目,针对只看过官方文档而又无从下手的开发者来说,可以作为一个较好的练手项目,对于有小程序开发经验的开发者而言,可以更好加深对小程序各类组件和API 的理解,为更深层次高难度的项目做铺垫。

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

去除异常值matlab程序

数据预处理中去除异常值的程序,matlab写成

用verilog HDL语言编写的秒表

在秒表设计中,分模块书写。用在七段数码管上显示。输入频率是1KHZ.可以显示百分秒,秒,分。如要显示小时,只需修改leds里的代码和主模块代码。改程序以通过硬件电路验证。完全正确。

[透视java——反编译、修补和逆向工程技术]源代码

源代码。

相关热词 c# 开发接口 c# 中方法上面的限制 c# java 时间戳 c#单元测试入门 c# 数组转化成文本 c#实体类主外键关系设置 c# 子函数 局部 c#窗口位置设置 c# list 查询 c# 事件 执行顺序
立即提问