1、刚刚拿到210开发板,发现资料只要友善的superboot,这个是他们没有公开的二进制文件,只能用来刷系统。而且只能配合他们的minitools SD-flasher.exe软件来使用。对于学习boot和linux内核来说简直一点用没有。
2、于是碰到了一个致命的问题,如何把自己编译的uboot放在sd卡,将sd卡制作启动盘?在网上百度了一大堆,发现方式多种多样,有window专门制作sd卡,还有朱友鹏老师的sd_fusing2.sh sd_fusing.sh等等脚本,最后发现都或多或少有以下问题。
3、其实解决办法就是首先到github上下载smart210的源代码,他们已经将代码中的硬件地址配置好了。我们只需要下载,编译使用。下载地址为:
GitHub - kangear/smart210-uboot: Support DNW
4、编译过程:make SMART210_config
maek ARCH=arm CROSS_COMPILE=arm-linux-
5、制作sd卡启动盘,ging把uboot写到sd卡内
由于210有一个bl1 bl2的存在,我们不能直接把u-boot烧到第一扇区,我一开始直接把uboot烧进去,一直出现错误。其实应该先把spl/smart210-spl.bin文件烧到第一扇区,然后再把u-boot.bin烧到49扇区就能成功了。为什么第二阶段拷贝到49扇区,因为u-boot的第一阶段代码是被IROM的固话代码搬移到IRAM里的。根据手册只搬移了24K到IRAM。每个扇区是512字节,那么前48个扇区正好是24K,第二阶段就在24K之后,当然这个第二阶段的扇区也可以改变,需要在第二阶段搬移代码的时候修改即可。
具体制作就用两条命令就ok了。
dd iflag=dsync oflag=dsync if=spl/smart210-spl.bin of=/dev/sdb seek=1
dd iflag=dsync oflag=dsync if=u-boot.bin of=/dev/sdb seek=49
6、当然,网上看到很多资料,由于编译的时候已经把两个文件合成一个文件了,使用一下命令应该也是可以的
dd iflag=dsync oflag=dsync if=smart210-uboot.bin of=/dev/sdc seek=1
7、最后,把sd卡插到开发板即可