[Skiboot] [PATCH 1/3] core: Add support for cec_power_down() on mambo
Michael Ellerman
mpe at ellerman.id.au
Mon Mar 30 20:45:36 AEDT 2015
Currently when running on mambo OPAL_CEC_POWER_DOWN doesn't work, the
simulator keeps running.
We can use the magic mambo support instruction with the right opcode to
ask mambo to stop the simulation.
Signed-off-by: Michael Ellerman <mpe at ellerman.id.au>
---
asm/misc.S | 5 +++++
core/platform.c | 14 ++++++++++++--
include/platform.h | 2 ++
3 files changed, 19 insertions(+), 2 deletions(-)
diff --git a/asm/misc.S b/asm/misc.S
index bbabebc3a803..5e47c9828205 100644
--- a/asm/misc.S
+++ b/asm/misc.S
@@ -69,3 +69,8 @@ mambo_write:
.long 0x000eaeb0
blr
+.global mambo_sim_exit
+mambo_sim_exit:
+ li %r3, 31 /* aka. SimExitCode */
+ .long 0x000eaeb0
+ b .
diff --git a/core/platform.c b/core/platform.c
index f93b141860cb..541fc6c186af 100644
--- a/core/platform.c
+++ b/core/platform.c
@@ -21,6 +21,7 @@
#include <console.h>
#include <timebase.h>
#include <cpu.h>
+#include <chip.h>
struct platform platform;
@@ -59,9 +60,18 @@ static void generic_platform_init(void)
fake_rtc_init();
}
+static int64_t generic_cec_power_down(uint64_t request __unused)
+{
+ if (chip_quirk(QUIRK_MAMBO_CALLOUTS))
+ mambo_sim_exit();
+
+ return OPAL_UNSUPPORTED;
+}
+
static struct platform generic_platform = {
- .name = "generic",
- .init = generic_platform_init,
+ .name = "generic",
+ .init = generic_platform_init,
+ .cec_power_down = generic_cec_power_down,
};
void probe_platform(void)
diff --git a/include/platform.h b/include/platform.h
index be5999ba344f..80aa8babbe43 100644
--- a/include/platform.h
+++ b/include/platform.h
@@ -177,4 +177,6 @@ extern int resource_loaded(enum resource_id id, uint32_t idx);
extern int wait_for_resource_loaded(enum resource_id id, uint32_t idx);
+extern void mambo_sim_exit(void);
+
#endif /* __PLATFORM_H */
--
2.1.0
More information about the Skiboot
mailing list