0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

RISC V的I2C操作

XL FPGA技术交流 2024-11-01 11:06 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群


接口处理

top接口

output system_i2c_0_io_sda_writeEnable,

output system_i2c_0_io_sda_write,

input system_i2c_0_io_sda_read,

output system_i2c_0_io_scl_writeEnable,

output system_i2c_0_io_scl_write,

input system_i2c_0_io_scl_read,

soc接口处理

.system_i2c_0_io_sda_write(system_i2c_0_io_sda_write),

.system_i2c_0_io_sda_read(system_i2c_0_io_sda_read),

.system_i2c_0_io_scl_write(system_i2c_0_io_scl_write),

.system_i2c_0_io_scl_read(system_i2c_0_io_scl_read),

WriteEnable信号的处理

I2CSDASCL对应FPGA双向IO,需设置为弱上拉。

I2C对应的三态门的OE信号:需要赋值为I2C SDA/SCLwrite信号;rtl中的表述如下:

主要原因在于:i2c通信过程中,当总线空闲时,两根线均为高电平。连到总线上的任一器件输出的低电平,都将使总线的信号变低,即各器件的SDASCL都是线""关系。

2)引脚在输出信号的同时还将引脚上的电平进行检测,检测是否与刚才输出一致,为"时钟同步""总线仲裁"提供了硬件基础。

assign system_i2c_0_io_sda_writeEnable = !system_i2c_0_io_sda_write;

assign system_i2c_0_io_scl_writeEnable = !system_i2c_0_io_scl_write;

Interface配置示例


I2C寄存器设置

在I2C的设置中第一步是要配置寄存器。寄存器的说明在ds文档中。

tsuData中,1代表10ns;

Timeout中,1表示10ns

tLow和tHigh的1代表10ns




