forked from libretro/Lakka-LibreELEC
5a9f30cb89
remove upstreamed Allwinner patches
rebase Allwinner patches
remove upstreamed Amlogic patches
add CONFIG_SYS_LOAD_ADDR=0x1000000 to WeTek configs
add CONFIG_SYS_LOAD_ADDR=0x43e00000 to Odroid XU4 config
remove obsolete NXP patch
- d9a6f0eed6
130 lines
4.7 KiB
Diff
130 lines
4.7 KiB
Diff
From 7719c6f06b698b3a32248dea61710f222ee8d7a1 Mon Sep 17 00:00:00 2001
|
|
From: Samuel Holland <samuel@sholland.org>
|
|
Date: Sat, 9 Oct 2021 22:43:26 -0500
|
|
Subject: [PATCH 11/13] arm: psci: Add definitions for PSCI v1.1
|
|
|
|
Add the new option, function IDs, and prototypes for PSCI v1.1
|
|
implementations. In the process, fix some issues with the existing
|
|
definitions:
|
|
- Fix the incorrectly-named ARM_PSCI_0_2_FN64_SYSTEM_RESET2.
|
|
- Replace the deprecated "affinity_level" naming with "power_level".
|
|
|
|
Signed-off-by: Samuel Holland <samuel@sholland.org>
|
|
---
|
|
arch/arm/cpu/armv7/Kconfig | 3 +++
|
|
arch/arm/cpu/armv8/fwcall.c | 2 +-
|
|
arch/arm/include/asm/psci.h | 9 +++++++--
|
|
arch/arm/include/asm/system.h | 14 +++++++++-----
|
|
arch/arm/lib/psci-dt.c | 2 ++
|
|
5 files changed, 22 insertions(+), 8 deletions(-)
|
|
|
|
diff --git a/arch/arm/cpu/armv7/Kconfig b/arch/arm/cpu/armv7/Kconfig
|
|
index 60bb0a9e1ec4..06b477619334 100644
|
|
--- a/arch/arm/cpu/armv7/Kconfig
|
|
+++ b/arch/arm/cpu/armv7/Kconfig
|
|
@@ -49,6 +49,9 @@ choice
|
|
help
|
|
Select the supported PSCI version.
|
|
|
|
+config ARMV7_PSCI_1_1
|
|
+ bool "PSCI V1.1"
|
|
+
|
|
config ARMV7_PSCI_1_0
|
|
bool "PSCI V1.0"
|
|
|
|
diff --git a/arch/arm/cpu/armv8/fwcall.c b/arch/arm/cpu/armv8/fwcall.c
|
|
index 16914dc1eed6..87de09979b18 100644
|
|
--- a/arch/arm/cpu/armv8/fwcall.c
|
|
+++ b/arch/arm/cpu/armv8/fwcall.c
|
|
@@ -103,7 +103,7 @@ void __noreturn psci_system_reset2(u32 reset_level, u32 cookie)
|
|
{
|
|
struct pt_regs regs;
|
|
|
|
- regs.regs[0] = ARM_PSCI_0_2_FN64_SYSTEM_RESET2;
|
|
+ regs.regs[0] = ARM_PSCI_1_1_FN64_SYSTEM_RESET2;
|
|
regs.regs[1] = PSCI_RESET2_TYPE_VENDOR | reset_level;
|
|
regs.regs[2] = cookie;
|
|
if (use_smc_for_psci)
|
|
diff --git a/arch/arm/include/asm/psci.h b/arch/arm/include/asm/psci.h
|
|
index 67e9234066b0..aa351867eee7 100644
|
|
--- a/arch/arm/include/asm/psci.h
|
|
+++ b/arch/arm/include/asm/psci.h
|
|
@@ -22,8 +22,9 @@
|
|
#include <linux/bitops.h>
|
|
#endif
|
|
|
|
-#define ARM_PSCI_VER_1_0 (0x00010000)
|
|
#define ARM_PSCI_VER_0_2 (0x00000002)
|
|
+#define ARM_PSCI_VER_1_0 (0x00010000)
|
|
+#define ARM_PSCI_VER_1_1 (0x00010001)
|
|
|
|
/* PSCI 0.1 interface */
|
|
#define ARM_PSCI_FN_BASE 0x95c1ba5e
|
|
@@ -68,7 +69,6 @@
|
|
#define ARM_PSCI_0_2_FN64_AFFINITY_INFO ARM_PSCI_0_2_FN64(4)
|
|
#define ARM_PSCI_0_2_FN64_MIGRATE ARM_PSCI_0_2_FN64(5)
|
|
#define ARM_PSCI_0_2_FN64_MIGRATE_INFO_UP_CPU ARM_PSCI_0_2_FN64(7)
|
|
-#define ARM_PSCI_0_2_FN64_SYSTEM_RESET2 ARM_PSCI_0_2_FN64(18)
|
|
|
|
/* PSCI 1.0 interface */
|
|
#define ARM_PSCI_1_0_FN_PSCI_FEATURES ARM_PSCI_0_2_FN(10)
|
|
@@ -86,6 +86,11 @@
|
|
#define ARM_PSCI_1_0_FN64_STAT_RESIDENCY ARM_PSCI_0_2_FN64(16)
|
|
#define ARM_PSCI_1_0_FN64_STAT_COUNT ARM_PSCI_0_2_FN64(17)
|
|
|
|
+/* PSCI 1.1 interface */
|
|
+#define ARM_PSCI_1_1_FN_SYSTEM_RESET2 ARM_PSCI_0_2_FN(18)
|
|
+
|
|
+#define ARM_PSCI_1_1_FN64_SYSTEM_RESET2 ARM_PSCI_0_2_FN64(18)
|
|
+
|
|
/* 1KB stack per core */
|
|
#define ARM_PSCI_STACK_SHIFT 10
|
|
#define ARM_PSCI_STACK_SIZE (1 << ARM_PSCI_STACK_SHIFT)
|
|
diff --git a/arch/arm/include/asm/system.h b/arch/arm/include/asm/system.h
|
|
index f75eea16b36c..02effcc6cc38 100644
|
|
--- a/arch/arm/include/asm/system.h
|
|
+++ b/arch/arm/include/asm/system.h
|
|
@@ -556,17 +556,21 @@ void mmu_page_table_flush(unsigned long start, unsigned long stop);
|
|
#ifdef CONFIG_ARMV7_PSCI
|
|
void psci_arch_cpu_entry(void);
|
|
void psci_arch_init(void);
|
|
+
|
|
u32 psci_version(void);
|
|
-s32 psci_features(u32 function_id, u32 psci_fid);
|
|
+s32 psci_cpu_suspend(u32 function_id, u32 power_state, u32 pc, u32 context_id);
|
|
s32 psci_cpu_off(void);
|
|
-s32 psci_cpu_on(u32 function_id, u32 target_cpu, u32 pc,
|
|
- u32 context_id);
|
|
-s32 psci_affinity_info(u32 function_id, u32 target_affinity,
|
|
- u32 lowest_affinity_level);
|
|
+s32 psci_cpu_on(u32 function_id, u32 target_cpu, u32 pc, u32 context_id);
|
|
+s32 psci_affinity_info(u32 function_id, u32 target_affinity, u32 power_level);
|
|
u32 psci_migrate_info_type(void);
|
|
void psci_system_off(void);
|
|
void psci_system_reset(void);
|
|
+s32 psci_features(u32 function_id, u32 psci_fid);
|
|
+s32 psci_cpu_default_suspend(u32 function_id, u32 pc, u32 context_id);
|
|
+s32 psci_node_hw_state(u32 function_id, u32 target_cpu, u32 power_level);
|
|
+s32 psci_system_suspend(u32 function_id, u32 pc, u32 context_id);
|
|
+s32 psci_system_reset2(u32 function_id, u32 reset_type, u32 cookie);
|
|
#endif
|
|
|
|
#endif /* __ASSEMBLY__ */
|
|
|
|
diff --git a/arch/arm/lib/psci-dt.c b/arch/arm/lib/psci-dt.c
|
|
index 903b3357048a..ea9d1c8355c2 100644
|
|
--- a/arch/arm/lib/psci-dt.c
|
|
+++ b/arch/arm/lib/psci-dt.c
|
|
@@ -66,6 +66,8 @@ int fdt_psci(void *fdt)
|
|
init_psci_node:
|
|
#if CONFIG_IS_ENABLED(ARMV8_SEC_FIRMWARE_SUPPORT)
|
|
psci_ver = sec_firmware_support_psci_version();
|
|
+#elif defined(CONFIG_ARMV7_PSCI_1_1)
|
|
+ psci_ver = ARM_PSCI_VER_1_1;
|
|
#elif defined(CONFIG_ARMV7_PSCI_1_0) || defined(CONFIG_ARMV8_PSCI)
|
|
psci_ver = ARM_PSCI_VER_1_0;
|
|
#elif defined(CONFIG_ARMV7_PSCI_0_2)
|
|
--
|
|
2.33.0
|
|
|