linux怎么读zynq的ddr数据,Zynq—Linux移植学习笔记(一)

本文详细介绍了Zynq Linux的配置和启动过程,包括从下载u-boot和Linux源码,修改配置参数,编译生成u-boot、Linux内核以及设备树,到通过JTAG或SD卡启动Linux的步骤。关键步骤涉及u-boot参数修改、Linux内核配置、设备树的编译以及不同启动方式的文件加载。同时,文中提到了针对不同启动方式的文件系统和内存设置,以及针对特定硬件的时钟频率和串口配置。
摘要由CSDN通过智能技术生成

b85db167def201d8309ec3af5b94b17a.png

1、相关网站

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

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

2、启动过程aa2aaaf3305353604ba09c9ffc978658.png

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的地址9f857f7c0756e9021af6b933028a3fc5.png

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

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

4、修改参考时钟b373a09b24159a157e0811f11fef87ef.png

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

将修改好的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以前的版本,如果使用的还是ramdisk32M或ramdisk8M,需要注意:

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,运行界面如下所示。5ef8d4cdb694be56f6335233d4c4d4b7.png

图2 生成QSPI启动文件

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

进入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大小调整,缓存地址需要和前面的缓存地址一致)

文章来源:Felven的博客

注:本文为授权转载文章,如需转载请联系作者授权

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: zynq-linux移植学习笔记应包含以下内容: 1. 对zynq架构和硬件资源的理解,包括PS和PL部分的特点。 2. 如何使用Xilinx SDK来编译和配置u-boot和Linux内核。 3. 如何在硬件平台上运行和调试Linux系统。 4. 怎样在Linux系统中配置和使用各种硬件资源,如DMA、Ethernet、Flash等。 5. 如何在Linux系统中移植和运行应用程序,并与硬件资源进行交互。 6. 如何进行系统优化和资源管理,以提高系统性能和稳定性。 ### 回答2: Zynq是一款Xilinx公司开发的一种嵌入式系统芯片,其使用了双核Cortex-A9处理器和可编程逻辑器件(FPGA)的组合。移植LinuxZynq芯片中,可以使其具备无限的扩展能力,极大地拓展了其应用领域,因此掌握Zynq-Linux移植技术是非常重要的。 Zynq-Linux移植分为四个主要步骤: 第一,准备工作 在移植前,需要确认硬件平台是否支持Linux运行,并且需要对硬件进行配置,最好使用Zynq开发板的官方配置; 第二,内核移植 内核移植是整个移植过程中最关键的一步。需要根据硬件平台的特性对内核进行选择和配置。可以从内核源代码库中获取内核代码,然后进行交叉编译。移植内核的过程中需要注意内核配置参数的设置,同时也要确保内核模块和驱动程序的编写。 第三,文件系统移植移植Linux的过程中,文件系统也是非常重要的。可以使用开发板官方Linux镜像,也可以自己编译镜像。移植文件系统还涉及到root文件系统的配置、挂载方式、网络配置和各种服务的配置等问题。 第四,驱动移植 驱动程序是连接硬件和软件的关键部分,需编写相应的驱动程序来实现对硬件的控制。移植驱动程序的过程中需要关注各种硬件接口和设备驱动API的使用,确保驱动程序与硬件配合良好。 总结来说,Zynq-Linux移植技术的掌握需要具备较强的Linux基础知识、驱动开发经验和交叉编译工具链的使用能力。同时,还需要有耐心和细心,对每个步骤进行仔细的分析和处理。 在学习中,需要结合实际开发项目,多进行实践操作才能更好地掌握Zynq-Linux移植技术,为后续项目的开发和应用提供更好的支持。 ### 回答3: Zynq-7000系列是一种由Xilinx开发的SoC(系统级芯片),它将双ARM Cortex-A9处理器和可编程逻辑(FPGA)集成在一起。这使得开发人员可以使用硬件加速加速器来加速运行在Linux上的各种应用。然而,实现这个目标需要进行移植。 在开始Zynq Linux移植学习笔记之前,需要一些基本的知识。首先,需要了解Linux内核的基本工作原理和Linux驱动程序的编写技术。然后,需要了解FPGA和SoC体系结构。 在开始移植之前,需要为SoC开发板选择正确的Linux发行版。这通常需要考虑处理器体系结构,内存大小和设备驱动程序的可用性。另外,还需要考虑是否需要自定义内核或驱动程序以满足应用程序的需求。 接下来,需要编写设备树文件(DT)来描述SoC架构。设备树文件是一种描述硬件配置信息的特殊语言。它会告诉内核有哪些设备可用以及如何访问这些设备。 接下来,需要配置Linux内核以支持Zynq-7000处理器。这可能包括启用适当的内核配置选项,编写设备驱动程序以及配置启动过程。 最后,需要启动Zynq板并验证Linux系统稳定运行。这些步骤包括在启动过程中将设备树文件加载到内存中,以及启动用户空间应用程序。 总之,移植Zynq Linux是一项复杂的任务,需要广泛的专业知识和技术。但是,它可以为开发人员提供强大的硬件加速支持,使他们能够加速处理一系列计算密集型应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值