软件模拟I2C和硬件直接驱动I2C读取TCA95系列I2C转IO芯片分析

问题描述:

软件读取I2C转IO信号跳变,低电平时能读到高电平信号,高电平时能读到低电平信号,正确信号和错误信号的比值约10:1。

原因分析:

I2C芯片的驱动底层采用了软件模拟实现,没有防错机制,读取结果不确定。

解决方法:

修改I2C芯片驱动,改软件模拟I2C为硬件外设驱动。同时对读取的信号进行连续判读,消除读取的抖动。

详细分析:

软件模拟I2C的逻辑分析仪采样如下,可见时钟信号分布不均匀,对SDA信号的采样实际是依赖GPIO单次采样判断输入信号,无滤波处理时容易抖动。

c 复制代码
//初始化IIC
void IIC_Init(void)
{					     
	GPIO_InitTypeDef GPIO_InitStructure;
	RCC_APB2PeriphClockCmd(	RCC_APB2Periph_GPIOB, ENABLE );	//使能GPIOB时钟
	   
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6|GPIO_Pin_7;
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP ;   //推挽输出
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOB, &GPIO_InitStructure);
	GPIO_SetBits(GPIOB,GPIO_Pin_6|GPIO_Pin_7); 	//PB6,PB7 输出高
}
//读1个字节,ack=1时,发送ACK,ack=0,发送nACK   
u8 IIC_Read_Byte(unsigned char ack)
{
	unsigned char i,receive=0;
	SDA_IN();//SDA设置为输入
    for(i=0;i<8;i++ )
	{
        IIC_SCL=0; 
        delay_us(2);
		IIC_SCL=1;
        receive<<=1;
        if(READ_SDA)receive++;   
		delay_us(1); 
    }					 
    if (!ack)
        IIC_NAck();//发送nACK
    else
        IIC_Ack(); //发送ACK   
    return receive;
}

硬件I2C的逻辑分析仪采样如下,可见时钟信号分布均匀,对SDA信号的采样实际是依赖I2C外设判断输入信号,外设自带滤波处理能消除抖动。

而且软件模拟I2C需要占用CPU时间,一次通信约有数百微秒延时,硬件I2C则可以采用中断、DMA等方式做到无延时,释放CPU性能。

相关推荐
Fpga_User17 分钟前
基于Zynq UltraScale+的FLASH固化问题记录
嵌入式硬件·fpga开发
炸膛坦客18 分钟前
单片机/C语言八股:(十二)C 语言中 malloc 和 free 用法(动态分配内存)
c语言·单片机·嵌入式硬件
国产电子元器件20 分钟前
超充时代来了,大电流检测技术面临什么挑战?
嵌入式硬件
炸膛坦客31 分钟前
单片机/C语言八股:(十一)指针的补充,包括指针的类型和大小
c语言·开发语言·单片机
单片机设计星球1 小时前
51单片机的【智能火灾报警系统】仿真设计
单片机·嵌入式硬件·51单片机
Saniffer_SH1 小时前
【每日一题】PCIe链路协商的时候进入Polling compliance如何排错?
服务器·人工智能·驱动开发·嵌入式硬件·测试工具·fpga开发·自动化
浩子智控1 小时前
航天高可靠性设备开发—抗辐射
嵌入式硬件·fpga开发·硬件工程
Zaki_gd1 小时前
【MCU】- MCU开发中RTOS与裸机开发深度对比分析
单片机·嵌入式硬件
freemote1 小时前
单极性霍尔开关OH3144/OH44E
stm32·单片机·霍尔传感器·oh3144/oh44e·单极性霍尔开关
易水寒陈2 小时前
单片机的工厂方法模式和桥接模式结合使用
单片机·桥接模式·工厂方法模式