diff options
author | Nicholas Piggin <npiggin@gmail.com> | 2017-09-20 16:56:03 +1000 |
---|---|---|
committer | Stewart Smith <stewart@linux.vnet.ibm.com> | 2017-09-20 23:25:01 -0500 |
commit | 5e09fe1f19d3f56b1cebb44439da5b5de6e1fccd (patch) | |
tree | 159d5c1c26a8068df3ec6cc623f5db7e3bfa8310 /include/processor.h | |
parent | 5779c11fdc57c4dc474beb00f044f34ec1c58368 (diff) | |
download | skiboot-5e09fe1f19d3f56b1cebb44439da5b5de6e1fccd.zip skiboot-5e09fe1f19d3f56b1cebb44439da5b5de6e1fccd.tar.gz skiboot-5e09fe1f19d3f56b1cebb44439da5b5de6e1fccd.tar.bz2 |
core: POWER9 implement OPAL_SIGNAL_SYSTEM_RESET
This implements OPAL_SIGNAL_SYSTEM_RESET, using scom registers to
quiesce the target thread and raise a system reset exception on it.
It has been tested on DD2 with stop0 ESL=0 and ESL=1 shallow power
saving modes.
DD1 is not implemented because it is sufficiently different as to
make support difficult.
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
[stewart@linux.vnet.ibm.com: fixup hdat_to_dt test]
Signed-off-by: Stewart Smith <stewart@linux.vnet.ibm.com>
Diffstat (limited to 'include/processor.h')
-rw-r--r-- | include/processor.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/include/processor.h b/include/processor.h index 2e1ac37..da48304 100644 --- a/include/processor.h +++ b/include/processor.h @@ -206,6 +206,21 @@ #include <compiler.h> #include <stdint.h> +#include <stdbool.h> + +static inline bool is_power9n(uint32_t version) +{ + if (PVR_TYPE(version) != PVR_TYPE_P9) + return false; + /* + * Bit 13 tells us: + * 0 = Scale out (aka Nimbus) + * 1 = Scale up (aka Cumulus) + */ + if ((version >> 13) & 1) + return false; + return true; +} /* * SMT priority |