พัฒนาฟีเจอร์ Bootloader ของ Android

หน้านี้จะอธิบายวิธีสร้าง เรียกใช้ และพัฒนาฟีเจอร์บูตโหลดเดอร์ของ Android ในอุปกรณ์ Cuttlefish

แหล่งที่มาของ AOSP

หากต้องการพัฒนาฟีเจอร์ของโปรแกรมโหลดบูต Android ให้ใช้การกำหนดค่า Cuttlefish ของ U-boot กับ Cuttlefish ใน aosp-main หรือในสาขา Generic System Image (GSI) สำหรับ Android 11 ขึ้นไป แหล่งที่มาใน AOSP มีดังนี้

พัฒนา Bootloader

หากต้องการสร้าง เรียกใช้ และพัฒนาการ์ดบูตในเครื่อง ให้ทำตามขั้นตอนต่อไปนี้

  1. โคลนไฟล์ Manifest สำหรับ U-boot เวอร์ชัน Android โดยทำดังนี้

    $ 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
  2. สร้างเป้าหมาย Bootloader ที่เหมาะสำหรับสถาปัตยกรรม Cuttlefish ของคุณ เช่น

    • x86_64

      $ tools/bazel run //u-boot:crosvm_x86_64_dist
    • AArc64

      $ 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

  3. เปิดอุปกรณ์ Cuttlefish ด้วย Bootloader รวมพารามิเตอร์ pause_in_bootloader เพื่อปิดใช้การบูตอัตโนมัติและให้คุณโต้ตอบกับโปรแกรมโหลดบูต

    $ launch_cvd \
        -bootloader /$PATH/$TO/u-boot-mainline/out/u-boot-mainline/dist/u-boot.rom \
        -pause_in_bootloader -console=true
  4. หากต้องการเชื่อมต่อกับ Bootloader ให้เชื่อมต่อกับคอนโซล Bootloader

    $ screen ~/cuttlefish_runtime/console
  5. เมื่อโต้ตอบกับ Bootloader เสร็จแล้ว ให้บูตต่อโดยพิมพ์ boot ลงในคอนโซล

ทดสอบโฟลว์ Bootloader ด้วยเคอร์เนลต่างๆ

หากต้องการทดสอบขั้นตอนการบูตโหลดเดอร์ด้วยเคอร์เนลหรือโมดูลเคอร์เนลอื่น ให้ส่งอาร์ติแฟกต์เป้าหมาย (เคอร์เนลและโมดูลเคอร์เนล) โดยใช้อาร์กิวเมนต์ --kernel_path และ --initramfs_path Assembler จะแพ็กอิมเมจบูตอีกครั้งโดยอิงตามอาร์ติแฟกต์ที่ส่งมาในอาร์กิวเมนต์

cvd create \
    -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