Zynq-Linux移植学习笔记之一-入门[通俗易懂]

Zynq-Linux移植学习笔记之一-入门[通俗易懂]1、相关网站zynqlinux软件网站:www.wiki.xilinx.comzynqu-bootgithub地址:https://github.com/xilinx 2、启动过程3、u-boot配置3.1下载u-bootUBOOT有多个版本,可以去网站上下载相应的版本。14.5及早期的版本对Micron的QSPIFlash芯片支持不完整。建议下载后期

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

1、相关网站

zynq linux软件网站:www.wiki.xilinx.com

zynq u-boot github地址:https://github.com/xilinx

 

2、启动过程

Zynq-Linux移植学习笔记之一-入门[通俗易懂]

3、u-boot配置

3.1 下载u-boot

UBOOT有多个版本,可以去网站上下载相应的版本。14.5及早期的版本对Micron的QSPI Flash芯片支持不完整。建议下载后期版本

$ git clone git://git.xilinx.com/u-boot-xlnx.git(下载u-boot源码命令)

3.2 u-boot参数修改

1)  .\u-boot\arch\arm\cpu\armv7\zynq\clk.c

由于使用的是50M参考时钟,需要更改参考时钟

# define CONFIG_ZYNQ_PS_CLK_FREQ    33333333UL更改为

# define CONFIG_ZYNQ_PS_CLK_FREQ    50000000UL

2)  .\u-boot\include\configs\zynq_zc70x.h

由于使用的是串口0,需要更改串口定义

#define CONFIG_ZYNQ_SERIAL_UART1更改为

#define CONFIG_ZYNQ_SERIAL_UART0

3)  .\u-boot\include\configs\zynq_zc70x.h

根据DDR实际大小修改内存配置参数

#define CONFIG_SYS_SDRAM_SIZE          (1024* 1024 * 1024)更改为

#define CONFIG_SYS_SDRAM_SIZE          (512 * 1024 * 1024)(根据实际内存大小修改)

3.3 u-boot编译

在linux系统下进入u-boot

$ cd u-boot

$ git apply 0001-Xilinx.patch

(这条命令可以不执行,该命令的目的是将ramdisk8M.image.gz改为ramdisk32M.image.gz)

$ make distclean

$ make zynq_xxx_config

(zynq_xxx是在/include/configs/下的h文件名,根据需要编译的文件名而定。在执行命令之前,如果要求文件进行编辑,执行gedit xxx.h)

$ make

编译结束后会在当前文件夹下生成u-boot文件,拷贝后,改成u-boot.elf文件

4、Linux配置

4.1 下载Linux

$ git clonegit://git.xilinx.com/linux-xlnx.git(下载Linux源码)

4.2 Linux编译

$su

$cp mkimage /bin

(转换为root用户,将.\u-boot\tools\mkimage文件拷贝到根目录的bin目录下,生成uImage文件需要使用)

$ cd linux-xlnx

$ make distclean

$make ARCH=arm xilinx_zynq_defconfig

(xilinx_zynq_defconfig可根据实际情况选择,目录为.\linux-xlnx\arch\arm\configs)

$ make ARCH=arm menuconfig

选择 Exit

$make ARCH=arm UIMAGE_LOADADDR=0x8000uImage

编译完成后,生成的uImage文件和zImage文件存放在.\linux-xlnx\arch\arm\boot下

5、Linux设备树配置

5.1 修改dts文件

从\linux-xlnx\arch\arm\boot\dts目录下选择对应的开发板修改,本设计选择zynq-zc706.dts

$ gedit xxx.dts

(如果不用编辑,可略过此步骤)

对xxx.dts的修改,根据实际配置进行修改,本设计需修改三个地方,一个是更改为串口0,一个是修改参考时钟(由33333333改为50000000),最后修改内存大小配置

1、  修改串口地址,修改为串口0的地址

Zynq-Linux移植学习笔记之一-入门[通俗易懂]

2、  修改clocks数组中的数值(串口0对应23和40),按照下图中的clks数组,从0开始。

Zynq-Linux移植学习笔记之一-入门[通俗易懂]

3、修改串口0的中断号,根据UG585中的中断号分配表,查找对应的设备中断号,减去32

4、修改参考时钟

Zynq-Linux移植学习笔记之一-入门[通俗易懂]

5、修改内存配置(根据硬件实际使用的内存大小修改,本设计中内存大小为512MB)

Zynq-Linux移植学习笔记之一-入门[通俗易懂]

将修改好的dts文件拷贝到linux-xlnx /scripts/dtc目录下

5.2 编译devicetree

$ cd linux-xlnx

$ ./scripts/dtc/dtc -O dtb -I dts -odevicetree.dtb xxx.dts

(如果前面没有编译生成uImage文件,此命令会报错,找不到dtc命令)

将linux-xlnx目录生成的devicetree.dtb拷贝到相应的地方

5.3 下载ramdisk

从网上下载ramdisk32M.image.gz

由于git clonegit://git.xilinx.com/apps/busybox.git无法正常运行,所以直接拷贝了zed板的文件,未做任何改动。下载地址见:http://download.csdn.net/detail/jj12345jj198999/9717091

6、启动Linux

6.1 JTAG启动

超级终端的速率选择115200

将u-boot.elf,uImage,devicetree.dtb和ramdisk32M.image.gz文件拷贝到工程路径的/hw目录下

