• Vivado_AXI Quad SPI_IP核


    ZYNQ_FPGA_SPI通信协议多种实现方式
    填一下前面的坑。
    介绍关于Vivado中AXI Quad SPI v3.2的使用方法。
    参考资料:pg153-axi-quad-spi.pdf,可自行在官网下载。
    在这里插入图片描述
    以该IP核的Standard SPI Mode的使用为例。

    Address Space OffsetRegister NameAccess TypeDefault Value (hex)Description
    40hSRRWriteN/ASoftware reset register
    60hSPICRR/W0x180SPI control register
    64hSPISRRead0x0a5SPI status register
    68hSPI DTRWrite0x0SPI data transmit register. A single register or a FIFO
    6ChSPI DRRReadN/ASPI data receive register. A single register or a FIFO
    70hSPISSRR/WNo slave is selected 0xFFFFSPI Slave select register
    74hSPI Transmit FIFO Occupancy RegisterRead0x0Transmit FIFO occupancy register
    78hSPI Receive FIFO Occupancy RegisterRead0x0Receive FIFO occupancy register
    1ChDGIERR/W0x0Device global interrupt enable register
    20hIPISRR/TOW0x0IP interrupt status register
    28hIPIERR/W0x0IP interrupt enable register

    着重介绍使用时所必需的寄存器。
    在这里插入图片描述
    D9:选择数据传输格式LSB first,还是MSB first。默认MSB。
    D8:写0时使能主机传输,写1时禁止。
    D7:选择从机选择方式。写0时由内核控制,写1时由SPISSR寄存器控制。
    D6:写1时复位接收FIFO指针。
    D5:写1时复位发送FIFO指针。
    D4:CPHA。
    D3:CPOL。
    D2: 写0时将SPI配置为从机模式,写1时为主机模式。
    D1:写0时禁用SPI,写1时启用SPI。
    D0:写0时正常,写1时启用loopback模式。

    在这里插入图片描述
    此寄存器的中的N取决于Transfer Width parameter,可设置为8,16,32.
    在这里插入图片描述
    此寄存器中的N为可选择的从机数目,需要使能哪个从机,即在对应位置0。

    IP核配置界面如下图。
    在这里插入图片描述
    各参数含义显而易见,值得注意的是Transaction Widith代表一次传输的数据位宽,Frequency Ratio = ext_spi_clk / sck。

    手册中提供一个编程例子:
    在这里插入图片描述
    第1步,将0x1E6写入SPICR(60h)。0x1E6 = 0001 1110 0110。
    则目前配置为LSB First,禁止主机传输,使用SPI SSR选择从机, 复位 RX FIFO,复位TX FIFO,CPHA=0,CPOL=0,主机模式,使能SPI,正常模式。
    第2步,将0x06写入SPIDTR(68h),0x06即需要传输的8位数据。
    第3步,将0x00写入SPISSR(70h),即拉低SS信号。
    第4步,将0x0E6写入SPICR(60h),将SPICR的D8置0,使能传输。
    第5步,将0x01写入SPISSR(70h),即拉高SS信号。
    第6步,将0x1E6写入SPICR(60h),将SPICR的D8置1,禁用传输。

    若使用PS端只需要调用AXI总线的读写函数,完成上述步骤即可。

    Xil_Out32((BaseAddr) + (u32)(RegOffset), (u32)(Data));
    Xil_In32((BaseAddr) + (u32)(RegOffset));
    
    • 1
    • 2

    若使用PL端则,参考以下仿真时序。
    在这里插入图片描述
    SPI通信前的具体时序如下图,
    在这里插入图片描述
    SPI通信后的具体时序如下图,
    在这里插入图片描述
    从上图结果也可以验证Frequency Ratio = ext_spi_clk / sck。

  • 相关阅读:
    git时出现的若干问题以及解决方案
    学习java第六周总结
    Q&A 云计算实验问题汇总
    (附源码)springboot企业合同管理系统 毕业设计 161456
    SAP 自定义表数据导入程序
    【C++】Windows端VS code中运行CMake工程(手把手教学)
    【C语言】每日一题,快速提升(4)!
    网络基础知识面试题1
    【算法面试题汇总】LeetBook列表的算法面试题汇总---动态规划题目及答案
    24张图攻克border-image
  • 原文地址:https://blog.csdn.net/weixin_44625313/article/details/127903721