PYNQ Z2二:第一个工程

2023-10-11 14:30
文章标签 第一个 工程 z2 pynq

本文主要是介绍PYNQ Z2二:第一个工程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PYNQ Z2二:第一个工程

  • Hello World
    • 介绍
    • 下载安装vivado
    • 建立第一个工程
      • 添加PYNQ-Z2的配置信息
      • 添加引脚约束文件XDC
    • 串口通讯

Hello World

PYNQ Z2端通过串口输出的PC端

介绍

PYNQ Z2使用的是jupyter_notebooks在线Python开发,但是,PYNQ脱胎于ZYNQ,其基本架构依然延续ZYNQ。本人没有开发ZYNQ的经验,所以,为了更深入的了解PYNQ Z2的内部机制,先学习了ZYNQ的开发,在总结了各路大牛的博客之后,在 ALINX_ZYNQ开发平台基础教程V1.02 第四章:PL的“Hello World”LED实验的指导下,完成了本次实验,因为PYNQZYNQ终归是有些区别的,在具体实验过程中要懂得灵活做出改动。

下载安装vivado

个人建议前往官网下载
本人下载的当前最新版本2019.1
vivado下载

图1:vivado2019.1下载

先下载WebPACK,要注册账号,和填一些下载信息

安装文件

图2:安装文件

下载完成后如上图所示,直接运行,账号登陆,可以选择边下载边安装也可以下载独立完整的安装包,本人选择的是下载独立完整的安装包。下载速度稳定在4M左右,而网上其他的下载链接一般是百度云盘,下载速度在几M到几百K变动,相对于上述方法慢了一点。而且本人尝试从其他地方下载WebPACK再下载2018.1失败了两次,通过官网下载一次成功。下载完毕后的安装参考虚无缥缈vs威武的博客。
本人一次就安装成功了,但是接下来出问题了,简单描述一下。
应用图标

图3:应用图标

安装完成后如图3所示。
操作系统规格

图4:操作系统规格

系统版本如图4所示,除了DocNav外其他都打不开,在网上看了很多攻略,但是参考意义较小。
报错提示

图5:运行报错提示

报错如上图所示,经过大量的实验后发现,鼠标右键->以管理员身份运行就可以打开了,或者打开CMD界面,将图标拖拽进去Enter也可以打开,真是简单到想哭。

建立第一个工程

本次实验很大程度参考了Mculover666的博客因此有部分内容会省略,以避免重复。

添加PYNQ-Z2的配置信息

将PYNQ-Z2文件夹添加到下面的根目录下,安装目录不同而不同
E:\Xilinx\Vivado\2019.1\data\boards\board_files重新打开vivado软件即可。
PYNQ-Z2文件夹内部文件

图6:PYNQ-Z2文件夹内部文件

如图6所示为PYNQ-Z2文件夹内部文件。

添加引脚约束文件XDC

官网下载链接

实验具体步骤参考
ALINX_ZYNQ开发平台基础教程V1.02 第四章:PL的“Hello World”LED实验,需要注意的有以下几点:

XDC存储的是对工程的管脚约束和时许约束,本人在添加完XDC文件后因为第一次使用vivado所以对XDC的用途不是很清楚,所以添加完XDC文件后直接跑synthesis、implementation和generate bitstream

本人在这里弄了很久都不行,最后本人通过引脚连接自己编写XDC文件才成功生成ledbit文件。

LED引脚定义1

图7:LED引脚定义1

LED引脚定义2

图8:LED引脚定义2

LED引脚定义3

图9:LED引脚定义3

LED引脚定义4

图10:LED引脚定义4

如上图7、8、9、10所示是PYNQ-Z2的引脚定义,进行管脚约束和时许约束后的XDC文件如图11所示:

XDC文件

图11:XDC文件

虽然最后成功了,但是一直不知道前面哪里出错了,好难受。

串口通讯

串口对应的引脚号

图12:串口对应的引脚号

串口对应的引脚号。为《MIO14、MIO15》
补充:通过Board File中的part0_pin文件可以很轻松的查询到PYNQ-Z2的引脚定义,如图13所示:
board file

图13:Board File中的part0_pin文件

UART0

图14:根据引脚定义选择合适的UART0

这里我们选择UART0,如上图14所示.

硬件设计的信息

图15:硬件设计的信息

Launch SDK后可以看到硬件设计的信息,包括目标芯片型号,设计软件版本和设计日期,还有可供开发使用的PS端外设的寄存器列表。

注:每次修改SDK中的C文件后都要Save All并Project->Build All,代码无错误,编译通过才可以写入,否则会写入上一次的程序。

打印

图16

如图16所示,在修改三次代码后才编译通过,写入成功。

修改后的代码

图17:修改后的代码

如图所示为修改后的代码,打印不同进制数。

这篇关于PYNQ Z2二:第一个工程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/188708

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数

Spring Roo 实站( 一 )部署安装 第一个示例程序

转自:http://blog.csdn.net/jun55xiu/article/details/9380213 一:安装 注:可以参与官网spring-roo: static.springsource.org/spring-roo/reference/html/intro.html#intro-exploring-sampleROO_OPTS http://stati

使用gradle做第一个java项目

涉及到的任务如下: assemble任务会编译程序中的源代码,并打包生成Jar文件,这个任务不执行单元测试。 Total time: 5.581 secs E:\workspace\Test>gradle assemble :compileJava :processResources UP-TO-DATE :classes :findMainClass :jar :b

vue2实践:第一个非正规的自定义组件-动态表单对话框

前言 vue一个很重要的概念就是组件,作为一个没有经历过前几代前端开发的我来说,不太能理解它所带来的“进步”,但是,将它与后端c++、java类比,我感觉,组件就像是这些语言中的类和对象的概念,通过封装好的组件(类),可以通过挂载的方式,非常方便的调用其提供的功能,而不必重新写一遍实现逻辑。 我们常用的element UI就是由饿了么所提供的组件库,但是在项目开发中,我们可能还需要额外地定义一

二、Maven工程的创建--JavaSEJavaEE

1、idea创建Maven JavaSE工程:  2、idea创建Maven JavaEE工程:   (1)手动创建 (2)插件方式创建 在idea里安装插件JBLJavaToWeb; 选择需要生成的项目文件后,右击: 项目的webapp文件夹出现小蓝点,代表成功。

三、Maven工程的构建

首先,创建和构建是两个概念。 构建是指将源代码、依赖库和资源文件等转换为可执行或可部署的应用程序的过程。 在这个过程中包括编译源代码、链接依赖库、打包和部署等多个步骤。 项目构建是软件开发过程中至关重要的一部分,它能够大大提高软件开发效率,使得开发人员更加专注于应用程序的开发和维护,而不必关心应用程序的构建细节。 同时,项目构建还能将多人写的代码聚合,并能够自动化项目的构建和部署,

SpringMVC的第一个案例 Helloword 步骤

第一步:web.xml配置 <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocati

我在高职教STM32——准备HAL库工程模板(1)

新学期开学在即,又要给学生上 STM32 嵌入式课程了。这课上了多年了,一直用的都是标准库来开发,已经驾轻就熟了。人就是这样,有了自己熟悉的舒适圈,就很难做出改变,老师上课也是如此,排斥新课和不熟悉的内容。显然,STM32 的开发,HAL 库已是主流,自己其实也在使用,只不过更换库就意味着教学内容有很大变化,自己也就迟迟没有迈出调整这一步。现在,是时候做出变化了,笔者计划保持教学项