1、 devicetree配置
devicetree中涉及到QSPI FLASH的部分如下:
一般qspi flash被区分为五个分区,配置时需要注意下面几点:
Is_dual表示并行模式,如果不是并行设置为0(Set if parallel. Reset if single or stacked.)
Num_cs表示flash芯片数量,目前zynq把qspi flash当成一个芯片,即使板子上贴了两块芯片,zynq也只是当成一片使用
配置完devicetree后在xilinx_zynq_defconfig中也需要配置MTD分区
CONFIG_CMDLINE="
console=ttyPS0,115200n8
root=/dev/ram rw
initrd=0x00800000,16M
earlyprintk
mtdparts=physmap-flash.0:512K(nor-fsbl),512K(nor-u-boot),5M(nor-linux),9M(nor-user),1M(nor-scratch),-(nor-rootfs)"
通过对比devicetree中的分区和defconfig中的分区可以发现共同点:
fsbl和u-boot位于前1M(nor-fsbl+nor-u-boot)分区
linux内核位于接下来的5M(nor-linux)分区
devicetree,rootfs,bitstream中位于后面9M(nor-user)中(实际只占用6M)
2、 kernel配置
配置完devicetree后需要对kernel进行配置,在编译产生kernel时将相应的驱动加入kernel。
上图中需要将boot选项设置为采用bootloader内核参数。
将zynq QSPI控制器添加到内核中
3、 qspi flash测试
启动linux,在启动过程中能找到如下打印,当前linux kernel版本为3.14
从这里可以看出启动分区信息。
1)文件读写测试
当linux启动完成后,可以通过
列出所有的分区
很显然,两个分区信息一致。
接下来进行flash文件读写,首先在本地创建一个文件(大小4M)
拷贝到mtd3中
2)文件系统测试
除了对flash进行文件读写测试外,Qspiflash中也可以挂载文件系统进行测试
首先列出所有分区信息
对要挂载文件系统的分区进行擦除操作
创建目录
将分区挂载到qspi_flash0
创建要写入flash的文件
将文件写入flash
列出文件系统中文件
卸载文件系统
再次挂载文件系统
比较之前产生的文件与文件系统中的文件是否一致,一致证明文件系统有效
再次卸载文件系统
只要不擦除flash,Sample.bin将一直存在flash中,这样就验证了文件系统的正确性。