㈠ 過程預覽
⑴ 生成QSPI Flash啟動方式所需要的文件
① 生成preloader;
② 生成uboot;
③ 生成dtb;
④ 生成kernel;
⑤ 生成rootfs;
⑵ 上電燒寫文件到QSPI Flash
① 設置BSEL/CSEL pin使用QSPI Flash啟動;
② JTAG燒寫preloader到QSPI Flash;
③ JTAG燒寫uboot到QSPI Flash;
④ 配置HPS RGMII網口;
⑤ tftp下載並燒寫dtb到QSPI Flash;
⑥ tftp下載並燒寫kernel到QSPI Flash;
⑦ tftp下載並燒寫rootfs文件QSPI Flash;
⑧ tftp下載並燒寫fpga文件QSPI Flash;
⑶ 配置uboot環境變量
⑷ QSPI Flash booting log
㈡ 注意事項
⑴ TAG燒寫Flash工具quartus_hps.exe要求文件名擴展名必須為*.bin,否則將會出錯。
quartus_hps -c 1 -o PV -a 0x60000 u-boot.img.bin
quartus_hps -c 1 -o PV -a 0x60000 u-boot.img
其它文件同理,故都需要增加擴展名為bin。
⑵ 由於JTAG理論速度是8Mbps,實際中往往達不到,對於14M字節左右的rootfs,燒寫比較費時間。為節省時間也可以使用tftp通過RGMII口來sf命令燒寫QSPI FLash。
㈢ 步驟細述
⑴ 生成QSPI Flash啟動方式所需要的文件
① 生成preloader;
命令:bsp-editor.exe
C:\altera\13.1\embedded\examples\hardware\cv_soc_devkit_ghrd\hps_isw_handoff\soc_system_hps_0
修改BOOT_FROM_QSPI
命令:make
② 生成uboot;
命令:make
③ 生成dtb;
對於QSPI Flash大小:32MByte,每個分區的起始地址、大小及其功能,如下:
故修改soc_system_qspi_flash_booting.dts如下:
修改之后的dts文件:
soc_system_qspi_flash_booting.dts
命令:
dtc -I dts -O dtb -o soc_system_qspi_flash_booting.dtb soc_system_qspi_flash_booting.dts
生成的dtb:
soc_system_qspi_flash_booting.dtb
④ 生成kernel;
步驟⑤同時會生成kernel:
⑤ 生成rootfs;
A)下載鏈接:
http://releases.rocketboards.org/release/2013.11/gsrd/src/linux-socfpga-gsrd-13.1-src.bsx
B)生成過程:
C)生成后位置:
⑵ 上電燒寫文件到QSPI Flash
① 設置BSEL/CSEL pin使用QSPI Flash啟動;
② JTAG燒寫preloader到QSPI Flash;
命令:
quartus_hps -c 1 -o PV -a 0x0000 preloader-mkpimage.bin
③ JTAG燒寫uboot到QSPI Flash;
命令:
quartus_hps -c 1 -o PV -a 0x60000 u-boot.img.bin
④ 配置HPS RGMII網口;
命令:
set ethaddr 01:11:22:33:44:55
setenv serverip 192.168.1.66
setenv ipaddr 192.168.1.55
saveenv
ping $serverip
⑤ tftp下載並燒寫dtb到QSPI Flash;
A)tftp Server配置
B)命令:
tftp 0x1000000 soc_system_qspi_flash_booting.dtb
C)命令:
sf erase 0x50000 0x10000
sf write 0x1000000 0x50000 0x10000
⑥ tftp下載並燒寫kernel到QSPI Flash;
命令:
tftp 0x1000000 zImage
擦除+燒寫QSPI Flash命令:
sf update 0x1000000 0xa0000 0x310000
⑦ tftp下載並燒寫rootfs文件QSPI Flash;
命令:
tftp 0x1000000 altera-image-minimal-socfpga_cyclone5.jffs2
擦除+燒寫QSPI Flash命令:
sf update 0x1000000 0x800000 0xb40000
⑧ tftp下載並燒寫fpga文件QSPI Flash;
命令:
tftp 0x1000000 output_file.rbf
擦除+燒寫QSPI Flash命令:
sf update 0x1000000 0x1800000 0x6b0000
⑶ 配置uboot環境變量
命令:
setenv qspifpgaaddr 0x1800000
setenv qspifpga sf probe $\{qspiloadcs\}\; sf read $\{fpgadata\} $\{qspifpgaaddr\} $\{fpgadatasize\}\; fpga load $\{qspiloadcs\} $\{fpgadata\} $\{filesize\};
setenv bootcmd run qspifpga\; run bridge_enable_handoff\; run qspiload\; run qspiboot
saveenv
⑷ QSPI Flash booting log