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

目录

  • 0 前言
  • 1 平台
    • 1.1开发板资源说明
    • 1.2 如何使用TCA9548A
    • 1.3如何使用EEPROM M24C08
  • 2 主程序
    • 2.1器件初始化
    • 2.2 主要代码

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,连接方式如下,
ZCU102板上PS端的E2PROM读写(XIICPS)_第1张图片
从官方文档ug1182中可以看到PS端IIC连接的详情,该IIC总线同时挂到PS、PL和MP430端,之后又通过两片TCA9548A做设备的扩展或解决IIC从设地址冲突问题。

1.2 如何使用TCA9548A

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

1.3如何使用EEPROM M24C08

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

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)
		 

你可能感兴趣的:(ZYNQ)