| .. |
| # Copyright (c) 2024, Linaro Ltd. |
| # |
| # SPDX-License-Identifier: MIT |
| |
| SM8x50 (Snapdragon 8 Gen devboards) |
| =================================== |
| |
| .. note:: |
| sm8x50-userdebug is an AOSP build target for Snapdragon 8 Gen devboards. |
| It is supported only on v6.8+ kernel versions. Primarily supported and |
| tested on sm8550-hdk. Other `Snapdragon 8 Gen devboards <https://estore.lantronix.com/collections/product-development-kits>`_ |
| like sm8450-qrd, sm8450-hdk, sm8550-qrd, sm8650-qrd, and sm8650-hdk are |
| supported on the best efforts basis. |
| |
| `SM8550-HDK <https://estore.lantronix.com/collections/product-development-kits/products/snapdragon-8-gen-2-mobile-hardware-development-kit>`_ |
| is a Snapdragon 8 Gen 2 Mobile Hardware Development Kit. |
| |
| |
| Getting started with SM8550-HDK |
| ------------------------------- |
| |
| The power-up sequence for sm8550-hdk is similar to that of RB3 and RB5. The wall |
| power need to be switched ON first and then connect the USB-C to boot |
| automatically without pressing any physical button on the board. Make sure that |
| switch <7, 8> of S5702 is ON before powering ON the device to enable HDMI out. |
| |
| sm8x50-userdebug boots to UI with v6.8+ android-mainline and upstream kernel |
| using software rendering and linux-firmware binaries for now. |
| `lunch` target is not added yet and will be added as soon the firmware binaries |
| land in linaro-vendor / linux-firmware repo to make sure that the device has |
| more features enabled and is in a more usable state. Boot image header v2 is |
| used for now, while we are working on releasing ABL with header v4 support. |
| |
| |
| Compile AOSP from sources for SM8x50 (Snapdragon 8 Gen) devices |
| --------------------------------------------------------------- |
| |
| .. code:: |
| |
| mkdir $AOSP |
| cd $AOSP |
| repo init -u https://android.googlesource.com/platform/manifest -b master |
| repo sync -j`nproc` |
| ./device/linaro/dragonboard/fetch-vendor-package.sh |
| source ./build/envsetup.sh |
| lunch sm8x50-trunk_staging-userdebug |
| make -j`nproc` |
| |
| The above instructions will build AOSP images for sm8x50 devboards. This default |
| build supports booting from an mmc-sdcard (due to upstream UFS bugs currently |
| being looked at) and will boot to UI using software rendering support. |
| |
| |
| Flashing and booting AOSP from mmc-sdcard |
| ----------------------------------------- |
| |
| Reboot sm8x50 in fastboot mode and run following commands to disable verity |
| verity and and erase AOSP partitions for any stale images and to make sure |
| that every reboot/reset lands at the ABL fastboot mode prompt. |
| |
| .. code:: |
| |
| $AOSP/external/avb/avbtool.py make_vbmeta_image --flag 2 --padding_size 4096 --output ./vbmeta_disabled.img |
| fastboot --disable-verity --disable-verification flash vbmeta ./vbmeta_disabled.img |
| fastboot erase boot erase dtbo erase init_boot erase vendor_boot |
| fastboot reboot bootloader |
| |
| Booting AOSP from a mmc sdcard is an experimental build configuration and is |
| only intended to be used in the LKFT lab. But booting from mmc-sdcard is the |
| default option on SM8550-HDK due to some upstream UFS breakages. |
| |
| We chainload U-Boot from ABL bootloader and flash the, already plugged-in, |
| mmc-sdcard. For now we are using a WIP `upstream u-boot fork |
| <https://source.devboardsforandroid.linaro.org/platform/external/u-boot/+/refs/heads/wip/sm8x50/>`_. |
| |
| mmc boot configuration require atleast 16GB sdcard. Here are the instructions to |
| prepare and flash AOSP images on a MMC sdcard: |
| |
| .. note:: |
| Following commands that are listed with **=>** prompt means those commands need |
| to be run from the u-boot prompt on the device and commands with **$** means |
| they need to be run from the HOST machine. |
| |
| * Build U-Boot for SM8550-HDK and boot with it: |
| |
| .. code:: |
| |
| $ git clone https://source.devboardsforandroid.linaro.org/platform/external/u-boot -b wip/sm8x50 |
| $ cd u-boot |
| $ make CROSS_COMPILE=aarch64-linux-gnu- qcom_defconfig all |
| $ gzip u-boot-nodtb.bin |
| $ mkbootimg --os_version 14.0.0 --os_patch_level 2023-10 --header_version 2 --kernel u-boot-nodtb.bin.gz --dtb dts/upstream/src/arm64/qcom/sm8550-hdk.dtb --pagesize 2048 --cmdline "" --output u-boot-sm8550-hdk.img |
| $ fastboot boot u-boot-sm8550-hdk.img # this will boot U-Boot on sm8550-hdk |
| |
| * Prepare AOSP partition layout on the sdcard from the U-Boot prompt. Make sure |
| that a 16GB+ MMC sdcard is plugged into the board: |
| |
| .. code:: |
| |
| => run gpt_mmc_aosp |
| => reset # this will reboot in ABL fastboot mode |
| $ fastboot boot u-boot-sm8550-hdk.img |
| => run fastboot # starting U-Boot's fastboot command |
| $ fastboot erase boot erase init_boot erase vendor_boot erase modemst1 erase modemst2 erase fsg erase fsc erase misc erase metadata erase super erase userdata |
| $ fastboot reboot # rebooting in ABL fastboot mode |
| $ fastboot boot u-boot-sm8550-hdk.img |
| => run fastboot |
| |
| * To flash images on the MMC sdcard, make sure we run U-Boot's fastboot command |
| on the device before running the following flash and boot commands: |
| |
| .. code:: |
| |
| cd out/target/product/sm8x50 |
| fastboot flash super ./super.img flash userdata ./userdata.img format:ext4 metadata reboot |
| fastboot boot ./boot.img |
| |
| .. note:: |
| We do not flash **boot.img** on the sdcard; instead, we load the boot image from |
| device RAM by running ``fastboot boot boot.img``. |
| |
| It should boot sm8x50 devices to UI with software rendering support. |
| |
| .. note:: |
| To boot from the on-board UFS, build AOSP images with ``TARGET_SDCARD_BOOT=false`` |
| build flag and follow the same flashing and booting instructions as above. |
| |
| |
| Building and booting with custom kernel |
| --------------------------------------- |
| |
| The **Preferred** option is to build Android GKI kernel artifacts using official |
| Bazel build instructions. |
| |
| #. Build android-mainline kernel for SM8x50 devices |
| |
| Run the following commands to clone the android-mainline repo including the |
| kernel source, prebuilt Android toolchains and build scripts. |
| |
| .. code:: |
| |
| mkdir gki-repo |
| cd gki-repo |
| repo init -u https://android.googlesource.com/kernel/manifest -b common-android-mainline |
| repo sync -j`nproc` |
| tools/bazel clean |
| tools/bazel run //common:db845c_dist |
| |
| Now delete all the objects in |
| $(AOSP_TOPDIR)device/linaro/dragonboard-kernel/android-mainline/, then copy |
| build artifacts from out/db845c/dist/ to |
| $(AOSP_TOPDIR)/device/linaro/dragonboard-kernel/android-mainline/ |
| |
| Then rebuild AOSP and boot with new boot.img using: |
| |
| .. code:: |
| |
| make TARGET_KERNEL_USE=mainline bootimage -j`nproc`' |
| fastboot boot ./boot.img |
| |
| |
| #. Download and build upstream tracking kernel |
| |
| .. code:: |
| |
| git clone https://git.linaro.org/people/amit.pundir/linux -b rbX-mainline |
| cd linux |
| make ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu- mrproper |
| KCONFIG_CONFIG=./arch/arm64/configs/temp_aosp_rbx_sm8x50_defconfig ./scripts/kconfig/merge_config.sh -m -r ./arch/arm64/configs/aosp_defconfig ./kernel/configs/aosp_rbx_sm8x50.config |
| make ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu- temp_aosp_rbx_sm8x50_defconfig |
| make ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu- DTC_FLAGS=-@ -j`nproc` |
| make ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu- INSTALL_MOD_PATH=./modules/ INSTALL_MOD_STRIP=1 modules_install -j`nproc` |
| rm arch/arm64/configs/temp_aosp_rbx_sm8x50_defconfig |
| cp arch/arm64/boot/Image.gz arch/arm64/boot/dts/qcom/qrb5165-rb5.dtb arch/arm64/boot/dts/qcom/sdm845-db845c.dtb arch/arm64/boot/dts/qcom/sm8450-hdk.dtb arch/arm64/boot/dts/qcom/sm8450-qrd.dtb arch/arm64/boot/dts/qcom/sm8550-hdk.dtb arch/arm64/boot/dts/qcom/sm8550-qrd.dtb arch/arm64/boot/dts/qcom/sm8650-hdk.dtb arch/arm64/boot/dts/qcom/sm8650-qrd.dtb $AOSP/device/linaro/dragonboard-kernel/android-upstream/ |
| find ./modules/lib/ -iname \*.ko -exec cp {} $AOSP/device/linaro/dragonboard-kernel/android-upstream/ \; |
| |
| Then rebuild AOSP and boot with new boot.img using: |
| |
| .. code:: |
| |
| make TARGET_KERNEL_USE=upstream bootimage -j`nproc`' |
| fastboot boot ./boot.img |
| |
| |
| Known issues and Troubleshooting on sm8550-hdk |
| ---------------------------------------------- |
| |
| #. UFS is not stable. There are a series of known issues that are currently |
| being worked upon. |
| |
| For example: Probability of UFS probe running into a hard crash during boot |
| time is very high and it needs a power reset to recover. |
| |
| And then there is a run time UFS crash which leaves the device unusable. |
| |
| #. At times `fastboot boot` run into the following failure: |
| |
| .. code:: |
| |
| fastboot boot ./boot.img |
| Sending 'boot.img' (19988 KB) OKAY [ 0.460s] |
| Booting FAILED (remote: 'Failed to load/authenticate boot image: Load Error') |
| fastboot: error: Command failed |
| |
| Run the following set of commands to recover from the above error: |
| |
| .. code:: |
| |
| fastboot reboot bootloader |
| fastboot set_active a boot ./boot.img |
| |
| |
| Device Maintainer(s) |
| ******************** |
| - Amit Pundir <pundir at #aosp-developers on OFTC IRC> |