1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
.. _OPAL_CEC_POWER_DOWN:
OPAL_CEC_POWER_DOWN
===================
.. code-block:: c
#define OPAL_CEC_POWER_DOWN 5
int64 opal_cec_power_down(uint64 request)
As powering down the system is likely an asynchronous operation that we
have to wait for a service processor to do, :ref:`OPAL_CEC_POWER_DOWN`
should be called like the example code below:
.. code-block:: c
int rc = OPAL_BUSY;
do {
rc = opal_cec_power_down(0);
if (rc == OPAL_BUSY_EVENT)
opal_poll_events(NULL);
} while (rc == OPAL_BUSY || rc == OPAL_BUSY_EVENT);
for (;;)
opal_poll_events(NULL);
Arguments
---------
`uint64 request` values as follows:
0
Power down normally
1
Power down immediately
This OPAL call requests OPAL to power down the system. The exact difference
between a normal and immediate shutdown is platform specific.
Current Linux kernels just use power down normally (0). It is valid for a
platform to only support some types of power down operations.
Return Values
-------------
:ref:`OPAL_SUCCESS`
the power down request was successful.
This may/may not result in immediate power down. An OS should
spin in a loop after getting :ref:`OPAL_SUCCESS` as it is likely that there
will be a delay before instructions stop being executed.
:ref:`OPAL_BUSY`
unable to power down, try again later.
:ref:`OPAL_BUSY_EVENT`
Unable to power down, call :ref:`OPAL_POLL_EVENTS` and try again.
:ref:`OPAL_PARAMETER`
a parameter was incorrect
:ref:`OPAL_INTERNAL_ERROR`
Something went wrong, and waiting and trying again is unlikely to be
successful. Although, considering that in a shutdown code path, there's
unlikely to be any other valid option to take, retrying is perfectly valid.
In older OPAL versions (prior to skiboot v5.9), on IBM FSP systems, this
return code was returned erroneously instead of :ref:`OPAL_BUSY_EVENT` during an
FSP Reset/Reload.
:ref:`OPAL_UNSUPPORTED`
this platform does not support being powered off. Practically speaking, this
should **never** be returned, but in various simulation or bring-up situations,
it's plausible it is, so code should handle this gracefully.
|