พัฒนาฟีเจอร์ของโปรแกรมโหลดบูต Android

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

แหล่งที่มา AOSP

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

พัฒนา Bootloader

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

  1. โคลนไฟล์ Manifest สำหรับ U-boot ของ Android Fork

    $ 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
    • aarch64

      $ 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 ลงในคอนโซล

ทดสอบขั้นตอนการบูตด้วยเคอร์เนลต่างๆ

หากต้องการทดสอบขั้นตอนการบูตโหลดเดอร์ด้วยเคอร์เนลหรือโมดูลเคอร์เนลอื่น ให้ส่งอาร์ติแฟกต์เป้าหมาย (เคอร์เนลและโมดูลเคอร์เนล) โดยใช้อาร์กิวเมนต์ --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