Ubuntu PetaLinux安装教程

2023-11-30 07:32
文章标签 ubuntu 安装 教程 petalinux

本文主要是介绍Ubuntu PetaLinux安装教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转自:http://blog.csdn.net/u013793399/article/details/53054734

前言

PetalLinux是Xilinx公司推出的嵌入式Linux开发工具,专门针对Xilinx公司的FPGA SoC芯片和开发板,用户可以在PetaLinux工具的帮助下进行完整的开发流程,包括设计,验证,仿真,下载等。 
本文将详细介绍PetaLinux的安装流程,虽然实际上基本就是把Xilinx的UG1144翻译一遍。但对于初学者而言,全是英文的Guidance还是很难受的,可能某一步要输入某个命令,但是却并不知道为什么要这么做,这并不好,也容易打击信心,尤其是UG里还有一点小错误。

安装前的准备工作

  • 你需要一个运行着Linux操作系统的电脑作为主机。 
    • 你可以用虚拟机,也可以装双系统,或者你甚至可以直接把系统换成Linux。
    • 在这里,我用的是VMware虚拟机下的Ubuntu Kylin 14.04 LTS
  • 你需要一个足够大的硬盘空间,一个足够好的CPU,尽量大的内存。 
    • 毕竟是用来做开发的,对于配置要求还是比较高,Xilinx推荐4GB内存,20GB硬盘,2GHz主频CPU。
    • 然则,20GB硬盘远远不够!!我分配了100GB,安装完之后就剩30G空间了;我电脑一共就8GB内存,只能分给虚拟机2GB,倒是没出现什么问题,就是安装的时候比较慢,Guidance说只要“few minutes”,然而我需要花一局OW的时间。
    • 以下是Xilinx的推荐配置,不要相信他推荐的硬盘容量,其他都还好。 
      这里写图片描述
  • 安装一系列的支持包。以下是列表,最左边是支持包的名称,右侧是各个操作系统下,该支持包的安装包名称(很绕口,其实就是同一个功能在不同系统下有不同的叫法),只需要关注你所用的操作系统的那一列就可以了。记得在安装之前把这些支持库全部安装好,不然到时候等了好久,结果告诉你缺少库,请少侠重头再来,那就哭晕在厕所了。 
    这里写图片描述

  • 把shell设置成bash(这一步你看不懂的话可以忽略,因为有些人喜欢把shell设置为dash),具体设置方法是$ sudo dpkg-reconfigure bash,这里UG1144写错了。

  • 下载安装Vivado for Linux。或者你想在Windows下用Vivado搞完之后把文件扔到虚拟机里也可以,只是比较麻烦,还不如直接装在Linux里,实测界面和Windows下完全一样。推荐WebPack版本,虽说是阉割版,但还是可以用ZYNQ系列和MicroBlaze的全部功能,只是少了UltraScale系列和一些高端的7系列,重点是免费啊= =||

安装步骤

  • 下载PetaLinux包。网址如下: 
    • https://www.xilinx.com/support/download/index.html/content/xilinx/en/downloadNav/embedded-design-tools.html
    • 选择7.02GB的PetaLinux 2016.3 Installer
    • 下载完之后应该是一个 petalinux-v2016.3-final-installer.run 文件
    • 放到虚拟机里;
  • 建立安装路径,比如$ mkdir ~/Desktop/petalinux
  • 运行安装文件; 
    • $ ./petalinux-v2016.3-final-installer.run ~/Desktop/petalinux
    • 如果缺少后面的安装路径参数,则默认会安装在当前路径;
  • 经过漫长的等待~~~来到了Agreement部分了,就是一些协议,不同意就不让装,Windows下一般用勾选的方式,Linux终端没有这种条件,只能用Vim展示给你看。 
    • 按 Enter 进入协议文本,按 q 退出协议文本,然后就会有问你同不同意,输入 y 同意协议,进入下一条协议,按 q 退出,y 同意,若干次之后,就进入安装部分了。
  • 再次经过漫长的等待,安装完成。

环境配置

装好了工具,接下来就是要配置环境了。 
环境配置方法很简单,先确保你的shell是bash,具体设置方法看上面的“安装前准备工作”部分。 
然后运行$ source <path-to-installed-PetaLinux>/settings.sh 
比如我的安装路径是 ~/Desktop/petalinux,那对应的命令就是$ source ~/Desktop/petalinux/settings.sh

执行$ echo $PETALINUX 
如果显示出你的安装路径,那就证明环境变量配置好了

有一个问题是,每次打开一个新的终端,环境变量都会被重置,需要重新source,作为一个强迫症,我觉得这种重复而无聊的工作必然是可以自动化的。解决方案如下:

修改 ~/.bashrc 这个文件 
在最后加上 $ source ~/Desktop/petalinux/settings.sh 
.bashrc 是终端的初始化配置脚本,每次打开新的终端是的时候,都会执行这个脚本,把环境变量配置脚本加在里面,就能在打开的时候自动配置了。

安装PetaLinux BSP

BSP(Board Support Package)板级支持包,是一个文件包,当你使用特定的硬件平台时,可以帮你隔离底层硬件,更方便地进行上层开发。Xilinx的开发板基本上都有对应的BSP,在PetaLinux环境下可以很方便地生成一个基础工程,在基础工程的基础上进行配置和增删修改等,会比从零开始做简单得多。这里详细介绍了BSP的安装流程。

  • 下载你需要的板级支持包BSP。 
    • https://www.xilinx.com/support/download/index.html/content/xilinx/en/downloadNav/embedded-design-tools.html
    • 把PetaLinux下载列表往下拉,能看到很多的BSP,选择你想要的,比如我这里选的就是ZC706的BSP。
  • 把这个BSP文件放在你喜欢的地方。你可以把BSP文件看做一个种子,通过特定的命令可以让其“成长”为一个工程,一个模板工程,一个基于特定板子的基础工程,让你可以在此基础上直接进行开发而不需要关心板子上的具体电路等。
  • 好吧,其实我是骗你的,根本不需要什么安装,下载完放着就可以了;然则Guidance里说这就是Installation,所以也算不上骗吧┑( ̄Д  ̄)┍

