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
    +关注

    关注

    1628

    文章

    21721

    浏览量

    602859
收藏 人收藏

    评论

    相关推荐

    I2C协议的基础知识

    本文从I2C协议的概述开始,描述协议的历史、不同速度模式、物理层和数据帧结构,最后介绍I2C混合电压系统中电平兼容性以及上拉电阻大小计算。
    的头像 发表于 10-22 15:51 453次阅读
    <b class='flag-5'>I2C</b>协议的基础知识

    使用USCI I2C主站

    电子发烧友网站提供《使用USCI I2C主站.pdf》资料免费下载
    发表于 10-21 09:30 0次下载
    使用USCI <b class='flag-5'>I2C</b>主站

    I2C噪声毛刺滤波

    电子发烧友网站提供《I2C噪声毛刺滤波.pdf》资料免费下载
    发表于 10-08 14:39 5次下载
    <b class='flag-5'>I2C</b>噪声毛刺滤波

    了解I2C总线

    电子发烧友网站提供《了解I2C总线.pdf》资料免费下载
    发表于 10-08 11:13 2次下载
    了解<b class='flag-5'>I2C</b>总线

    I2C基本指南

    电子发烧友网站提供《I2C基本指南.pdf》资料免费下载
    发表于 09-10 09:40 0次下载
    <b class='flag-5'>I2C</b>基本指南

    CAN转I2C桥接器

    电子发烧友网站提供《CAN转I2C桥接器.pdf》资料免费下载
    发表于 08-28 11:10 0次下载
    CAN转<b class='flag-5'>I2C</b>桥接器

    UART转I2C桥接器

    电子发烧友网站提供《UART转I2C桥接器.pdf》资料免费下载
    发表于 08-28 09:24 1次下载
    UART转<b class='flag-5'>I2C</b>桥接器

    使用C2000 I2C模块连接EEPROM

    电子发烧友网站提供《使用C2000 I2C模块连接EEPROM.pdf》资料免费下载
    发表于 08-27 09:53 0次下载
    使用<b class='flag-5'>C</b>2000 <b class='flag-5'>I2C</b>模块连接EEPROM

    简单认识I2C通信协议

    I2C(Inter-Integrated Circuit)通信协议是由飞利浦公司(现为恩智浦半导体)开发的一种简单、双向二线制同步串行总线协议。自1982年发布以来,I2C协议因其高效、灵活和易于实现的特点,在电子设备间的数据交换中得到了广泛应用。以下是对
    的头像 发表于 07-25 18:06 1419次阅读

    I2C逻辑选型指南

    电子发烧友网站提供《I2C逻辑选型指南.pdf》资料免费下载
    发表于 06-20 16:20 2次下载

    如何通过cyusb3014的i2c操作界面操作ads1119的i2c接口?

    我使用 cyusb3014 作为 i2c 设备的主机,并使用 ads1119 采集电压。 我需要使用 i2c 操作相关指令。 例子中提供的示例只显示了读写步骤,即 dev_ Addr+reg_
    发表于 05-23 07:30

    什么是I2C协议 I2C总线的控制逻辑

    在实际使用过程中,I2C比较容易出现的一个问题就是死锁 ,死锁在I2C中主要表现为:I2C死锁时表现为SCL为高,SDA一直为低。
    发表于 03-12 09:17 1034次阅读
    什么是<b class='flag-5'>I2C</b>协议 <b class='flag-5'>I2C</b>总线的控制逻辑

    i2c接口由哪几根线组成 i2c接口可以接哪些器件

    I2C接口的线路可以适应不同的系统需求和器件规格,因此具体的线路配置可能会有所不同。但通常来说,时钟线(SCL)和数据线(SDA)是I2C接口的核心线路。
    的头像 发表于 03-05 16:55 3744次阅读
    <b class='flag-5'>i2c</b>接口由哪几根线组成 <b class='flag-5'>i2c</b>接口可以接哪些器件

    GD32 MCU硬件I2C不可靠不如软件I2C?来看看红枫派开发版的硬件I2C驱动如何做到稳得一批

    在一个评论中,看到网友对硬件I2C的讨论,硬件I2C Busy找不到原因、软件I2C稳得一批。
    的头像 发表于 02-23 09:37 2775次阅读
    GD32 MCU硬件<b class='flag-5'>I2C</b>不可靠不如软件<b class='flag-5'>I2C</b>?来看看红枫派开发版的硬件<b class='flag-5'>I2C</b>驱动如何做到稳得一批

    i2c工作原理及使用方法

    I2C(Inter-Integrated Circuit)是一种串行通信协议,用于在集成电路(IC)之间传输数据。它由Philips公司(今天的NXP半导体)于1982年开发,现在已经成为一种通用
    的头像 发表于 12-19 16:17 1281次阅读