xilinx平台中zynq的PS端iic使用

本文主要讲述zynq的iic使用。此IIC只能作为主站,作为从站的不适合本文。

Iic的接口在ps端。(iic的接口在pl端的情况下,不适合本文)

使用软件版本:vivado2018.3

pl端设置:

转载:https://blog.csdn.net/weixin_36590806/article/details/111485711

欢迎转载!

ps端:

1、初始化操作

2、写操作

使用函数“XIicPs_MasterSendPolled(&Iic, senddata, len, addr)”

定义一个u8 senddata[6];

senddata[0] = reg;   寄存器地址

senddata[1] = val; 数据内容

&lic:设备地址,

senddata:寄存器地址和写内容

len:写入数据的长度

addr:是iic器件地址。

3、读操作

XIicPs_MasterRecvPolled(&Iic, val, len, addr);

&lic:设备地址,

Val: 读取的数据内容

len:读取数据的长度

addr:是iic器件地址。

 

对于读函数,需要在注意的地方在于需要根据实际设备的读时序进行封装,直接调用这个函数可能不会成功。

 

在这个时序中可以看出,我们是先发送一个写动作,但没有实际数据写入,然后在发送一个读指令。在sdk中写函数和读函数是分开的,所以我们在读取数据时,可能跟我们在使用模拟iic操作的时候不太一样。

 

unsigned char IIC_read_reg(unsigned char address, unsigned char reg)

{

unsigned char val;

int Status;

unsigned char senddata[6];

senddata[0] = reg;

 

Status = XIicPs_MasterSendPolled(&Iic, senddata, 1, address);

if (Status != XST_SUCCESS)

{

printf("IIC Master integerReg Wirte Failed\r\n");

return XST_FAILURE;

}

while(XIicPs_BusIsBusy(&Iic));

 

Status = (si0_iic_read(&val,2,address));

 

if (Status != XST_SUCCESS)

{

printf("IIC Master integerReg Read Failed\r\n");

return XST_FAILURE;

}

 

return (val);

}

嘻嘻嘻。

posted @ 2020-12-21 19:08  hhh-fpga  阅读(1537)  评论(0编辑  收藏  举报