ZYBO-Z7开发板的PYNQ框架移植(PYNQ镜像制作)

2023-10-25 17:30

本文主要是介绍ZYBO-Z7开发板的PYNQ框架移植(PYNQ镜像制作),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

**

ZYBO-Z7开发板的PYNQ框架移植(PYNQ镜像制作)

**
PYNQ官方给出SD img 文件的开发板目前有三块:PYNQ-Z1,PYNQ-Z2以及ZCU104。笔者所用的开发板为ZYBO-Z7,需要自己生成SD卡的img来实现PYNQ功能。

参考:https://blog.csdn.net/qq575542641/article/details/89155521

一: 基本框架搭建
框架搭建基于Ubuntu16.04,此处注意18.04版本在框架移植方面仍存在问题,建议使用16.04版本。笔者电脑用的是Win10系统,所以采用VMware虚拟机进行SD img 文件的生成,同时虚拟机方便操作过程中的文件拷贝,同样用Windows系统的朋友们建议采用这种方法。注意虚拟机的内存设置尽量大一些,避免在之后镜像生成中报错,笔者用2g内存出现过镜像生成失败的情况。

安装好Ubuntu系统后建议先更换软件源,在system setting中选择Software&Updates,这里笔者用的是中科大的软件源
在这里插入图片描述

完成后我们正式开始环境搭建

1. 基本库环境:
修改shell环境,

sudo dpkg-reconfigure dash

此处注意一定要选择no,否则会导致之后petalinux安装失败

sudo apt-get install -y gcc git make net-tools libncurses5-dev tftpd zlib1g-dev libssl-dev \
flex bison libselinux1 gnupg wget diffstat chrpath socat xterm autoconf libtool tar unzip \
texinfo zlib1g-dev gcc-multilib build-essential libsdl1.2-dev libglib2.0-dev zlib1g:i386 \
screen pax gzip
sudo apt-get install tofrodos gawk xvfb zlib1g-dev:i386
sudo apt-get install tftpd-hpa
sudo chmod a+w /var/lib/tftpboot/

2.Xilinx基本环境安装
为了完成 img 生成,这里需要安装的软件包括:Petalinux,Vivado以及Vivado SDK。另需要板级镜像文件:bionic.arm.2.3.img。这里注意一下版本号的对应关系:
pynq_rootfs_arm_v2.3下载地址:离线镜像在这里插入图片描述
笔者所用的Vivado为2018.2版本,所对应的板级镜像即为v2.3版本,以此类推。

首先进入管理员权限来生成文件夹

sudo -s
mkdir -p /opt/pkg/petalinux/2018.2

同时为生成的文件夹赋予权限,同样与之后Petalinux的成功安装有关:

chown <your_user_name> /opt/pkg/
chown <your_user_name> /opt/pkg/petalinux
chown <your_user_name> /opt/pkg/petalinux/2018.2
chgrp <your_user_name> /opt/pkg/
chgrp <your_user_name> /opt/pkg/petalinux
chgrp <your_user_name> /opt/pkg/petalinux/2018.2

之后exit命令退出管理员模式

将下载好的Petalinux安装包复制到虚拟机(例:Downloads文件夹)
在这里插入图片描述
在对应的文件中右键打开终端(或cd命令到含有安装包的文件夹)
首先赋予执行权限:

sudo chmod +x petalinux-v2018.2-final-installer.run

之后运行安装包安装到指定路径

./petalinux-v2018.2-final-installer.run /opt/pkg/petalinux/2018.2

Ubuntu系统中准备好Vivado安装包
与前面的安装过程相同,在对应文件夹右键终端输入:

sudo ./xsetup

安装路径选择默认的 /opt/Xilinx/ ,安装完成后会自动生成对应的Vivado和SDK文件夹
终端中对执行所属权进行修改

sudo chmod 777 -R /opt/Xilinx/
sudo chmod 777 -R ~/.Xilinx/

3.PYNQ组件下载

  1. 下载开发包
