0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于zynq7000的linux系统搭建设计

电子设计 来源:AI加速微信公众号 作者:AI加速微信公众号 2020-11-30 11:56 次阅读

Zynq器件将armFPGA结合,利用了两者各自的优势,arm可以实现灵活的控制,而FPGA部分可以实现算法加速,这大大扩展了zynq的应用。比如深度学习加速,图像处理等等。PL侧表示FPGA的逻辑部分,PS侧为arm端以及一些AXI接口控制部分,二者实际上通过AXI接口实现通信和互联。PS可以通过AXI来对PL逻辑部分进行配置和控制,PL侧通过AXI和PS进行数据交互。本章基于zynq7020器件来搭建Linux系统,描述搭建Linux系统过程中PL侧的配置以及对u-boot,kenel,桌面系统的配置和编辑。

1. vivado工程创建

本文使用的是黑金的zynq7020开发板。搭建一个最基本的linux系统需要以下基本配置:

1)arm核的添加和配置。

打开vivado,新建工程。然后创建block,添加zynq processing system。图中iic是后边在开发IIC驱动时添加的,最基本的linux系统可以不适用IIC。

图1.1 添加zynq系统

2) bankIO电压设置。

根据原理图设置bank IO的电压。如图1.2所示。SD卡配置。

Linux系统安装在SD卡中,所以需要完成SD卡配置,根据原理图选择SD卡的使用引脚。

图1.2 IO电压和SD卡配置

3) UART口配置。

需要用到串口进行调试,所以配置串口MIO引脚。

图1.3 串口引脚配置

4) DDR配置。

内存是必须的。这里面已经有内存型号供你选择,不需要在对DDR参数做配置,只选择MT41J256M16RE-125就行了。

图1.4 DDR配置

这样就完成了一个Linux系统启动需要的最基本配置。接下来对工程进行综合和实现,生成bit,并在file菜单项中选择export/export hardware,选择include bitstream,点积OK就生成了linux系统需要的硬件工程。

接下来还需要生成启动u-boot的fsbl。这里简单说一下linux系统启动的基本过程:

FSBL(完成IO电压,SD卡,UART等硬件的检测和基本配置,然后启动u-boot。)->U-boot(这个主要完成arm硬件的一些更进一步检测和配置,然后去启动kernel)->kernel(这个是linux系统需要的所有驱动)->文件系统。

我们launch SDK,打开SDK生成fsbl和需要的设备树。

New->application project->zynq FSBL,然后进行编译,就生成了fsbl.elf文件。如果我们也已经生成了u-boot文件,就可以用SDK来制作boot.bin。我们可以选择fsbl的工程,右键create boot image,然后选择u-boot的路径,partition type选择dtafile。然后create image就会生成boot.bin了。我们在fsbl工程目录中的bootimage文件夹下看到boot.bin。

图1.5 选择u-boot路径

生成devicetree需要zynq的基本divecetree文件,可以在git上下载:https://github.com/Xilinx/device-tree-xlnx。下载的设备树文件添加到SDK中的repositories中:

图1.6 添加设备树文件来生成设备树

然后new->board support package project->device_tree,这样就生成了设备树源文件。源文件有以下几个:

Zynq-7000.dtsi,这个是zynq-7000的默认硬件配置,通常不需要修改。

pcw.dtsi,这个文件是针对自己的硬件平台进行进一步配置的。比如在zynq-7000中sdhci都是不使能的,在pcw.dtsi中就需要进行使能,并配置sdhci0的statue为okay。

System-top.dtsi,其配置一些别名,并配置chosen,这个主要是选择在启动硬件的时候如何和操作系统进行通信,比如stdout-path选择boot输出介质,一般都是串口输出。

用这三个文件就可以了。

图1.7 设备树源文件生成

以上就完成了linux系统启动的硬件工程搭建,设备树产生,以及fsbl产生。

2. u-boot编译

下载u-boot源码:https://github.com/Xilinx/u-boot-xlnx。

