【ZYNQ Ultrascale+ MPSOC FPGA教程】第二十二章PS端I2C的使用

描述

原创声明:

本原创教程由芯驿电子科技(上海)有限公司(ALINX)创作,版权归本公司所有,如需转载,需授权并注明出处。

适用于板卡型号:

AXU2CGA/AXU2CGB/AXU3EG/AXU4EV-E/AXU4EV-P/AXU5EV-E/AXU5EV-P /AXU9EG/AXU15EG

 

vivado工程目录为“ps_hello/vivado”

vitis工程目录为“ps_i2c/vitis”

软件工程师工作内容

以下为软件工程师负责内容。

从原理图中可以看出,PS端的I2C接了EEPROM。

 

Zynq

 

1. Vitis程序开发

1.1 EEPROM读写

1) 导入emample工程

 

Zynq

 

2) 导入xiicps_eeprom_polled_example工程

 

Zynq

 

EEPROM 的程序比较简单,具体代码大家可以自己去看,这里不详细说了。下面只对程序

的功能和一些要点做一下介绍:

  • EEPROM 的设备地址在程序的前面做了定义,这个地址就是系统访问外部 IIC 外设的设备地址,这里EEPROM地址为 0x54, 相当于 8bit 的 0xA8。

 

Zynq

 

EEPROM 的设备地址可以在 24LC04 的芯片手册上找的到,高 4 位是 A,后面 3 位是 Block地址,因为 24LC04 只有 2 个 Block, 所以高 2 位 Block Address 是无效的。

 

Zynq

 

  • 由于EEPROM的地址为1个字节,在程序中修改如下,并保存编译

 

Zynq

 

3) 程序流程如下:

ReadBuffer清0,WriteBuffer赋FF写16个字节到EEPROM读EEPROM的16个字节到ReadBuffer检验是否正确Readbuffer清0,WriteBuffer赋值10~25写16字节到EEPROM读16字节到ReadBuffer检验是否正确返回

4) 下载程序

 

Zynq

 

5) 串口结果

 

 

 

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

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分