mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-14 00:47:26 +00:00
c6d5809fe4
Since commit 8891410c729b ("MLK-19848 mx6dq: Fix chip version issue for rev1.3") it's not possible to call the HAB API functions on i.MX6DQ SoC Rev 1.3: Authenticate image from DDR location 0x12000000... undefined instruction pc : [<412c00dc>] lr : [<8ff560bc>] reloc pc : [<c8b6d0dc>] lr : [<178030bc>] sp : 8ef444a8 ip : 126e8068 fp : 8ff59aa8 r10: 8ffd51e4 r9 : 8ef50eb0 r8 : 006e8000 r7 : 00000000 r6 : 126ea01f r5 : 0000002b r4 : 126e8000 r3 : 412c00dd r2 : 00000001 r1 : 00000001 r0 : 00000063 Flags: nzCv IRQs off FIQs off Mode SVC_32 Resetting CPU ... resetting ... The hab.h code is defining the HAB API base address according to the old SoC revision number, thus failing when calling the HAB API authenticate_image() function. Fix this issue by using mx6dq rev 1.3 instead of mx6dq rev 1.5. Signed-off-by: Breno Lima <breno.lima@nxp.com> Reviewed-by: Ye Li <ye.li@nxp.com> Signed-off-by: Peng Fan <peng.fan@nxp.com>
93 lines
2.9 KiB
C
93 lines
2.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* (C) Copyright 2014 Freescale Semiconductor, Inc.
|
|
*/
|
|
|
|
#define MXC_CPU_MX23 0x23
|
|
#define MXC_CPU_MX25 0x25
|
|
#define MXC_CPU_MX27 0x27
|
|
#define MXC_CPU_MX28 0x28
|
|
#define MXC_CPU_MX31 0x31
|
|
#define MXC_CPU_MX35 0x35
|
|
#define MXC_CPU_MX51 0x51
|
|
#define MXC_CPU_MX53 0x53
|
|
#define MXC_CPU_MX6SL 0x60
|
|
#define MXC_CPU_MX6DL 0x61
|
|
#define MXC_CPU_MX6SX 0x62
|
|
#define MXC_CPU_MX6Q 0x63
|
|
#define MXC_CPU_MX6UL 0x64
|
|
#define MXC_CPU_MX6ULL 0x65
|
|
#define MXC_CPU_MX6ULZ 0x6B
|
|
#define MXC_CPU_MX6SOLO 0x66 /* dummy */
|
|
#define MXC_CPU_MX6SLL 0x67
|
|
#define MXC_CPU_MX6D 0x6A
|
|
#define MXC_CPU_MX6DP 0x68
|
|
#define MXC_CPU_MX6QP 0x69
|
|
#define MXC_CPU_MX7S 0x71 /* dummy ID */
|
|
#define MXC_CPU_MX7D 0x72
|
|
#define MXC_CPU_IMX8MQ 0x82
|
|
#define MXC_CPU_IMX8MD 0x83 /* dummy ID */
|
|
#define MXC_CPU_IMX8MQL 0x84 /* dummy ID */
|
|
#define MXC_CPU_IMX8MM 0x85 /* dummy ID */
|
|
#define MXC_CPU_IMX8MML 0x86 /* dummy ID */
|
|
#define MXC_CPU_IMX8MMD 0x87 /* dummy ID */
|
|
#define MXC_CPU_IMX8MMDL 0x88 /* dummy ID */
|
|
#define MXC_CPU_IMX8MMS 0x89 /* dummy ID */
|
|
#define MXC_CPU_IMX8MMSL 0x8a /* dummy ID */
|
|
#define MXC_CPU_IMX8MN 0x8b /* dummy ID */
|
|
#define MXC_CPU_IMX8MND 0x8c /* dummy ID */
|
|
#define MXC_CPU_IMX8MNS 0x8d /* dummy ID */
|
|
#define MXC_CPU_IMX8MNL 0x8e /* dummy ID */
|
|
#define MXC_CPU_IMX8MNDL 0x8f /* dummy ID */
|
|
#define MXC_CPU_IMX8MNSL 0x181 /* dummy ID */
|
|
#define MXC_CPU_IMX8MNUQ 0x182 /* dummy ID */
|
|
#define MXC_CPU_IMX8MNUD 0x183 /* dummy ID */
|
|
#define MXC_CPU_IMX8MNUS 0x184 /* dummy ID */
|
|
#define MXC_CPU_IMX8MP 0x185/* dummy ID */
|
|
#define MXC_CPU_IMX8MP6 0x186 /* dummy ID */
|
|
#define MXC_CPU_IMX8MPL 0x187 /* dummy ID */
|
|
#define MXC_CPU_IMX8MPD 0x188 /* dummy ID */
|
|
#define MXC_CPU_IMX8QXP_A0 0x90 /* dummy ID */
|
|
#define MXC_CPU_IMX8QM 0x91 /* dummy ID */
|
|
#define MXC_CPU_IMX8QXP 0x92 /* dummy ID */
|
|
#define MXC_CPU_MX7ULP 0xE1 /* Temporally hard code */
|
|
#define MXC_CPU_VF610 0xF6 /* dummy ID */
|
|
|
|
#define MXC_SOC_MX6 0x60
|
|
#define MXC_SOC_MX7 0x70
|
|
#define MXC_SOC_IMX8M 0x80
|
|
#define MXC_SOC_IMX8 0x90 /* dummy */
|
|
#define MXC_SOC_MX7ULP 0xE0 /* dummy */
|
|
|
|
#define CHIP_REV_1_0 0x10
|
|
#define CHIP_REV_1_1 0x11
|
|
#define CHIP_REV_1_2 0x12
|
|
#define CHIP_REV_1_3 0x13
|
|
#define CHIP_REV_1_5 0x15
|
|
#define CHIP_REV_2_0 0x20
|
|
#define CHIP_REV_2_1 0x21
|
|
#define CHIP_REV_2_2 0x22
|
|
#define CHIP_REV_2_5 0x25
|
|
#define CHIP_REV_3_0 0x30
|
|
|
|
#define CHIP_REV_A 0x0
|
|
#define CHIP_REV_B 0x1
|
|
#define CHIP_REV_C 0x2
|
|
|
|
#define BOARD_REV_1_0 0x0
|
|
#define BOARD_REV_2_0 0x1
|
|
#define BOARD_VER_OFFSET 0x8
|
|
|
|
#define CS0_128 0
|
|
#define CS0_64M_CS1_64M 1
|
|
#define CS0_64M_CS1_32M_CS2_32M 2
|
|
#define CS0_32M_CS1_32M_CS2_32M_CS3_32M 3
|
|
|
|
u32 get_imx_reset_cause(void);
|
|
ulong get_systemPLLCLK(void);
|
|
ulong get_FCLK(void);
|
|
ulong get_HCLK(void);
|
|
ulong get_BCLK(void);
|
|
ulong get_PERCLK1(void);
|
|
ulong get_PERCLK2(void);
|
|
ulong get_PERCLK3(void);
|