blob: 5aa2282f59a32b811d1b7ce676cf2334b3175a04 [file] [log] [blame]
David Huang61098202022-01-25 20:56:31 +05301/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * K3: J721S2 SoC definitions, structures etc.
4 *
Nishanth Menoneaa39c62023-11-01 15:56:03 -05005 * (C) Copyright (C) 2021 Texas Instruments Incorporated - https://www.ti.com/
David Huang61098202022-01-25 20:56:31 +05306 */
7#ifndef __ASM_ARCH_J721S2_HARDWARE_H
8#define __ASM_ARCH_J721S2_HARDWARE_H
9
David Huang61098202022-01-25 20:56:31 +053010#ifndef __ASSEMBLY__
11#include <linux/bitops.h>
12#endif
13
Andrew Davis990ec702022-10-07 14:22:05 -050014#define WKUP_CTRL_MMR0_BASE 0x43000000
15#define MCU_CTRL_MMR0_BASE 0x40f00000
David Huang61098202022-01-25 20:56:31 +053016#define CTRL_MMR0_BASE 0x00100000
David Huang61098202022-01-25 20:56:31 +053017
Andrew Davis990ec702022-10-07 14:22:05 -050018#define CTRLMMR_MAIN_DEVSTAT (CTRL_MMR0_BASE + 0x30)
David Huang61098202022-01-25 20:56:31 +053019#define MAIN_DEVSTAT_BOOT_MODE_B_MASK BIT(0)
20#define MAIN_DEVSTAT_BOOT_MODE_B_SHIFT 0
21#define MAIN_DEVSTAT_BKUP_BOOTMODE_MASK GENMASK(3, 1)
22#define MAIN_DEVSTAT_BKUP_BOOTMODE_SHIFT 1
23#define MAIN_DEVSTAT_PRIM_BOOTMODE_MMC_PORT_MASK BIT(6)
24#define MAIN_DEVSTAT_PRIM_BOOTMODE_PORT_SHIFT 6
25#define MAIN_DEVSTAT_BKUP_MMC_PORT_MASK BIT(7)
26#define MAIN_DEVSTAT_BKUP_MMC_PORT_SHIFT 7
27
David Huang61098202022-01-25 20:56:31 +053028#define CTRLMMR_WKUP_DEVSTAT (WKUP_CTRL_MMR0_BASE + 0x30)
29#define WKUP_DEVSTAT_PRIMARY_BOOTMODE_MASK GENMASK(5, 3)
30#define WKUP_DEVSTAT_PRIMARY_BOOTMODE_SHIFT 3
31#define WKUP_DEVSTAT_MCU_OMLY_MASK BIT(6)
32#define WKUP_DEVSTAT_MCU_ONLY_SHIFT 6
33
David Huang61098202022-01-25 20:56:31 +053034/* ROM HANDOFF Structure location */
Bryan Brattlof270537c2022-11-22 13:28:11 -060035#define ROM_EXTENDED_BOOT_DATA_INFO 0x41cfdb00
David Huang61098202022-01-25 20:56:31 +053036
37/* MCU SCRATCHPAD usage */
38#define TI_SRAM_SCRATCH_BOARD_EEPROM_START CONFIG_SYS_K3_MCU_SCRATCHPAD_BASE
39
Andrew Davisc178e6d2023-04-06 11:38:15 -050040#if defined(CONFIG_SYS_K3_SPL_ATF) && !defined(__ASSEMBLY__)
41
42#define J721S2_DEV_MCU_RTI0 295
43#define J721S2_DEV_MCU_RTI1 296
44#define J721S2_DEV_MCU_ARMSS0_CPU0 284
45#define J721S2_DEV_MCU_ARMSS0_CPU1 285
46
47static const u32 put_device_ids[] = {
48 J721S2_DEV_MCU_RTI0,
49 J721S2_DEV_MCU_RTI1,
50};
51
52static const u32 put_core_ids[] = {
53 J721S2_DEV_MCU_ARMSS0_CPU1,
54 J721S2_DEV_MCU_ARMSS0_CPU0, /* Handle CPU0 after CPU1 */
55};
56
57#endif
58
David Huang61098202022-01-25 20:56:31 +053059#endif /* __ASM_ARCH_J721S2_HARDWARE_H */