これは、小さな部品を燃やすことはできません。それでも、フルイメージをデバイスのメモリにコピーする必要があります。 回避策:U-Bootのネットワーク機能を使用してください(tftpboot)。イメージをメモリにダウンロードし、ボード上で実行してください。ここで
は、PowerPCボードの一つの例です:
nb_load=dhcp;run nb_load_dtb;run nb_load_vmlinuz;run nb_load_initrd
nb_load_initrd=tftpboot 0x1900000 /mybooklive/initrd
nb_load_vmlinuz=tftpboot 0x1000000 /mybooklive/vmlinuz
nb_load_dtb=tftpboot 0x1800000 /mybooklive/apollo3g.dtb
nb_boot=setenv bootargs ${nb_bootargs}; run nb_load; bootm 0x1000000 0x1900000 0x1800000
nb_bootargs=console=ttyS0,115200n8 ignore_loglevel
U-bootコマンドラインで実行run nb_boot
をブートします。
カーネルイメージ、初期RAMディスク、デバイスツリーBLOBが必要です(カーネルでコンパイルしない場合に備えて)。 U-bootコマンドラインで実行run bootcmd_edsboot
をブートするために
setenv boot_edsboot 'zboot 0x100000 0 0x3000000 0x1000000'
setenv bootargs_edsboot 'console=tty1 console=ttyS2,115200n8 rootfstype=ramfs rw'
setenv bootcmd_edsboot 'setenv bootargs ${bootargs_edsboot}; run load_edsboot; run boot_edsboot'
setenv load_edsboot 'load mmc 0:9 0x100000 vmlinuz.efi; load mmc 0:9 0x3000000 initrd'
:ここ
はeMMC装置から起動するインテルエジソンボードのU-ブートオプションの別の例です。
完全な記事はhereです。
あなたが持っているボードに応じて正しいファイル(DTB)とアドレスを取得する必要があることは明らかです。
ありがとう0andriy、私は今、どのようにubootが動作するかを理解することができました。私はネットワークブートオプションを使用しようとしますが、これは私の使用事例にとってはかなり適切です。 – silentnights