หน้านี้อธิบายวิธีสร้าง เรียกใช้ และพัฒนาฟีเจอร์ Android bootloader บนอุปกรณ์ Cuttlefish
แหล่งที่มาของ AOSP
หากต้องการพัฒนาฟีเจอร์ Bootloader ของ Android ให้ใช้การกำหนดค่า Cuttlefish ของ U-boot กับ Cuttlefish ใน aosp-main
หรือบน กิ่งก้านของอิมเมจระบบทั่วไป (GSI) สำหรับ Android 11 ขึ้นไป ต่อไปนี้เป็นแหล่งที่มาใน AOSP:
พัฒนาบูตโหลดเดอร์
หากต้องการสร้าง รัน และพัฒนาคุณลักษณะ bootloader ภายในเครื่อง ให้ทำตามขั้นตอนเหล่านี้:
โคลนรายการสำหรับ Android fork ของ U-boot:
$ mkdir u-boot-mainline $ cd u-boot-mainline $ repo init -u https://android.googlesource.com/kernel/manifest -b u-boot-mainline $ repo sync -j$(nproc) -q
สร้างเป้าหมาย bootloader ที่เหมาะสมสำหรับสถาปัตยกรรม Cuttlefish ของคุณ ตัวอย่างเช่น:
x86_64
$ tools/bazel run //u-boot:crosvm_x86_64_dist
อาร์ค64
$ tools/bazel run //u-boot:crosvm_aarch64_dist
ผลลัพธ์ไบนารี bootloader (
u-boot.bin
สำหรับ arm64 และu-boot.rom
สำหรับ x86_64)$PATH_TO_REPO/out/u-boot-mainline/dist
เปิดอุปกรณ์ Cuttlefish ด้วย bootloader รวมพารามิเตอร์
pause_in_bootloader
เพื่อปิดใช้งานการบูตอัตโนมัติและให้คุณโต้ตอบกับ Bootloader$ launch_cvd \ -bootloader /$PATH/$TO/u-boot-mainline/out/u-boot-mainline/dist/u-boot.rom \ -pause_in_bootloader -console=true
หากต้องการโต้ตอบกับ Bootloader ให้เชื่อมต่อกับคอนโซล Bootloader
$ screen ~/cuttlefish_runtime/console
เมื่อเสร็จสิ้นการโต้ตอบของ bootloader ให้ทำการบู๊ตต่อโดยพิมพ์
boot
ลงในคอนโซล
ทดสอบโฟลว์ bootloader ด้วยเคอร์เนลที่แตกต่างกัน
หากต้องการทดสอบโฟลว์ bootloader ด้วยเคอร์เนลหรือโมดูลเคอร์เนลที่แตกต่างกัน ให้ส่งส่วนเป้าหมาย (โมดูลเคอร์เนลและเคอร์เนล) โดยใช้อาร์กิวเมนต์ --kernel_path
และ --initramfs_path
แอสเซมเบลอร์จะบรรจุอิมเมจสำหรับบูตใหม่โดยอิงตามสิ่งประดิษฐ์ที่ส่งผ่านในอาร์กิวเมนต์
cvd start \
-kernel_path=/$PATH/$TO/common-android14-6.1/out/android14-6.1/dist/bzImage \
-initramfs_path=/$PATH/$TO/common-android14-6.1/out/android14-6.1/dist/initramfs.img
สำหรับข้อมูลเพิ่มเติม โปรดดูที่ พัฒนาเคอร์เนล Android