我的Linux内核映像uImage位于我的U盘中。我想从U-Boot启动它。设备树文件am335x-evm.dtb也位于我的U盘中。我所做的如下:
U-Boot# usb start
(Re)start USB...
USB0: scanning bus 0 for devices... 1 USB Device(s) found
scanning usb for storage devices... 1 Storage Device(s) found
U-Boot# fatls usb 0:1
3821960 uimage
kit3/
4065280 modules.tar
my_modules/
extra/
system volume information/
375 uenv.txt
40474 am335x-evm.dtb
4 file(s), 4 dir(s)
U-Boot# fatload usb 0:1 0xC0700000 uImage
reading uImage
3821960 bytes read in 2375 ms (1.5 MiB/s)
U-Boot# fatload usb 0:1 0xC0e00000 am335x-evm.dtb
reading am335x-evm.dtb
40474 bytes read in 48 ms (823.2 KiB/s)
U-Boot# bootm 0xC0700000 - 0xC0e00000
## Booting kernel from Legacy Image at c0700000 ...
Image Name: Linux-3.12.10-ge35dc10-dirty
Image Type: ARM Linux Kernel Image (uncompressed)
Data Size: 3821896 Bytes = 3.6 MiB
Load Address: 80008000
Entry Point: 80008000
Verifying Checksum ... OK
## Flattened Device Tree blob at c0e00000
Booting using the fdt blob at 0xc0e00000
Loading Kernel Image ... OK
OK
Using Device Tree in place at c0e00000, end c0e0ce19
Starting kernel ...
Run Code Online (Sandbox Code Playgroud)
它到此为止。怎么做?谢谢!
结果: 感谢所有在这篇文章中回答的人!现在,我可以使用U盘中的映像启动系统。我要做的是:
setenv bootargs "console=ttyO0,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext4 mem=512M coherent_pool=8M loglevel=0 lpj=3317760 rootwait"
usb start; fatls usb 0:1; fatload usb 0:1 0x82000000 uImage-orig-onUSB;fatload usb 0:1 0x80F80000 am335x-evm.dtb;bootm 0x82000000 - 0x80F80000
Run Code Online (Sandbox Code Playgroud)
如果没有第一句话,系统还可以启动和启动将在显示屏中显示的GUI程序。但是调试串口不再有反应!
至于第二句话,如果我使用0xC0700000和0xC0e00000的ram地址,如下所示,那么它将停止加载内核。原因应该是锯末在他的回答中提到的东西。@锯末
setenv bootargs "console=ttyO0,115200n8 root=/dev/mmcblk0p2 rw rootfstype=ext4 mem=512M coherent_pool=8M loglevel=0 lpj=3317760 rootwait"
usb start; fatls usb 0:1; fatload usb 0:1 0xC0700000 uImage-orig-onUSB;fatload usb 0:1 0xC0e00000 am335x-evm.dtb;bootm 0xC0700000 - 0xC0e00000
Run Code Online (Sandbox Code Playgroud)
尽管显示了“正在启动内核...”消息,但内核尚未真正开始执行(因为必须先重新定位映像并且也要对其进行压缩),因此启用Earlyprintk仍然无效。
看起来可疑的是RAM地址。
典型的“ am33xx-evm”板只有512MB RAM,起始于0x80000000。
但是,您正在尝试使用从0xC0700000到0xC0E0CE19的RAM地址,其中不应存在物理内存。
显然,内核和设备树未正确加载。
代替
fatload usb 0:1 0xC0700000 uImage
fatload usb 0:1 0xC0e00000 am335x-evm.dtb
bootm 0xC0700000 - 0xC0e00000
Run Code Online (Sandbox Code Playgroud)
尝试使用
fatload usb 0:1 0x80200000 uImage
fatload usb 0:1 0x80e00000 am335x-evm.dtb
bootm 0x80200000 - 0x80e00000
Run Code Online (Sandbox Code Playgroud)