aboutsummaryrefslogtreecommitdiffstats
path: root/roms/skiboot/test/sreset_world/sreset_kernel/sreset_kernel.S
diff options
context:
space:
mode:
authorAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
committerAngelos Mouzakitis <a.mouzakitis@virtualopensystems.com>2023-10-10 14:33:42 +0000
commitaf1a266670d040d2f4083ff309d732d648afba2a (patch)
tree2fc46203448ddcc6f81546d379abfaeb323575e9 /roms/skiboot/test/sreset_world/sreset_kernel/sreset_kernel.S
parente02cda008591317b1625707ff8e115a4841aa889 (diff)
Add submodule dependency filesHEADmaster
Change-Id: Iaf8d18082d3991dec7c0ebbea540f092188eb4ec
Diffstat (limited to 'roms/skiboot/test/sreset_world/sreset_kernel/sreset_kernel.S')
-rw-r--r--roms/skiboot/test/sreset_world/sreset_kernel/sreset_kernel.S99
1 files changed, 99 insertions, 0 deletions
diff --git a/roms/skiboot/test/sreset_world/sreset_kernel/sreset_kernel.S b/roms/skiboot/test/sreset_world/sreset_kernel/sreset_kernel.S
new file mode 100644
index 000000000..08960d589
--- /dev/null
+++ b/roms/skiboot/test/sreset_world/sreset_kernel/sreset_kernel.S
@@ -0,0 +1,99 @@
+// SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
+/*
+ * Test the SRESET OPAL call in Mambo by
+ * having a bit of fun printing 'Hello World' from the SRESET vector.
+ *
+ * Copyright 2013-2017 IBM Corp.
+ */
+
+ . = 0x0
+ .globl _start
+_start:
+/*
+ * Save some values passed in from skiboot into registers that are
+ * non-volatile over OPAL calls.
+ * r8 is the OPAL base
+ * r9 is the OPAL entry point point
+ */
+ mr %r13, %r8
+ mr %r14, %r9
+
+ bl here
+here: mflr %r8 /* work out where we are running */
+ subi %r8, %r8, here - _start
+ /* Stash OPAL base and entry point somewhere SRESET can find it */
+ li %r6, 0xe0
+ std %r13, 0(%r6)
+ std %r14, 8(%r6)
+ std %r8, 16(%r6)
+ addi %r6, %r8, sreset_code_end - _start
+ addi %r7, %r8, sreset_code - _start
+ li %r10, 0x100
+c:
+ lwa %r9, 0(%r7)
+ stw %r9, 0(%r10)
+ addi %r7,%r7,4
+ addi %r10,%r10,4
+ cmpd %r7,%r6
+ bne c
+ sync
+ icbi 0,%r0
+ sync
+ isync
+
+ li %r0, 1 /* OPAL_CONSOLE_WRITE */
+ li %r3, 0 /* terminal 0 */
+ addi %r4, %r8, len - _start /* ptr to length of string */
+ addi %r5, %r8, str - _start /* ptr to string start */
+ mr %r2, %r13
+ mtctr %r14
+ bctrl
+
+ li %r0, 145 /* OPAL_SIGNAL_SYSTEM_RESET */
+ li %r3, -2 /* All *OTHER* CPUs */
+ mr %r2, %r13
+ mtctr %r14
+ bctrl
+
+ /* We shouldn't get here but if we do, just wait here */
+ b .
+
+sreset_code:
+ li %r6, 0xe0
+ ld %r13, 0(%r6)
+ ld %r14, 8(%r6)
+ ld %r8, 16(%r6) /* "here" */
+ li %r0, 1 /* OPAL_CONSOLE_WRITE */
+ li %r3, 0 /* terminal 0 */
+ li %r4, len2 - _start
+ li %r5, str2 - _start
+ add %r4, %r8, %r4
+ add %r5, %r8, %r5
+ mr %r2, %r13
+ mtctr %r14
+ bctrl
+ li %r0, 5 /* OPAL_CEC_POWER_DOWN */
+ li %r3, 0 /* normal shutdown */
+ mr %r2, %r13
+ mtctr %r14
+ bctrl
+
+ /* We shouldn't get here but if we do, just wait here */
+ b .
+
+sreset_code_end:
+
+len:
+ .long 0x00
+ .long (strend - str)
+str:
+ .string "Hello World!\n"
+strend:
+
+len2:
+ .long 0x00
+ .long (str2end - str2)
+str2:
+ .string "Hello SRESET!\n"
+str2end:
+