ZCU102板上PS端的E2PROM读写(XIICPS)

0 前言

之前介绍了AXI_IIC的使用,这次为了直接使用ZCU102板上PS端的E2PROM,重新介绍下XIICPS的使用。
附上AXI_IIC的使用教程链接:https://blog.csdn.net/u013098336/article/details/99694145

1 平台

Vivado 2017.4
Windows 10
ZCU102开发板

1.1开发板资源说明

此次开发的项目直接使用开发板做主板,系统参数需要存储,ZCU102开发板上刚好有一个EEPROM,连接方式如下,
在这里插入图片描述
从官方文档ug1182中可以看到PS端IIC连接的详情,该IIC总线同时挂到PS、PL和MP430端,之后又通过两片TCA9548A做设备的扩展或解决IIC从设地址冲突问题。

1.2 如何使用TCA9548A

TCA9548A很简单,可以理解成一个开关,共8路可控,使能相应位后TCA9548A对应通道上的设备就挂到了总线上,使用前写入一次控制寄存器,之后就不用管了,除非是解决地址冲突问题,就需要反复写。
具体内容可以参照其手册,在这里就不赘述了。

1.3如何使用EEPROM M24C08

本次挂在总线上进行读写的EEPROM设备是M24C08,使用之前要对其工作机制进行了解,具体内容同样是参照手册,下面截取一些关键内容方便大家理解。
在这里插入图片描述
上图为其写入时序,可以单字节写,也可以以page为单位写,page一次为8字节,其中Byte Address为存储器地址,8位总共为256字节,但该芯片容量为1kB,其他空间如何寻址,让我百思不得其解,后来读手册加试验,终于搞明白了了,看下面两张图,第一张为EEPROM IIC接口地址,其中b1 b2 充当了Address的高两位,这样和Address byte 组合起来就有10位,就可以表示1kB字节了
在这里插入图片描述
在这里插入图片描述

2 主程序

2.1器件初始化

使用前先对ps端iic接口进行初始化,在这里就不赘述了,具体可以参考其他设备的初始化过程或者参考软件自带的demo。
有一点要说的是,一般采用中断的方式都会有回调函数

void XIicPs_SetStatusHandler(XIicPs *InstancePtr, void *CallBackRef,
				  XIicPs_IntrHandler FunctionPtr)
  • The handler is called within interrupt context, so it should finish its work quickly.

2.2 主要代码

采用中断方式,EEPROM读写主要使用以下两个函数,一个读一个写,用起来很简单也很方便,具体用法自己工程搭起来试一下就知道了,每人的问题不一样,我这里说多了也没用,不过欢迎大家留言讨论,我很愿意尽自己努力为大家解答。

/*
其中MsgPtr第一个数据应为寄存器地址,具体参照上图IIC的时序图,ByteCount应为实际要写的字节数+地址字节数
*/
void XIicPs_MasterSend(XIicPs *InstancePtr, u8 *MsgPtr, s32 ByteCount,
		 u16 SlaveAddr)
/*
读之前应先调用写函数写入要读的寄存器地址,否则读到的是默认的当前地址
*/		 
void XIicPs_MasterRecv(XIicPs *InstancePtr, u8 *MsgPtr, s32 ByteCount,
		 u16 SlaveAddr)
		 
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值