进入XMD命令窗口

cdD:/shen/switch/v20/20130825prj1/project_1/project_1.sdk/SDK/SDK_Export/hw

(根据实际的工程路径选择)

connect arm hw

source ps7_init.tcl

ps7_init

dow -data devicetree.dtb 0x2a00000

(地址可以根据实际情况更改)

dow -data ramdisk32M.image.gz 0x2000000

(地址可以根据实际情况更改)

dow -data uImage 0x3000000

(地址可以根据实际情况更改)

dow u-boot.elf

con

在超级终端上回车

在超级终端上运行 bootm 0x30000000x2000000 0x2a00000(和上面下载地址一致)

对于14.5以前的版本,如果使用的还是ramdisk32Mramdisk8M,需要注意:

dow -data ramdisk32M.image.gz 0x2000000

(这一步的偏移量和下载文件有关,如果是ramdisk8M.image.gz,偏移量为0x800000;如果是ramdisk32M.image.gz,偏移量为0x2000000)

6.2 SD卡启动

1)在SDK中将FSBL、XXX.bit和u-boot.elf文件生成xxx.bin和xxx.mcs文件,把xxx.bin命名为boot.bin。

2)SD卡格式化为FAT32格式,将boot.bin,zImage,devicetree.dtb和ramdisk32M.image.gz(注意使用同一版本)拷贝到SD卡里。

6.3 QSPI启动

在SDK中,生成启动文件xxx.bin,运行界面如下所示。

Zynq-Linux移植学习笔记之一-入门[通俗易懂]

图2 生成QSPI启动文件

备注:可以根据uImage、devicetree和ramdisk的实际文件大小调整offset,这样可以调整最终生成的可烧写文件的大小,在做了offset调整后,在uboot目录下.\include\configs\zynq-common.h作相应的修改,注意三个文件在QSPI flash中所处的偏移地址一定要和sfread中的一致。另外还要注意读取到内存中时的数据大小,不能小于文件的实际大小。

 Zynq-Linux移植学习笔记之一-入门[通俗易懂]

进入XMD命令窗口

connect arm hw

cdD:/shen/switch/v20/20130825prj1/project_1/project_1.sdk/SDK/SDK_Export/hw

(根据实际的工程路径选择)

source ps7_init.tcl

ps7_init

dow u-boot.elf

dow -data xxx.bin 0x08000000

(需要烧写的文件,缓存地址可以改变,如变为0x04000000)

con

在超级终端中Enter

sf probe 0 0 0

sf erase 0 0x02000000

(32MB,根据实际flash大小调整)

(如果是Micron的Flash,删除时间比较久,一个subsector(4KB)需要花费0.3s,8192个subsector需要40.96s)

sf write 0x08000000 0 0x01ffffff

(根据实际flash大小调整,缓存地址需要和前面的缓存地址一致)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/193107.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • vuecli安装_vuecli3项目打包并运行

    vuecli安装_vuecli3项目打包并运行前言vue-cli是和vue进行深度组合的工具,可以快速帮我们创建vue项目,并且把一些脚手架相关的代码给我们创建好。真正使用vue开发项目,都是用vue-cli来创建项目的。vue-cli介绍

  • linux下yum命令出现Loaded plugins: fastestmirror

    linux下yum命令出现Loaded plugins: fastestmirror

  • Spring中,三级缓存解决循环依赖[通俗易懂]

    Spring中,三级缓存解决循环依赖[通俗易懂]发现Spring三级缓存没有写到博客里,这里从自己的笔记迁移一下,补上:创建的都是单例,如果是构造方法注入,不能解决;如果是设值方法注入,用三级缓存解决:DefaultSingletonBeanRegistry:singletonObjectsearlySingletonObjectssingletonFactories代码流程:bean在createBeanInstance后,populateBean前:DefaultSingletonBeanRegistry:addSingl

  • acwing-2180. 最长递增子序列问题(最大流+拆点+最长上升子序列)

    acwing-2180. 最长递增子序列问题(最大流+拆点+最长上升子序列)给定正整数序列 x1,⋯,xn。计算其最长递增子序列的长度 s。计算从给定的序列中最多可取出多少个长度为 s 的递增子序列。(给定序列中的每个元素最多只能被取出使用一次)如果允许在取出的序列中多次使用 x1 和 xn,则从给定序列中最多可取出多少个长度为 s 的递增子序列。注意:递增指非严格递增。输入格式第 1 行有 1 个正整数 n,表示给定序列的长度。接下来的 1 行有 n 个正整数 x1,⋯,xn。输出格式第 1 行输出最长递增子序列的长度 s。第 2 行输出可取出的长度为 s 的

  • set/getenforce

    set/getenforce在AndroidKK4.4版本后,Google启用SELinux来增强Android的安全性。可以使用setenforce命令进行设置模式:adbshellsetenforce0//设置成Permissive模式adbshellsetenforce0//设置成Permissive模式adbshellsetenforce1//设置成Enforc

  • 开心网外挂之争车位之发起比赛

    开心网外挂之争车位之发起比赛       publicvoidlalisai_KaiShiBiSai(stringid)       {           AccessHelperAH=newAccessHelper();           KaiXinHelperKH=newKaiXinHelper();           DataTabledt=AH.GetDataTable(“

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号