summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMinda Chen <minda.chen@starfivetech.com>2023-11-13 09:43:07 +0300
committerMinda Chen <minda.chen@starfivetech.com>2023-12-22 06:39:37 +0300
commit4cb7c94a83a60276f5516e5ad9702488acf0bb78 (patch)
treeed6e306f450d0682a7cde53d6918b248d3c5ed4c
parent4472e9c5c616781481f882ea1d36b408fc8eba6d (diff)
downloadu-boot-4cb7c94a83a60276f5516e5ad9702488acf0bb78.tar.xz
dts: set rtos opensbi domain
set rtos opensbi domain to boot rtos from opensbi. Signed-off-by: Minda Chen <minda.chen@starfivetech.com>
-rw-r--r--arch/riscv/dts/jh7110.dtsi55
1 files changed, 55 insertions, 0 deletions
diff --git a/arch/riscv/dts/jh7110.dtsi b/arch/riscv/dts/jh7110.dtsi
index f3f830f5f3..851cce1a96 100644
--- a/arch/riscv/dts/jh7110.dtsi
+++ b/arch/riscv/dts/jh7110.dtsi
@@ -15,6 +15,56 @@
#address-cells = <2>;
#size-cells = <2>;
+ chosen {
+ opensbi-domains {
+ compatible = "opensbi,domain,config";
+
+ rpmsg_shmem: rpmsg_shmem {
+ compatible = "opensbi,domain,memregion";
+ base = <0x0 0x6e400000>;
+ order = <22>;
+ };
+
+ rtcode: rtcode {
+ compatible = "opensbi,domain,memregion";
+ base = <0x0 0x6e800000>;
+ order = <23>;
+ };
+
+ rtheap: rtheap {
+ compatible = "opensbi,domain,memregion";
+ base = <0x0 0x6f000000>;
+ order = <24>;
+ };
+
+ allmem: allmem {
+ compatible = "opensbi,domain,memregion";
+ base = <0x0 0x0>;
+ order = <64>;
+ };
+
+ udomain: u-domain {
+ compatible = "opensbi,domain,instance";
+ possible-harts = <&cpu0 &cpu1 &cpu2 &cpu3>;
+ regions = <&rpmsg_shmem 0x3f>, <&rtcode 0x0>, <&rtheap 0x0>, <&allmem 0x3f>;
+ next-addr = <0x0 0x40200000>;
+ boot-hart = <&cpu1>;
+ system-reset-allowed;
+ system-suspend-allowed;
+ };
+
+ rtdomain: rt-domain {
+ compatible = "opensbi,domain,instance";
+ possible-harts = <&cpu4>;
+ regions = <&rpmsg_shmem 0x3f>, <&rtcode 0x3f>, <&rtheap 0x3f>, <&allmem 0x3f>;
+ boot-hart = <&cpu4>;
+ next-arg1 = <0x0 0x0>;
+ next-addr = <0x0 0x6e800000>;
+ next-mode = <0x1>;
+ };
+ };
+ };
+
cpus {
#address-cells = <1>;
#size-cells = <0>;
@@ -37,6 +87,7 @@
next-level-cache = <&cachectrl>;
riscv,isa = "rv64imacu_zba_zbb";
tlb-split;
+ opensbi-domain = <&udomain>;
status = "disabled";
cpu0intctrl: interrupt-controller {
@@ -64,6 +115,7 @@
next-level-cache = <&cachectrl>;
riscv,isa = "rv64imafdcbsux_zba_zbb";
tlb-split;
+ opensbi-domain = <&udomain>;
status = "okay";
cpu1intctrl: interrupt-controller {
@@ -91,6 +143,7 @@
next-level-cache = <&cachectrl>;
riscv,isa = "rv64imafdcbsux_zba_zbb";
tlb-split;
+ opensbi-domain = <&udomain>;
status = "okay";
cpu2intctrl: interrupt-controller {
@@ -118,6 +171,7 @@
next-level-cache = <&cachectrl>;
riscv,isa = "rv64imafdcbsux_zba_zbb";
tlb-split;
+ opensbi-domain = <&udomain>;
status = "okay";
cpu3intctrl: interrupt-controller {
@@ -145,6 +199,7 @@
next-level-cache = <&cachectrl>;
riscv,isa = "rv64imafdcbsux_zba_zbb";
tlb-split;
+ opensbi-domain = <&rtdomain>;
status = "okay";
cpu4intctrl: interrupt-controller {