git clone https://github.com/Xilinx/PYNQ.git
cd PYNQ
git checkout v2.3
git checkout -b ZYBO-Z7
  1. 重要:检测安装依赖库环境
    依次进入下载好的 /PYNQ/sdbuild/scripts/
    运行setup_host.sh
chmod +x setup_host.sh
./setup_host.sh
  1. 成功后通过终端打开编辑shell环境文件
sudo gedit  ~/.bashrc

在打开的文档末尾追加:

source /opt/pkg/petalinux/2018.2/settings.sh
source /opt/Xilinx/Vivado/2018.2/settings64.sh
source /opt/Xilinx/SDK/2018.2/settings64.sh
export PATH=/opt/qemu/bin:/opt/crosstool-ng/bin:$PATH
  1. 进入文件夹 /opt/crosstool-ng/lib/crosstool-ng-1.22.0/scripts/build/libc/
    打开文件newlib.sh
    将"{http://mirrors.kernel.org/sourceware/newlib,
    ftp://sourceware.org/pub/newlib}"
    改为 “ftp://sourceware.org/pub/newlib"或者"http://mirrors.kernel.org/sourceware/newlib”
    如图:
    在这里插入图片描述
  2. 源文件修改
    因为笔者并没有安装SDx环境,所用进入 /PYNQ/sdbuild/ 文件夹,打开Makefile
    删除如下内容:
which sdx | fgrep ${KERNEL_VERSION}

环境搭建完成

二:soc系统构建
为了完成PYNQ的SD img的成功生成,我们需要的材料有:
1.rootfs文件(不含内核信息的镜像,可以加速生成过程)其中ZYNQ7000采用的是arm镜像,ZYNQ UltraScale+采用的为aarch64镜像
2.开发板的板级描述文件,具体可分为两种形式:
1.直接提供bsp文件;
2.提供bit文件和hdf文件
具体可见PYNQ官网介绍:
在这里插入图片描述
这里我们采用第二种方法。

Vivado工程建立

  1. 新建Vivado工程,板卡选择ZYBO-Z7开发板
  2. Create Block design,添加ZYNQ7000 IP核,点击Run Block Automation
  3. 双击ZYNQ7000对IP核进行配置(如图)需要注意保证SD,enet以及gpio端口使能
  4. Create HDL Wrapper之后生成bit流
  5. export hardware(注意勾选include bitstream)
    在这里插入图片描述

三:框架移植
1.板级描述文件的准备
在上一步床创建的Vivado工程目录中找到
<project_name>.runs\impl_1<project_name>_wrapper.bit
<project_name>.sdk<project_name>_wrapper.hdf
其中<project_name>为你在Vivado中所命名的工程名
修改二者文件名为base.bit 以及system.hdf
其中bit流文件用于FPGA配置,hdf文件用于对已建立的Soc系统进行描述

2.ZYBO-Z7镜像构建

  1. 在 /PYNQ/sdbuild/ 目录下新建文件夹 ‘prebuilt’
    将bionic.arm.2.3.img文件拷贝至该文件夹
  2. 在 /PYNQ/boards/ 目录下新建文件夹 ‘ZYBO-Z7’
  3. 在 ZYBO-Z7 中再新建两个文件夹分别为 base 和petalinux_bsp
  4. 在 petalinux_bsp 中再建立文件夹 hardware_project
  5. 分别将base.bit拷贝到base;system.hdf拷贝到hardware_project
  6. 复制/boards/PYNQ-Z2中的 .spec文件至ZYBO-Z7下并修改文件夹名为ZYBO-Z7.spec
  7. 打开ZYBO-Z7.spec,修改内容如下
ARCH_${BOARD} := arm
BSP_${BOARD} := 
BITSTREAM_${BOARD} := base/base.bit
STAGE4_PACKAGES_Pynq-Z2 := pynq  ethernet

返回 /PYNQ/sdbuild/ 打开终端

make BOARDS=ZYBO-Z7 \
PREBUILT=./prebuilt/bionic.arm.2.3.img

等待img文件生成完成。