10.1.3 软件部分(Risc V

l I2C通信主要包括以下几个部分:

1、主设备发送起始位(Start

2、主/从发送数据(TxData(注:软件处理时,主发送从设备的地址和读/写位,与发送数据处理方式相同)

3、主/从接收数据(RxData

4、主/从发送应答信号(ACK

5、主设备发送停止位(Stop


l 对应的C函数:

1、主设备发送起始位(Start

i2c_masterStartBlocking(I2C_CTRL);//master send start signal

2、主/从发送数据(TxData

i2c_txByte(I2C_CTRL, 0xC0);//master/slave send data

3、/从接收数据(RxData

i2c_rxData(I2C_CTRL)//master/slave receive data

4、主/从发送应答信号(ACK

i2c_txAckBlocking(I2C_CTRL);//master/slave send ACKi2c_txNackBlocking(I2C_CTRL);//master/slave send NaCK#(不需要发送ACK,但是需要等待一个应答周期的时候,用Nack函数)

5、主设备发送停止位(Stop

i2c_masterStopBlocking(I2C_CTRL);//master send stop

l 小结:

RISC V中提供的关于I2C的函数,相当于把I2C通信过程中各个状态进行了分解的,上述提到的各个函数功能,除了必须通过I2C主设备实现的功能:发送startstop之外,函数本身并没有主从之分;

当需要RISC V中的I2C做从设备时,只需监控总线状态(如是否接收到有效的数据等),同时调用对应的函数,给主设备发送应答信号,根据主设备提供的指令,接收/发送相应的数据即可;

硬件验证平台


原文标题:RISC V的I2C操作

文章出处:【微信公众号:易灵思FPGA技术交流】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1664

    文章

    22502

    浏览量

    639054
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    SGM4541 I2C总线过压保护器:设计与应用的详细解析

    电流(IQ)的I2C总线过压保护器。当SCLA或SDAA引脚的电压超过VCC + 0.69V时,SCLA与SCLB、SDAA与SDAB之间
    的头像 发表于 03-17 16:30 380次阅读

    SGM4541A:I2C总线过压保护的理想之选

    SGM4541A:I2C总线过压保护的理想之选 在电子设备的设计中,I2C总线的稳定运行至关重要。而SGM4541A作为一款低IQ I2C总线过压保护器,凭借其出色的性能和丰富的特性,为I2C
    的头像 发表于 03-17 16:30 209次阅读

    I2C 为什么只要两根线就能搞定通信?

    到目前为止,我们已经讨论了SPI通信和UART通信的基础知识,现在让我们讨论本系列的最后一个协议,即集成电路间协议(I2C)。如果您曾经构建过使用OLED显示器、气压传感器或陀螺仪/加速度计模块
    的头像 发表于 01-04 09:14 2038次阅读
    <b class='flag-5'>I2C</b> 为什么只要两根线就能搞定通信?

    P82B715:I2C总线扩展的得力助手

    )的P82B715,一款专门用于缓冲高电容I2C总线系统的器件,看看它是如何解决这些问题的。 文件下载: p82b715.pdf 1. 器件概述 P82B715是一款支持通过I²C总线进行双向数据传输的器件,它能够缓冲
    的头像 发表于 12-26 10:20 1504次阅读

    基于FPGA的I2C控制模块设计

    I2C_WRITE_WDATA.v模块实现I2C写时序,I2C_Controller (I2C控制器)例化了I2C_WRITE_WDATA.v
    的头像 发表于 12-26 09:48 5922次阅读
    基于FPGA的<b class='flag-5'>I2C</b>控制模块设计

    探索TCA1116:低电压16位I2C I/O扩展器的卓越性能

    时,SDA和SCL仍具有5V容限(泄漏电流1uA),这为电源管理提供了更大的灵活性。同时,它支持1.8VI2C操作,能适应不同的电源
    的头像 发表于 12-24 09:55 989次阅读

    AS32X601的I2C模块操作EEPROM详解

    国科安芯推出的AS32X601系列MCU芯片内置的I2C模块提供了符合工业标准的两线串行制接口,可用于MCU和外部I2C设备的通讯。I2C总线使用两条串行线:串行数据线SDA和串行时钟线SCL
    的头像 发表于 12-21 21:39 1574次阅读
    AS32X601的<b class='flag-5'>I2C</b>模块<b class='flag-5'>操作</b>EEPROM详解

    TCAL6408:8位转换I2C总线/SMBus I/O扩展器的深度剖析

    1.08V至3.6V,支持1.2V、1.8V、2.5V和3.3V
    的头像 发表于 12-16 11:45 1770次阅读

    TCAL6416R:16位转换I2C总线、SMBus I/O扩展器的深度解析

    TCAL6416R的工作电源电压范围为1.08V至3.6V,无论是I2C总线侧(VCCI)还是P端口侧(VCCP)都能适应这一宽电压范围。它支持1.2V、1.8
    的头像 发表于 12-15 17:55 2385次阅读

    I2C死锁的问题

    在实际使用过程中,I2C比较容易出现的一个问题就是死锁 ,死锁在I2C中主要表现为:I2C死锁时表现为SCL为高,SDA一直为低。 在I2C主设备进行读写
    发表于 12-04 06:00

    深入剖析I2C协议

    I2C是由Philips开发的简单的双向两线总线,在深入浅出理解SPI协议中,我们区分了单工,半双工,全双工协议数据流向的区别,根据特征,I2C协议属于半双工协议(即同一时刻,数据单向流动)。此外
    的头像 发表于 08-21 15:10 3876次阅读
    深入剖析<b class='flag-5'>I2C</b>协议

    第十八章 I2C通信测试

    本章介绍了I2C协议,其物理层用SDA和SCL双线,支持多设备:协议层含起始/停止信号、应答机制等。还讲解W55MH32的I2C外设及初始化,并进行了通信测试代码的分析。
    的头像 发表于 06-19 17:07 1463次阅读
    第十八章 <b class='flag-5'>I2C</b>通信测试

    CYPD3177 I2C通信无应答怎么解决?

    SOC端通过I2C与CYPD3177进行通信,在读芯片ID时(0x0002寄存器),主机发送数据后无应答。目前SOC端和CYPD3177只连接了两根I2C线,一根地线和3.3V供电。硬件连接是否有问题?软件配置在读ID前是否需要
    发表于 05-12 07:10

    简单了解I2C接口

    在电子电路的复杂世界里,各种电路模块设备需要相互通信才能协同工作 ,I2C接口就像是电路模块设备间的沟通桥梁,今天就带大家深入了解它。
    的头像 发表于 05-08 14:15 2807次阅读
    简单了解<b class='flag-5'>I2C</b>接口

    基于RT-Thread的I2C(软件) 实践 | 技术集结

    一、软硬件介绍(一)I2C(软件)I2C是一种广泛应用于嵌入式系统中的短距离串行通信协议,支持多主多从设备模式,主机通过时钟信号SCL和数据线SDA与从机进行数据交互。在RT-Thread操作系统中
    的头像 发表于 05-06 18:44 1212次阅读
    基于RT-Thread的<b class='flag-5'>I2C</b>(软件) 实践 | 技术集结