码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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。

  • 相关阅读:
    (十四)线程(基础)
    [算法刷题笔记]二叉树练习(3)完全二叉树的节点个数
    「 安全工具介绍 」软件成分分析工具Black Duck,业界排名TOP 1的SCA工具
    程序员的 100款代码表白特效,一个比一个浪漫
    如何使用Docker部署Nacos服务?Nacos Docker 快速部署指南: 一站式部署与配置教程
    9. Spring Boot外部配置文件
    关于Arxiv使用的一些方法
    JAVA独龙族民族特色服务网站计算机毕业设计Mybatis+系统+数据库+调试部署
    一文深度了解估值最高量子初创企业!PsiQuantum的愿景、技术及合作
    计算机毕业设计Java大众采编本微资讯发布平台(源码+系统+mysql数据库+lw文档)
  • 原文地址:https://blog.csdn.net/weixin_44625313/article/details/127903721
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号