主要配置u-boot中的./configs/*_defconfig文件,这个主要是对arm端硬件进行配置。这里我们就使用zynq_zc702_defconfig,当然这里可以修改默认设备树文件和board_name. 比如将defconfig文件命名为board_name_defconfig,相应有文件./include/configs/board_name.h来描述板卡信息

然后在./include/configs中复制一份zynq_zc70x.h为你想要的板级名称。这个时候我们需要修改zynq_common.h中的配置。由于我们的文件系统在SD卡的第二分区,所以需要修改宏定义:CONFIG_EXTRA_ENV_SETTINGS,去除了ramdisk的启动。

然后建立uEnv.txt,在其中设置环境变量。如图2.3所示。指定了文件系统所在位置为SD卡分区2。文件系统格式为ext3。

图2.1 defconfig文件,红框可以修改成为你的板卡的名字和设备树名字


图2.2 sdboot变量修改前和修改后

图2.3 uEnv.txt中设置

接下来就是编译u-boot了。需要用到交叉编译工具arm-xilinx-linux-gnueabi。目前的vivado工具中已经没有这个交叉编译工具了,可以到网上下载这个工具链。然后export PATH=$PATH: dir/bin。可以在Makefile中设置默认的编译工具:

图2.4 Makefile中设置编译工具

然后make board_name_defconfig进行配置,最后make就可以编译出u-boot了。根目录下的u-boot.elf正是我们需要的文件,用于合成boot.bin。在1节中已经介绍了。

3. 编译kernel

Kernel可以到git上下载,kernel包含所有的驱动,如果进行驱动修改的话,可以在其中进行配置。比如筛选某些驱动。通常开发新的驱动,并不需要在其中进行修改。因为驱动可以通过命令行在系统启动后动态加载。所以只仅仅对驱动编译就行了,在Makefile中添加编译工具,这个核u-boot一样。然后make uImage LOADADDR=0x00008000就可以了。编译完成后再arch/arm/boot中产生uImage,这个是我们要用到的内核文件。

设备树文件的编译也很简单,就是通过设备树编译工具dtc将dtsi文件编为dtc文件就行了,这里注意dtc文件名称要和在u-boot中zynq-common.h中的设备树文件名称一样。通常都为devicetree。编译命令为:

dtc –I dtx –O dtb –o devicetree.dtb your.dts

文件系统可以使用linaro Ubuntu文件系统,从网上下载,解压。这个时候需要对SD卡进行分区,1区为fat格式,有200M就够了,存放boot.bin,uImage,devicetree.dtb,uEnv.txt文件。第二区用ext3格式,存放linaro Ubuntu文件系统。

4. linux系统启动过程

图4.1 fsbl启动

图4.2 fsbl完成

图4.3 u-boot启动:读取env,uImage和设备树

图4.4 启动kernel

图4.5 文件系统的启动

总结

本篇在zynq7000的基础上,制作一个最基本的linux系统。整个流程包括工程创建,fsbl和设备树生成,u-boot的配置和编译,kernel编译以及文件系统制作。

linux系统

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    87

    文章

    10986

    浏览量

    206713
  • Zynq
    +关注

    关注

    9

    文章

    598

    浏览量

    46608
收藏 人收藏

    评论

    相关推荐

    简谈Xilinx Zynq-7000嵌入式系统设计与实现

    今天给大侠带来简谈Xilinx Zynq-7000嵌入式系统设计与实现,话不多说,上货。 Xilinx的ZYNQ系列FPGA是二种看上去对立面的思想的融合,ARM处理器的串行执行+FPGA
    发表于 04-10 16:00

    请问FX3的UART口和Xilinx ZYNQ7000的PS端的UART进行硬件连接需要TTL电平转换吗?

    想让FX3的UART口和Xilinx ZYNQ7000的PS(Processor system)端的内置UART相互通信,两个芯片使用的是同一个电源(同在一块板子上或分别在两块相互连接的板子上),请教一下它们之间的硬件连接需要TTL电平转换(使用2块MAX3232ESE芯片,如下图所示)么?谢谢
    发表于 02-28 08:32

    通过JTAG启动Linux的方法和脚本

    在 AMD SoC 器件(AMD Zynq 7000 SoC,AMD Zynq UltraScale+ MPSoC,AMD Versal Adaptive SoC),常见的启动方式是通过加载外部
    的头像 发表于 12-22 10:27 586次阅读
    通过JTAG启动<b class='flag-5'>Linux</b>的方法和脚本

    使用 PCIE 更新 AMD ZYNQ™ 的 QSPI Flash 参考设计

    简介 AMD ZYNQ7000 的 S_AXI 端口提供了外设访问 PS 内部外设控制器的接口,这其中包括 4 个 S_AXI_HP 端口以及两个 S_AXI_GP 端口。一般来说,可以访问
    发表于 11-30 18:49

    基于zynq7020器件来搭建Linux系统

    Zynq器件将arm和FPGA结合,利用了两者各自的优势,arm可以实现灵活的控制,而FPGA部分可以实现算法加速,这大大扩展了zynq的应用。比如深度学习加速,图像处理等等。PL侧表示FPGA的逻辑部分,PS侧为arm端以及一些AXI接口控制部分,二者实际上通过AXI接
    发表于 11-09 11:28 1940次阅读
    基于<b class='flag-5'>zynq</b>7020器件来<b class='flag-5'>搭建</b><b class='flag-5'>Linux</b><b class='flag-5'>系统</b>

    Zynq的AMP多核处理

    写的是Zynq 7000系列的,arm有两个核。主要有AMP和SMP两种方式,SMP是两个核运行一个操作系统,跑LINUX的话,使能SMP,资源会自动分配给两个核运行。AMP是两个核独
    的头像 发表于 10-17 16:59 274次阅读
    <b class='flag-5'>Zynq</b>的AMP多核处理

    Zynq-7000 SoC的安全启动应用说明

    电子发烧友网站提供《Zynq-7000 SoC的安全启动应用说明.pdf》资料免费下载
    发表于 09-13 11:46 1次下载
    <b class='flag-5'>Zynq-7000</b> SoC的安全启动应用说明

    Zynq-7000 SoC:嵌入式设计教程

    电子发烧友网站提供《Zynq-7000 SoC:嵌入式设计教程.pdf》资料免费下载
    发表于 09-13 09:20 3次下载
    <b class='flag-5'>Zynq-7000</b> SoC:嵌入式设计教程

    Ai-WB2系列模组linux开发环境搭建方案

    Linux下编译速度比windows快很多,一般推荐优先使用linux环境开发。Ubuntu是非常常见Linux操作系统。这里介绍下如何快速搭建
    发表于 09-09 09:55 317次阅读
    Ai-WB2系列模组<b class='flag-5'>linux</b>开发环境<b class='flag-5'>搭建</b>方案

    ZYNQ7000系列FPGA资源对比

    对于软硬件技术开发人员,ZYNQ是比较好的入门级FPGA,你可以在FPGA上用verilog编写RTL代码,也可以在ARM中用C语言编写应用程序。而入手一块低成本的开发板则是你开启软硬件技术开发的一条捷径。
    的头像 发表于 09-06 11:00 669次阅读
    <b class='flag-5'>ZYNQ7000</b>系列FPGA资源对比

    蜂鸟E203移植ZYNQ7000开发板调试打印hellowaord乱码怎么解决?

    移植蜂鸟E203到zynq 保留GPIOA模块,用gpio16和gpio17做串口uart的RX和TX.用Nucleistidio里面模板的helloworld建工程后,下载到开发板里面 串口打印
    发表于 08-12 07:49

    xilinx ZYNQ7000系列基本开发流程之PS端

    ZYNQ 芯片分为 PL 和 PS, PS 端的 IO 分配相对是固定的,不能任意分配,虽然 PS 端的 ARM 是硬核,但是在 ZYNQ 当中也要将 ARM 硬核添加到工程当中才能使用,FPGA
    的头像 发表于 08-11 09:36 5359次阅读
    xilinx <b class='flag-5'>ZYNQ7000</b>系列基本开发流程之PS端

    Linux系统开发环境搭建

    今天给大家讲一讲Linux系统开发环境搭建
    发表于 07-12 14:51 681次阅读
    <b class='flag-5'>Linux</b><b class='flag-5'>系统</b>开发环境<b class='flag-5'>搭建</b>

    Xilinx ZYNQ UltraScale+系列产品介绍

    Zynq UltraScale+MPSoC是Xilinx推出的第二代多处理SoC系统,它在第一代Zynq-7000的基础上进行了全面升级。
    的头像 发表于 06-09 10:07 1834次阅读
    Xilinx <b class='flag-5'>ZYNQ</b> UltraScale+系列产品介绍

    Ai-WB2系列模组linux开发环境搭建教程

    Linux下编译速度比windows快很多,一般推荐优先使用linux环境开发。Ubuntu是非常常见Linux操作系统。这里介绍下如何快速搭建
    的头像 发表于 05-08 15:12 752次阅读
    Ai-WB2系列模组<b class='flag-5'>linux</b>开发环境<b class='flag-5'>搭建</b>教程