3.烧写SD卡
将 /sdbuild/output 目录下生成的.img复制至Windows

下载并使用 Win32DiskImager将镜像烧写至SD卡(至少8g)上
烧写完成后将U盘重新接入Ubuntu虚拟机,注意查看分区内容,FAT32分区是否存在BOOT.bin以及image.ub文件。如果没有将 /PYNQ/sdbuild/output/boot/ 文件夹下对应的文件拷贝至这一分区。
烧写失败需还原SD卡请参考SD卡还原

4.SD 卡测试
将烧录完成的SD卡插入板卡中,接通网线,并上电启动。
建议采用Xshell进行端口交互
出现下图即说明启动成功在这里插入图片描述
在这里插入图片描述
恭喜你,你的ZYBO板以及拥有自己的Linux系统了,现在可以用ifconfig命令查看一下
在这里插入图片描述
这里笔者遇到过第一次上电启动检测不到eth0连接的问题,解决方法如下:
首先进入管理员模式

sudo -s

使能eth0

ifconfig eth0 up

为eth0分配IP地址,这里需要查看自己计算机的ip,确保二者在同一网段

ifconfig eth0 192.168.1.223 netmask 255.255.255.0

完成后退出管理员模式,再次ifconfig即可查看到eth0

框架移植完成

附录:

四:Jupyter Notebook的使用
在端口中输入jupyter notebook
在这里插入图片描述
复制红线部分,打开浏览器,粘贴,修改localhost:8888部分为 <your_ZYBO_IP_address>:9090 即可访问jupyter notebook
在这里插入图片描述
另:
文件夹路径输入\PYNQ\Xilinx可以直接访问板上文件在这里插入图片描述

Fin

这篇关于ZYBO-Z7开发板的PYNQ框架移植(PYNQ镜像制作)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Docker镜像pull失败两种解决办法小结

《Docker镜像pull失败两种解决办法小结》有时候我们在拉取Docker镜像的过程中会遇到一些问题,:本文主要介绍Docker镜像pull失败两种解决办法的相关资料,文中通过代码介绍的非常详细... 目录docker 镜像 pull 失败解决办法1DrQwWCocker 镜像 pull 失败解决方法2总

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Python GUI框架中的PyQt详解

《PythonGUI框架中的PyQt详解》PyQt是Python语言中最强大且广泛应用的GUI框架之一,基于Qt库的Python绑定实现,本文将深入解析PyQt的核心模块,并通过代码示例展示其应用场... 目录一、PyQt核心模块概览二、核心模块详解与示例1. QtCore - 核心基础模块2. QtWid

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统

使用国内镜像源优化pip install下载的方法步骤

《使用国内镜像源优化pipinstall下载的方法步骤》在Python开发中,pip是一个不可或缺的工具,用于安装和管理Python包,然而,由于默认的PyPI服务器位于国外,国内用户在安装依赖时可... 目录引言1. 为什么需要国内镜像源?2. 常用的国内镜像源3. 临时使用国内镜像源4. 永久配置国内镜

QT移植到RK3568开发板的方法步骤

《QT移植到RK3568开发板的方法步骤》本文主要介绍了QT移植到RK3568开发板的方法步骤,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录前言一、获取SDK1. 安装依赖2. 获取SDK资源包3. SDK工程目录介绍4. 获取补丁包二

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization

SpringBoot集成图片验证码框架easy-captcha的详细过程

《SpringBoot集成图片验证码框架easy-captcha的详细过程》本文介绍了如何将Easy-Captcha框架集成到SpringBoot项目中,实现图片验证码功能,Easy-Captcha是... 目录SpringBoot集成图片验证码框架easy-captcha一、引言二、依赖三、代码1. Ea

Gin框架中的GET和POST表单处理的实现

《Gin框架中的GET和POST表单处理的实现》Gin框架提供了简单而强大的机制来处理GET和POST表单提交的数据,通过c.Query、c.PostForm、c.Bind和c.Request.For... 目录一、GET表单处理二、POST表单处理1. 使用c.PostForm获取表单字段:2. 绑定到结