Xilinx zynq-7000系列FPGA移植Linux操作系统详细教程

一:前言

最近手上压了一块米联客的Miz7035,一块xilinx zynq-7000系列的开发板,想着正好学习一下linux在ARM9上的移植,网上基本都是ZC702、zed的教程,这对于买了非标准板的人来说就不太友好,很多文件都不知道是怎么生成的。本着学习加分享的心态,把这两天移植linux的过程写下来,尽可能详细。驱动和系统移植不是我的专长,很多地方我也是知其然不知其所以然,写得不对的地方欢迎指正。

二:前期准备 

1、一台安装好linux系统的主机,我安装的是centos7.2.

2、一块zynq-7000系列的FPGA开发板,我手上的是米联客miz7035,其他zynq系列一样通用。

3、vivado开发环境,我安装的2018.2版本

4、u-boot,device-tree,kernel下载。地址分别是:https://github.com/Xilinx/u-boot-xlnx (u-boot)、https://github.com/Xilinx/linux-xlnx(kernel)、https://github.com/Xilinx/device-tree-xlnx(device-tree)。

5、根文件系统,这里我裂墙推荐Debian,Debian这个Linux系统,底层非常稳定,内核和内存的占用都非常小,下载地址:https://pan.baidu.com/s/1eHmjGd-dTtgnITjG2D3CYA

三:操作步骤

1.设置交叉编译环境

因为最终运行在arm9上,所以uboot、内核,文件系统编译都需要用arm-linux交叉编译工具,zynq2000使用的是arm-linux-gnueabihf,交叉编译工具可以从网上单独下载,也可直接使用vivado自带的交叉编译工具。使用方法也很简单

source /opt/Xilinx/SDK/2018.2/settings64.sh

或者

gedit /opt/Xilinx/SDK/2018.2/.settings64-SDK_Core_Tools.sh

将该文件中的内容全部复制到bashrc,更新环境变量,这样在新的终端中打开,环境变量也不会消失。

2.u-boot编译

进入u-boot文件夹,

make distclean  //清除配置文件和编译中间结果
make CROSS_COMPILE=arm-linux-gnueabihf- zynq_mz7x_defconfig //重新配置,生成makefile,具体板子不一样,在U-Boot/configs文件夹下
make CROSS_COMPILE=arm-linux-gnueabihf- tools //编译开发所需要的工具
make CROSS_COMPILE=arm-linux-gnueabihf- //编译,完成后生成一个elf文件u-boot,uboot.bin,u-boot.srec等文件

最后把编译生成的u-boot后缀改成.elf,连同u-boot.img和spl/boot.bin,一共三个文件拷贝出来。

3.kernel内核编译

export PATH=${YOUR_UBOOT_DIR}/tools:$PATH  //编译内核如果要生成uImage,则需要用到mkimage工具,该工具在u-boot/tools下有提供
make distclean //清除配置文件和编译中间结果
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- xilinx_mz7x_defconfig //重新配置,生成makefile
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- prepare scripts //编译开发所需要的工具
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- UIMAGE_LOADADDR=0x8000 uImage //编译内核,且生成uImage

最后把{KERNEL_DIR}/arch/arm/boot/zImage,{KERNEL_DIR}/arch/arm/boot/uImage拷贝出来。


    # zImage  - compressed kernel image
    # uImage  - zImage plus U-Boot header
uImage是在zImage之前加上一个长度为0x40的“头”,说明这个映像文件的类型、加载位置、生成时间、大小等信息。换句话说,如果直接从uImage的0x40位置开始执行,zImage和uImage没有任何区别。

4、设备树编译

经过内核编译,在kernel文件夹下script/dtc中有编译好的设备树编译工具

cd kernel/scripts/dtc
./dtc -I dts -O dtb -o devicetree.dtb /FPGA工程目录/SDK目录/device_tree_bsp_0/system-top.dts //dts为sdx工程中生成,编译后在当前目录下生成一个名为devicetree.dtb)。

5. 编译并安装内核模块,更新文件系统

本文提供的rootfs是已经编译好的,如果想要重新编译或者更新文件系统,可以下载后解压,然后执行以下步骤

cd your_downlood_kernel_dir //打开编译好的内核文件夹
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- modules //编译内核模块,
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- modules_install INSTALL_MOD_PATH=../rootfs // 在上一步打开的终端中,重新安装内核模块,安装路径为解压出来的rootfs路径
tar -cvzf rootfs.tar.gz rootfs。//将安装好内核模块的根文件系统重新压缩

6.生成启动镜像文件

制作启动镜像需要用到三个文件:fsbl.elf、system.bit和第二步生成的u-boot.elf。

打开SDK工具,生成fsbl的方法网上很多,自己查阅,不赘述了,这里只介绍如何制作boot image

在fsbl工程目录上右键选择Create Boot Image

加入u-boot.elf的路径,然后Create Image,就会在指定的输出路径上生成BOOT.bin

7.设置UBOOT环境变量

新建一个uEnv.txt,输入内容:

optargs=console=tty0 consoleblank= vt.global_cursor_default=

这部分不是很懂,有清楚的请留言。

8.制作SD卡

找一张SD卡,通过系统自带的磁盘工具,首先格式化。然后创建两个分区,一个100M FAT格式,命名为UBOOT,剩余的8G ext4格式,命名为rootfs。如图所示:

将步骤6、7、4、3生成的BOOT.bin、uEnv.txt、devicetree.dtb、uImage拷贝到UBOOT分区下

