zynq 加载bit方法总结
来源:互联网 发布:广州大学生数据分析 编辑:程序博客网 时间:2024/06/14 05:01
版权属于原作者,此处转载不涉及任何利益,仅供学习交流
原文地址:http://xilinx.eetop.cn/viewnews-1887
如何在Zynq-7000上烧写PL Image
在Zynq-7000上编程PL大致有3种方法:
1. 用FSBL,将bitstream集成到boot.bin中
2. 用U-BOOT命令
3. 在Linux下用xdevcfg驱动。
步骤:
1. 去掉bitstream的文件头
用FSBL烧写PL Images没有什么好说的,用Xilinx SDK的Create Boot Image工具即可完成,不再赘述。用后两种方法需要把bitstream文件的文件头用bootgen工
一个典型的bif文件如下所示:
the_ROM_image:
{
[bootloader]<fsbl_name>.elf
<pl_bitstream_name>.bit
<u-boot_name>.elf
}
bif文件可以用文本编辑器写,也可以用Xilinx SDK的Create Boot Image工具生成。然后在命令行下用以下命令即可去掉bitstream文件的文件头。
bootgen -image <bootimage>.bif -split bin -o i BOOT.BIN
"-split”参数可以生成以下文件:
<pl_bitstream_name>.bit.bin
2. 在U-BOOT下烧写PL Image
命令”fpga load”和”fpga loadb”都可以。区别是前一个命令接受去掉了文件头的bitstream文件,后一个命令接受含有文件
在OSL 2014.2上,缺省编译就可以完整支持写入PL Image的功能。但是在Petalinux 2013.10下,尽管可以在U-BOOT下看到命令”fpga”,还需要在文件
<PROJ>/subsystems/linux/configs/u-boot/platform-to
/* Enable the PL to be downloaded */
#define CONFIG_FPGA
#define CONFIG_FPGA_XILINX
#define CONFIG_FPGA_ZYNQPL
#define CONFIG_CMD_FPGA
#define CONFIG_FPGA_LOADFS
在OSL 2014.2 U-BOOT中,具体的功能是在zynqpl.c的zynq_load()中实现的。
3. 在Linux下烧写PL Image
OSL Linux 2014.2.01中已经含有xdevcfg驱动了(之前就有,不过本文是在这个版本上验证的),直接用以
cat <path_to_storage_media>/<pl_bitstream_name>.bit.bin > /dev/xdevcfg
Linux驱动的源代码在xilinx_devcfg.c中。因为驱动的编号是通过alloc_chrde
在Linux驱动中,每次往DevCfg中写入4096字节,直到全部写完。
4. 在用户程序中烧写PL Image
目前没有现成的源码来完成这个功能,不过可以用mmap()把DevCfg的寄存器映射到用户程序的虚地址
* FSBL中的pcap.c
* U-BOOT中的zynqpl.c
* Linux中的xilinx_devcfg.c
* Xilinx SDK中的例子。例子位于以下位置,随SDK的版本会有变化。
C:\Xilinx\SDK\2014.1\data\embeddedsw\XilinxProcess
小结:
DevCfg外设内部有自己的DMA,只需要简单的配置PL Image的基地址和长度到DevCfg寄存器,就可以完成Zynq-7000 PL Image的加载。Xilinx已经提供了灵活的解决方案,如果开发者要把这个功能集成在自己的应用程序中
- zynq 加载bit方法总结
- Zynq cap调试总结
- Xilinx zynq zc702学习总结
- Xilinx zynq zc702学习总结
- zynq bit文件固化在flash里,上电不启动
- 加载xib的方法总结
- apk加载32bit 64bit
- Xilinx zynq zc702学习总结 部分内容更正
- Zynq软硬件协同设计 总结一
- Xilinx zynq的资料获取总结
- 类加载+获取方法的方法总结
- 9.2 Zynq嵌入式系统调试方法
- ZYNQ fsbl阶段的调试方法
- bit fields 总结
- mysql bit 总结
- Leetcode bit manipulation 总结
- Java中加载配置文件的方法总结
- 网页加载速度优化方法总结
- vuejs 安装
- C#77课的主要内容
- ubuntu-16.04安装gcc-linux-gcc,交叉编译会遇到的问题心得
- What is a good product?
- 第二十一课 I/O库
- zynq 加载bit方法总结
- Masonry的简单使用
- 保存图片控制器方法
- Linux中find常见用法示例
- Repeater06-Repeater动态添加一行
- hebernate,JPA select 子查询语句问题
- const和#define的区别
- mybatis的resultType
- 在ios开发中怎么获取应用崩溃日志