zynq的PL端iic使用

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

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

如果iic的接口在ps端,请看:https://blog.csdn.net/weixin_36590806/article/details/111485711

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

使用软件版本:vivado2018.3

 

先说下PL端的设置吧:

然后设置地址啥的,就不多说了。

开始zynq端的编程了:

貌似不需要初始化的,我的没有经过初始化就可以使用的,可能是因为只当作主站的原因吧。

 

接下来就是写函数

unsigned iic_write(unsigned char iic_base,unsigned char Address, unsigned char *BufferPtr, int ByteCount)
{
    volatile unsigned SentByteCount;
    volatile unsigned AckByteCount;
    u8 WriteBuffer[sizeof(Address) + 16];
    int Index;
    u32 CntlReg;
    char IicAddr;  
    for (Index = 0; Index < ByteCount; Index++) {
        WriteBuffer[sizeof(Address) + Index] = BufferPtr[Index];
    }   
    SentByteCount = XIic_Send(IIC_BASE_ADDRESS, IicAddr,
                  WriteBuffer, sizeof(Address) + ByteCount,
                  XIIC_STOP);   
    return SentByteCount - sizeof(Address);
}

说明下函数的内容:

iic_base:iic的地址,这个可以看原理图,就知道iic的地址

Address:准备写iic的寄存器地址

*BufferPtr:写iic的数据内容

ByteCount:写iic的数据长度

IIC_BASE_ADDRESS:就是这个iic的地址,这个可以从#include "xparameters.h"里面看到。

然后就是读函数了:

unsigned iic_read(unsigned char iic_base,unsigned char Address, unsigned char *BufferPtr, int ByteCount)
{
    volatile unsigned ReceivedByteCount;
    u16 StatusReg;
    u32 CntlReg;
    do {
        StatusReg = XIic_ReadReg(IIC_BASE_ADDRESS, XIIC_SR_REG_OFFSET);
        if(!(StatusReg & XIIC_SR_BUS_BUSY_MASK)) {
            ReceivedByteCount = XIic_Send(IIC_BASE_ADDRESS,
                    iic_base,
                            (u8 *)&Address,
                            sizeof(Address),
                            XIIC_STOP);

            if (ReceivedByteCount != sizeof(Address)) {


                CntlReg = XIic_ReadReg(IIC_BASE_ADDRESS,
                            XIIC_CR_REG_OFFSET);
                XIic_WriteReg(IIC0_BASE_ADDRESS, XIIC_CR_REG_OFFSET,
                        CntlReg | XIIC_CR_TX_FIFO_RESET_MASK);
                XIic_WriteReg(IIC0_BASE_ADDRESS,
                        XIIC_CR_REG_OFFSET,
                        XIIC_CR_ENABLE_DEVICE_MASK);
            }
        }

    } while (ReceivedByteCount != sizeof(Address));/* Send is aborted so reset Tx FIFO */


    ReceivedByteCount = XIic_Recv(IIC_BASE_ADDRESS, iic_base,
                    BufferPtr, ByteCount, XIIC_STOP);
    return ReceivedByteCount;
}
说明下函数的内容:

iic_base:iic的地址,这个可以看原理图,就知道iic的地址

Address:准备读iic的寄存器地址

*BufferPtr:读到iic的数据内容。

ByteCount:读iic的数据长度

 

以上就是pl端iic的使用了,这样就可以愉快的使用了。嘻嘻嘻。

 

posted @ 2021-01-19 20:11  hhh-fpga  阅读(1104)  评论(0编辑  收藏  举报