blob: 780341124a8fe2dd12764596425ec4e30aaebba1 [file] [log] [blame]
Lokesh Vutla6edde292019-06-13 10:29:43 +05301/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * K3: J721E SoC definitions, structures etc.
4 *
Nishanth Menoneaa39c62023-11-01 15:56:03 -05005 * (C) Copyright (C) 2018-2019 Texas Instruments Incorporated - https://www.ti.com/
Lokesh Vutla6edde292019-06-13 10:29:43 +05306 */
7#ifndef __ASM_ARCH_J721E_HARDWARE_H
8#define __ASM_ARCH_J721E_HARDWARE_H
9
10#include <config.h>
Simon Glass4dcacfc2020-05-10 11:40:13 -060011#ifndef __ASSEMBLY__
12#include <linux/bitops.h>
13#endif
Lokesh Vutla6edde292019-06-13 10:29:43 +053014
Andrew Davis990ec702022-10-07 14:22:05 -050015#define WKUP_CTRL_MMR0_BASE 0x43000000
16#define MCU_CTRL_MMR0_BASE 0x40f00000
Lokesh Vutla6edde292019-06-13 10:29:43 +053017#define CTRL_MMR0_BASE 0x00100000
Lokesh Vutla6edde292019-06-13 10:29:43 +053018
Andrew Davis990ec702022-10-07 14:22:05 -050019#define CTRLMMR_MAIN_DEVSTAT (CTRL_MMR0_BASE + 0x30)
Lokesh Vutla6edde292019-06-13 10:29:43 +053020#define MAIN_DEVSTAT_BOOT_MODE_B_MASK BIT(0)
21#define MAIN_DEVSTAT_BOOT_MODE_B_SHIFT 0
22#define MAIN_DEVSTAT_BKUP_BOOTMODE_MASK GENMASK(3, 1)
23#define MAIN_DEVSTAT_BKUP_BOOTMODE_SHIFT 1
24#define MAIN_DEVSTAT_PRIM_BOOTMODE_MMC_PORT_MASK BIT(6)
25#define MAIN_DEVSTAT_PRIM_BOOTMODE_PORT_SHIFT 6
Andreas Dannenbergee0f5e62020-05-16 21:05:01 +053026#define MAIN_DEVSTAT_BKUP_MMC_PORT_MASK BIT(7)
27#define MAIN_DEVSTAT_BKUP_MMC_PORT_SHIFT 7
Lokesh Vutla6edde292019-06-13 10:29:43 +053028
Lokesh Vutla6edde292019-06-13 10:29:43 +053029#define CTRLMMR_WKUP_DEVSTAT (WKUP_CTRL_MMR0_BASE + 0x30)
30#define WKUP_DEVSTAT_PRIMARY_BOOTMODE_MASK GENMASK(5, 3)
31#define WKUP_DEVSTAT_PRIMARY_BOOTMODE_SHIFT 3
32#define WKUP_DEVSTAT_MCU_OMLY_MASK BIT(6)
33#define WKUP_DEVSTAT_MCU_ONLY_SHIFT 6
34
Lokesh Vutla8e7bd012020-08-05 22:44:22 +053035/* ROM HANDOFF Structure location */
Bryan Brattlof270537c2022-11-22 13:28:11 -060036#define ROM_EXTENDED_BOOT_DATA_INFO 0x41cffb00
Lokesh Vutla8e7bd012020-08-05 22:44:22 +053037
Andreas Dannenbergd036a212020-01-07 13:15:54 +053038/* MCU SCRATCHPAD usage */
39#define TI_SRAM_SCRATCH_BOARD_EEPROM_START CONFIG_SYS_K3_MCU_SCRATCHPAD_BASE
40
Andrew Davisc178e6d2023-04-06 11:38:15 -050041#if defined(CONFIG_SYS_K3_SPL_ATF) && !defined(__ASSEMBLY__)
42
43#define J721E_DEV_MCU_RTI0 262
44#define J721E_DEV_MCU_RTI1 263
45#define J721E_DEV_MCU_ARMSS0_CPU0 250
46#define J721E_DEV_MCU_ARMSS0_CPU1 251
47
48static const u32 put_device_ids[] = {
49 J721E_DEV_MCU_RTI0,
50 J721E_DEV_MCU_RTI1,
51};
52
53static const u32 put_core_ids[] = {
54 J721E_DEV_MCU_ARMSS0_CPU1,
55 J721E_DEV_MCU_ARMSS0_CPU0, /* Handle CPU0 after CPU1 */
56};
57
58#endif
59
Lokesh Vutla6edde292019-06-13 10:29:43 +053060#endif /* __ASM_ARCH_J721E_HARDWARE_H */