[PATCH 0/3] arm: meson: extend sm calls to support Amlogic chip_id v1, v2

Viacheslav adeep at lexina.in
Tue Feb 11 08:32:43 CET 2025


Hi!

10/02/2025 20.50, Evgeny Bachinin wrote:
> The Amlogic Meson SoC secure monitor (TF-A) handles a call (0x82000044)
> to retrieve a chip_id from eFuse OTP data [1].
> 
> Previously, this sm call (0x82000044) was used to retrieve just unique
> SoC number [2] (a.k.a. SoC "serial" [3]), identifying particular die.
> This SoC serial, stored in the eFuse, is always 12 bytes long.
> 
> However, this smc provides more info and the patch series generalizes
> the API to provide SoC serial and support of chip_id.
> 
> Chip_id in eFuse OTP storage exists in two flavors [1]: v1 (12 bytes)
> and v2 (16 bytes). The vendor U-Boot handles this difference before
> returning the chip_id value to the client and generalizes versions to
> look like the following (always 16 bytes in size):
> 
>      4 bytes      12 bytes
>      +-------+-------------------+
>      |       |                   |
>      | CPUID | SOC SERIAL NUMBER |
>      |       |                   |
>      +-------+-------------------+
>      0                          15
> 
> The original chip_id value is utilized in several algorithms (for
> example, in the Amlogic boot protocols), making it crucial to have the
> ability to read the original chip_id value as intended by the vendor [3]
> 
> Links:
> [1] https://github.com/TrustedFirmware-A/trusted-firmware-a/blob/03a7a43e18927c876ef5f554e54fa11d252d4f7e/plat/amlogic/common/aml_sip_svc.c#L21
> [2] https://lore.kernel.org/u-boot/20190612094908.24858-2-narmstrong@baylibre.com/
> [3] https://lore.kernel.org/linux-arm-kernel/202311242104.RjBPI3uI-lkp@intel.com/T/#m630fbeea6a6e7d531290b5c0af205af4fb979757
> 
> Signed-off-by: Evgeny Bachinin <EABachinin at salutedevices.com>
> ---
> Patch is based on:
> - v5 of Linux patch series
>    https://lore.kernel.org/linux-amlogic/20240610084032.3096614-1-adeep@lexina.in/
> 
> Tested:
> * on A1, AXG.

+ gxl (S905W)

Tested-by: Viacheslav Bocharov <adeep at lexina.in>


> * U-boot CI: https://github.com/u-boot/u-boot/pull/740/checks
> 
> ---
> Evgeny Bachinin (3):
>        arm: meson: unify type being used for socinfo
>        arm: meson: sm: get rid of SM_CHIP_ID_SIZE
>        arch: arm: meson: support Amlogic chip_id v1 and v2
> 
>   arch/arm/include/asm/arch-meson/boot.h |  14 ++++
>   arch/arm/include/asm/arch-meson/sm.h   |  48 ++++++++++++-
>   arch/arm/mach-meson/board-info.c       |  13 ++--
>   arch/arm/mach-meson/sm.c               | 120 ++++++++++++++++++++++++++++++---
>   4 files changed, 179 insertions(+), 16 deletions(-)
> ---
> base-commit: 6d41f0a39d6423c8e57e92ebbe9f8c0333a63f72
> change-id: 20250208-meson_chip_id_all_vers-8ed402afae36
> 
> Best regards,



More information about the U-Boot mailing list