Registered User Tag: 2017 source edit |
Registered User mNo edit summary |
||
(3 intermediate revisions by 2 users not shown) | |||
Line 3: | Line 3: | ||
|MPUs checklist=STM32MP13x, STM32MP15x, STM32MP25x | |MPUs checklist=STM32MP13x, STM32MP15x, STM32MP25x | ||
}}</noinclude> | }}</noinclude> | ||
{{FlowCompatibility/Android}} | |||
This article explains how to build the Android™ bootloader binaries for a selected STM32 device. It is intended for Distribution Package users. | |||
This article explains how to rebuild the primary and secondary bootloaders for the STM32 device families. It is intended for Distribution Package users. | |||
This article explains how to rebuild the primary and | |||
== Prerequisites == | == Prerequisites == | ||
The environment must be installed using the | The environment must be installed using the distribution package adapted to the selected microprocessor unit. | ||
{{PC$}} source build/envsetup.sh | To execute the following instructions, work from the distribution root directory and initialize the environment with the following instructions: | ||
{{PC$}} lunch aosp_{{HighlightParam|''<BoardId>''}}-userdebug | {{PC$}}source build/envsetup.sh | ||
{{PC$}} bspsetup | {{PC$}}lunch aosp_{{HighlightParam|''<BoardId>''}}-userdebug | ||
{{Info| The <code>bspsetup</code> instruction only needs to be run once for each distribution}} | {{PC$}}bspsetup | ||
{{Info| The <code>bspsetup</code> instruction only needs to be run once for each distribution.}} | |||
== Partition layout == | == Partition layout == | ||
The Trusted Firmware (TF-A) is used as the | The Trusted Firmware (TF-A) is used as the primary bootloader in the OpenSTDroid distribution. The TF-A binary file is part of the FSBL partition. | ||
The TF-A binary file is part of the | |||
The Universal Bootloader (U-Boot) is used as the | The Universal Bootloader (U-Boot) is used as the secondary bootloader in the OpenSTDroid distribution. The U-Boot binary file is part of the FIP partition. | ||
The U-Boot binary file is part of the | |||
The binaries are available in <code>device/stm/{{HighlightParam|''<STM32Series>''}}-bootloader/prebuilt</code>. | The binaries are available in <code>device/stm/{{HighlightParam|''<STM32Series>''}}-bootloader/prebuilt</code>. | ||
Line 39: | Line 36: | ||
By default, the bootloader sources are not part of the OpenSTDroid distribution. To load the sources, execute the following instruction: | By default, the bootloader sources are not part of the OpenSTDroid distribution. To load the sources, execute the following instruction: | ||
{{PC$}} load_bootloader | {{PC$}}load_bootloader | ||
It will load both the TF-A and U-Boot sources. | It will load both the TF-A and U-Boot sources. | ||
Line 59: | Line 56: | ||
To build both the FSBL and the SSBL, run: | To build both the FSBL and the SSBL, run: | ||
{{PC$}} build_bootloader | {{PC$}}build_bootloader | ||
{{Warning| The build script is only compatible with <code>x86_64</code> host machine. The <code>arm64</code> host machine compatible version will arrive soon.}} | {{Warning| The build script is only compatible with <code>x86_64</code> host machine. The <code>arm64</code> host machine compatible version will arrive soon.}} | ||
This instruction generates both the TF-A and the U-Boot for every available board, memory and boot mode in the optee configuration. | This instruction generates both the TF-A and the U-Boot for every available board, memory, and boot mode in the optee configuration. | ||
To get | To get more details on available options, run: | ||
{{PC$}} build_bootloader -h | {{PC$}}build_bootloader -h | ||
Hereafter, this is the result for version 1.8: | |||
<pre> | <pre> | ||
Usage: build_bootloader [Options] [Mode Options] [Board Options] | Usage: build_bootloader [Options] [Mode Options] [Board Options] | ||
Line 93: | Line 90: | ||
To update prebuilt images add '''-i''' option: | To update prebuilt images add '''-i''' option: | ||
{{PC$}} build_bootloader -i | {{PC$}}build_bootloader -i | ||
To integrate the updated prebuilt images, execute from the root directory: | To integrate the updated prebuilt images, execute from the root directory: | ||
{{PC$}} make -j | {{PC$}}make -j | ||
Then update associated partitions on your device. Refer to [[How to populate boards for Android]] | Then update associated partitions on your device. Refer to [[How to populate boards for Android]] | ||
<noinclude> | <noinclude> | ||
{{PublicationRequestId | | {{PublicationRequestId | 33629 | 2025-01-13 | }} | ||
[[Category:How to Android]] | [[Category:How to Android]] | ||
[[Category:Android]] | [[Category:Android]] | ||
</noinclude> | </noinclude> |
Latest revision as of 11:20, 13 March 2025
This article explains how to build the Android™ bootloader binaries for a selected STM32 device. It is intended for Distribution Package users.
This article explains how to rebuild the primary and secondary bootloaders for the STM32 device families. It is intended for Distribution Package users.
1. Prerequisites[edit | edit source]
The environment must be installed using the distribution package adapted to the selected microprocessor unit.
To execute the following instructions, work from the distribution root directory and initialize the environment with the following instructions:
<BoardId>-userdebug bspsetupsource build/envsetup.sh lunch aosp_
2. Partition layout[edit | edit source]
The Trusted Firmware (TF-A) is used as the primary bootloader in the OpenSTDroid distribution. The TF-A binary file is part of the FSBL partition.
The Universal Bootloader (U-Boot) is used as the secondary bootloader in the OpenSTDroid distribution. The U-Boot binary file is part of the FIP partition.
The binaries are available in device/stm/<STM32Series>-bootloader/prebuilt
.
3. Load the bootloader sources[edit | edit source]
By default, the bootloader sources are not part of the OpenSTDroid distribution. To load the sources, execute the following instruction:
load_bootloader
It will load both the TF-A and U-Boot sources.
The bootloader sources are located in:
- TF-A:
device/stm/<STM32Series>-bootloader/tf-a-<STM32Series>
- U-Boot:
device/stm/<STM32Series>-bootloader/u-boot-<STM32Series>
4. Build the bootloaders[edit | edit source]
To build both the FSBL and the SSBL, run:
build_bootloader
This instruction generates both the TF-A and the U-Boot for every available board, memory, and boot mode in the optee configuration.
To get more details on available options, run:
build_bootloader -h
Hereafter, this is the result for version 1.8:
TF-A and/or U-Boot) Options: -h / --help: print this message -v / --version: get script version -i / --install: update prebuilt images --verbose=<level>: enable verbosity (1 or 2 depending on level of verbosity required) -p / --programmer: build dedicated programmer version (-i option forced) -g/--gdb: generate .elf files useful for debug purpose -t / --tools: generate fiptool for the HOST machine Board options: (default = all possibilities) -b <name> / --board=<name>: set board name from following list = eval (default: all) -m <config> / --mem=<config>: set memory configuration from following list = sd emmc (default: all)Usage: build_bootloader [Options] [Mode Options] [Board Options] This script allows building the bootloaders source (
5. Integrate the bootloaders[edit | edit source]
To update prebuilt images add -i option:
build_bootloader -i
To integrate the updated prebuilt images, execute from the root directory:
make -j
Then update associated partitions on your device. Refer to How to populate boards for Android