zynq 7000 的 iic 外设编程

本文主要介绍zynq 7000下的i2c ps 外设编程。实验是在vivado 2018.3 上完成的。

本实验的前提条件是你已经做过了zynq 7000的helloworld sdk 实验。一般开发板的厂家都提供了的,一些设置与所用硬件有关,也可参考我的博客 petalinux 2018.2 下的helloworld 实验

I2C总线简介

I2C总线是由Philips公司开发的一种简单、双向二线制同步串行总线。它只需要两根线即可在连接于总线上的器件之间传送信息。I2C总线上分成主机和从机两种设备。

     主机用于启动总线传送数据并产生时钟以同步从机,此时任何被寻址的器件均被认为是从器件.在总线上主机和从机、发送和接收的关系不是恒定的,而取决于此时数据传送方向。如果主机要发送数据给从器件,则主机首先寻址从器件,然后主动发送数据至从器件,最后由主机终止数据传送;如果主机要接收从器件的数据,首先由主器件寻址从器件.然后主机接收从器件发送的数据,最后由主机终止接收过程。在这种情况下.主机负责产生定时时钟和终止数据传送。

SDA(串行数据线)和SCL(串行时钟线)都是双向I/O线,接口电路为开漏输出,需通过上拉电阻接电源VCC。当总线空闲时.两根线都是高电平,连接总线的外同器件都是CMOS器件,输出级也是开漏电路.在总线上消耗的电流很小,因此,总线上扩展的器件数量主要由电容负载来决定,因为每个器件的总线接口都有一定的等效电容.而线路中电容会影响总线传输速度.当电容过大时,有可能造成传输错误.所以,其负载能力为400pF,因此可以估算出总线允许长度和所接器件数量。

zynq 7000的I2C

在zynq 7000中有2种方式可以控制iic(I2C)外设,一种是利用zynq 7000的 PS 外设i2c ,还有一种是axi4-i2c IP。 我认为前面简单一点,所以采用的前面那种方式。

在vivao 里打开以前设计的helloworld 工程,或者其他工程,没有就先做一个,打开原理图设计(open block design),双击zynq 打开zynq设置。

在设置界面

  • 5
    点赞
  • 59
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
Zynq是一种基于FPGA和ARM处理器的集成电路平台,用于实现嵌入式系统的设计。配置IIC(Inter-Integrated Circuit)是在Zynq平台上实现IIC总线通信的过程。 首先,我们需要在Zynq平台上配置IIC控制器。在Vivado集成开发环境中,可以使用Block Design进行配置。将Zynq的处理系统与相应的IIC控制器连接起来,在系统设计中添加AXI IIC IP核,然后根据需要设置IIC控制器的参数,如时钟频率、传输模式等。 接下来,我们需要在嵌入式软件中编写代码来配置IIC控制器和进行IIC通信。在Zynq平台上,可以使用Xilinx提供的开发套件SDK来进行编程。首先,在Vivado中生成.bit文件并导出硬件,然后打开SDK进行嵌入式软件开发。在工程中,创建一个新的C工程或修改已有的工程,添加IIC控制器的驱动文件,并根据需要编写相关代码。 在软件代码中,我们可以使用IIC控制器的驱动程序接口来配置IIC控制器、发送和接收数据。例如,可以使用函数如"XIicPs_Config *"来获取IIC控制器的默认配置,然后使用函数如"XIicPs_CfgInitialize"初始化IIC控制器。接下来,使用函数如"XIicPs_SetOptions"设置IIC控制器的传输选项,如时钟频率、地址重复模式等。最后,使用函数如"XIicPs_MasterSendPolled"和"XIicPs_MasterRecvPolled"发送和接收数据。 在配置完成后,我们可以使用适当的硬件连接和电路设计来连接Zynq平台上的IIC控制器。使用合适的IIC设备(如传感器、显示器、存储器等)连接IIC总线,然后根据IIC设备的规格和要求进行通信。 总之,通过在Zynq平台上配置IIC控制器,编写软件代码并进行硬件连接,我们可以实现Zynq与其他IIC设备之间的通信。这样,我们可以在嵌入式系统中利用IIC总线来传输数据和与其他设备进行交互。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值