将步骤5生成的rootfs.tar.gz解压到rootfs分区下。

四:实验结果

五、结束语

至此,debian在zynq上的移植全部结束,之后,我将分享如何在linux基础上开发字符驱动,以及如何运行QT程序,并通过一个摄像头采集的例子作为具体应用。

 

Xilinx zynq-7000系列FPGA移植Linux操作系统详细教程的更多相关文章

  1. VM安装linux操作系统详细教程

    1.首先我们新建一个虚拟机,先不安装操作系统,稍后再对其安装Linux系统. 新建虚拟机步骤如下: 打开VMware软件,菜单栏点击“文件(F)”–>选择“新建虚拟机(N)”,如下图1,(或者直 ...

  2. ZYNQ FLASH+EMMC手动移植LINUX启动

    前言 虽可使用Petalinux进行移植,简单方便,但为了更清楚明白的了解整个流程,还是尝试了一波手动移植. 参考资料 ZYNQ Linux 移植:包含petalinux移植和手动移植debian9 ...

  3. VMware虚拟机12安装linux系统详细教程

    亲测有效,附图: 工具/原料 VM ware workstation12虚拟机(百度下载) 深度linux镜像ios系统文件 链接:https://pan.baidu.com/s/1RY1Plgru4 ...

  4. Zynq ZC706 传统方式移植Linux -- 编译kernel 文件系统 devicetree

    1.kernel 实际操作时候,下面两条命令就够了. make ARCH=arm xilinx_zynq_defconfig make ARCH=arm CROSS_COMPILE=arm-xilin ...

  5. Zynq ZC706 传统方式移植Linux -- 编译u-boot

    我用的是zc706不是zed 基本思路是: 1.安装交叉编译工具(见 https://www.cnblogs.com/idyllcheung/p/10532654.html ) 2.下载xilinx ...

  6. Linux操作系统入门教程

    http://www.linuxidc.com/Linux/2015-07/120815p8.htm

  7. u盘安装Linux系统详细教程

    2012-05-06 02:30:44 分类: LINUX 想不想体验一下Linux下呢?刻盘太浪费钱,而U盘却可以多次利用.本文就是要介绍如何通过U盘安装Linux系统的.只要用Universal- ...

  8. VMware虚拟机安装Linux系统详细教程

    VMware14虚拟机安装RedHad6系统步骤 redhat网盘资源:链接:https://pan.baidu.com/s/1GlT20vevqbZ9qTxsGH1ZzA 提取码:oh57 如果网盘 ...

  9. VMware上安装Kali Linux 超详细教程

    一.下载镜像文件 下载好系统对应镜像文件  https://www.kali.org/downloads/ 二.创建新的虚拟机 1.创建新的虚拟机 我们使用自定义的配置方法. 2.添加镜像文件的路径 ...

随机推荐

  1. 团队项目个人进展——Day04

    一.昨天工作总结 冲刺第四天,昨天继续忙着整理数据结构与算法的知识,在项目上看了看有关视频,学习了有关视图的地方和文档说明 二.遇到的问题 无 三.今日工作规划 学习并实现地图的放大与缩小

  2. 【翻译&转载】shader的导数函数介绍

    原文链接:http://www.aclockworkberry.com/shader-derivative-functions/ 他人的翻译:http://blog.sina.com.cn/s/blo ...

  3. Maven安装及MyEclipse中使用Maven

    Step1:下载mavenhttp://maven.apache.org/download.cgi,下载好后解压到一个路径中 Step2:配置环境变量, 新建变量名:MAVEN_HOME 变量值:D: ...

  4. machine learning model(algorithm model) .vs. statistical model

    https://www.analyticsvidhya.com/blog/2015/07/difference-machine-learning-statistical-modeling/ http: ...

  5. 浅析NSTextContainer

    浅析NSTextContainer TextKit中的NSTextContainer有点晦涩难懂,如果想用TextKit实现文本分页的效果,你是必须要使用NSTextContainer的...... ...

  6. JS DateTime 格式化

    首先看我们在浏览器接收到的DateTime格式的数据: 如果没有在传输的时候把DateTime转成字符串的话,我们只需要在JS中加一段代码即可转换,代码如下: function ChangeDateF ...

  7. 安全预警-防范新型勒索软件“BlackRouter”

    近期,出现一种新型勒索软件“BlackRouter”,开发者将其与正常软件恶意捆绑在一起,借助正常软件的下载和安装实现病毒传播,并以此躲避安全软件的查杀.目前,已知的被利用软件有AnyDesk工具(一 ...

  8. C++ Boost在Windows和Linux下的编译安装

    再debian下直接apt-get install gcc g++就可以了.按照类似的逻辑,再Fedora下yum install gcc g++ 报告无法找到g++包. 差了一下,原来这个包的名字叫 ...

  9. 开源作业调度框架 - Quartz.NET - 实战使用1

    简介: 第一步:下载Quartz.NET 下载Quartz.NET只需要打开网址选择适宜的版本进行下载解压缩即可. 目前最新版本是2.3.3,压缩包为6MB,不过鉴于国内网速.我还是加一下博客园的下载 ...

  10. 查找数据库表中重复的 Image 类型值

    直接上代码: SELECT * FROM [dbo].[V_Courseware] ))) IN ())) FROM [dbo].[V_Courseware] ))) ); 替换以上代码中相应对象即可 ...