利用BSP生成一个工程

刚刚说到,BSP相当于一个种子,可以种出一个工程,现在我们就来动手吧。

  • 首先 cd 到你希望放置工程的路径。比如我的就是: 
    • $ cd ~/Desktop/petalinux_project
  • 创建一个工程 
    • petalinux-create -t project -s ~/Desktop/BSP/zc706.bsp
    • 把上面的路径换成你的BSP放置的路径,文件名也换成你的BSP的文件名(废话…)
    • -t 表示的是 type,类型是project,-s 表示 source,源是你的BSP文件
    • 你也可以加一个 -n 参数,自定义工程的名称。n for name
  • 好的,一个BSP工程建立完毕。

创建一个自定义工程

创建工程肯定不可能只从BSP生成嘛,以下步骤可以创建一个自定义的工程,而不是基于某个特定开发板的工程。

  • 先 cd 到你希望放置工程的路径。比如我的就是: 
    • $ cd ~/Desktop/petalinux_project
  • 创建一个工程 
    • petalinux-create -t project --template zynq --name test_proj
    • 这样就创建了一个基于zynq芯片模板,名为test_proj的工程了。
    • template属性可以选择zynq,zynqMP,microblaze。

将硬件平台从Vivado工程导出

Vivado中,可以通过以下方法导出硬件描述文件(.hdf) 
- File -> Export -> Export to hardware 
将导出的 hdf 文件放好,待会需要用到。

将工程的硬件配置导入PetaLinux

我们从Vivado中得到了一个硬件,并导出为 .hdf 文件,现在可以把它导入PetaLinux平台。

  • 首先 cd 到你的工程根目录下
  • 导入硬件配置文件 
    • $ petalinux-config --get-hw-description=~/Desktop
    • 注意参数是 存有hdf文件的路径,而不是文件本身。
  • 然后应该会弹出一个菜单让你配置,配置完之后 save,exit即可。 
    • 其实一般不用怎么动,尤其是第一次跟着做的话基本一脸懵逼
    • 每个细目具体是什么意思,参考UG1144的附录B和附录C

生成系统镜像文件

生成一个Linux镜像文件。

  • 首先 cd 到你的工程根目录下
  • 生成系统镜像 
    • $ petalinux-build
    • 生成日志 build.log 存放在‘build’子目录中
    • 镜像文件存放在 /images/linux 中

生成引导镜像

我们有了一个系统镜像,有了一个FPGA的比特流文件,还有了一个u-boot。我们就可以生成一个引导镜像BOOT.bin 
命令如下: 
$ petalinux-package --boot --fpga xxx.bit --u-boot 
其中 xxx.bit 是你在Vivado里生成出来的比特流文件。 
然后你就可以看见当前目录下生成了一个BOOT.bin,就是引导镜像文件。

打包Pre-Built镜像

举个栗子,我们成功地做了一个镜像系统,现在需要将其备份,可以通过以下命令将其打包为“Pre-Built镜像”。 
首先 cd 到工程根目录。 
$ petalinux-package --prebuilt --fpga xxx.bit 
然后就会出现一个prebuilt目录,里面有完整的系统镜像文件。 
我们可以用prebuilt的镜像来引导系统,命令如下: 
$ petalinux-boot --qemu --prebuilt 3 
其中3代表的是 < BOOT_LEVEL >,可以选择为1/2/3,分别代表不同的引导层次,具体请参考UG1144的24页。

在QEMU中启动系统

上面说到的用prebuilt的镜像引导是其中一种方法,也可以直接引导。 
在工程根目录下执行如下命令:

  • $ petalinux-boot --qemu --u-boot 
    • 这样就可以把u-boot下载到QEMU中;
    • 其中 qemu 表示在QEMU虚拟环境中启动,可以换成 --jtag,这样就可以通过J-TAG下载到板子上。
  • $ petalinux-boot --qemu --kernel 
    • 这样就可以把内核下载到QEMU中;
    • 其实还需要一个 --dtb参数的,dtb是device tree blob,设备树文件,用来描述外挂的设备地址,如果缺省此参数,则会自动选用 /images/linux/system.dtb 文件

        设置APP应用


利用petallinux 系统可以开发一个新的APP

在根目录下输入命令:

            $ petalinux-create -t modules --name mymodule --enable

  Change to the newly created module directory.
$ cd <plnx-proj-root>/components/modules/mymodule
4. Place the pre-built library mymodule.
$ cp <path-to-prebuilt-module> .

    




那么,到这里,就安装成功并简单地测试了一下了。 
UG1144是个好东西,后面还有打包固件包、封装自己的BSP、添加用户库、添加用户应用、自动登录等等的教程。
刚开始看确实很痛苦啊,看了一整天,跟着做,做完了博客里写的部分,才看了不到一半。而且是全英文,虽然我英语不差,但是看起来还是有些吃力。 
┑( ̄Д  ̄)┍话虽如此,还是推荐看英文的UG,毕竟原汁原味,我水平也有限,有一些可能理解不到位。反正,一起加油吧。。。

这篇关于Ubuntu PetaLinux安装教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP