blob: 7924632678e74362513b8b78372c3f5677471ee7 [file] [log] [blame]
Boyan Karatotevdd2600e2024-10-25 18:18:17 +01001/* DRAM1 + 0x2000_0000 */
2load_addr=0xa0000000
3/* DRAM1 + 0x0800_0000 */
4initrd_addr_r=0x88000000
5
6bootcmd=
Leo Yan0b50abc2024-10-25 18:18:19 +01007 virtio scan;
8 if virtio info; then
9 blk_dev=virtio;
10 else;
11 blk_dev=mmc;
12 fi;
13 echo block device is ${blk_dev};
14 if part number ${blk_dev} 0 vbmeta is_avb; then
15 echo '${blk_dev} with vbmeta partition detected.';
Boyan Karatotevdd2600e2024-10-25 18:18:17 +010016 echo 'Starting Android Verified boot...';
Leo Yan0b50abc2024-10-25 18:18:19 +010017 avb init ${blk_dev} 0;
Boyan Karatotevdd2600e2024-10-25 18:18:17 +010018 if avb verify; then
19 set bootargs $bootargs $avb_bootargs;
Leo Yan0b50abc2024-10-25 18:18:19 +010020 part start ${blk_dev} 0 boot boot_start;
21 part size ${blk_dev} 0 boot boot_size;
22 ${blk_dev} read ${load_addr} ${boot_start} ${boot_size};
Boyan Karatotevdd2600e2024-10-25 18:18:17 +010023 bootm ${load_addr} ${load_addr} ${fdt_addr_r};
24 else;
25 echo 'AVB verification failed.';
26 exit;
27 fi;
Leo Yan0b50abc2024-10-25 18:18:19 +010028 elif part number ${blk_dev} 0 system is_non_avb_android; then
Boyan Karatotevdd2600e2024-10-25 18:18:17 +010029 echo 'Booting Android non-AVB...';
30 booti ${kernel_addr_r} ${initrd_addr_r} ${fdt_addr_r};
31 elif iminfo ${load_addr}; then
32 echo 'Booting FIT image...';
33 bootm ${load_addr} ${load_addr} ${fdt_addr_r};
Leo Yanc2837402024-10-25 18:18:20 +010034 else;
35 echo 'Booting Debian...';
36 set bootargs $bootargs root=/dev/mmcblk0p1 rw;
37 booti ${kernel_addr_r} - ${fdt_addr_r};
Boyan Karatotevdd2600e2024-10-25 18:18:17 +010038 fi;
39 echo 'ERROR: No valid image to boot the system. Aborting boot sequence.';