Marri Devender Rao | 7847960 | 2020-01-06 03:45:11 -0600 | [diff] [blame] | 1 | #include "phalerror/phal_error.hpp" |
Ramesh Iyyar | b181d3b | 2019-10-17 13:39:10 -0500 | [diff] [blame] | 2 | |
Marri Devender Rao | 7847960 | 2020-01-06 03:45:11 -0600 | [diff] [blame] | 3 | #include <libipl.H> |
Ramesh Iyyar | b181d3b | 2019-10-17 13:39:10 -0500 | [diff] [blame] | 4 | |
Ramesh Iyyar | b181d3b | 2019-10-17 13:39:10 -0500 | [diff] [blame] | 5 | #include <phosphor-logging/log.hpp> |
| 6 | #include <registration.hpp> |
| 7 | namespace openpower |
| 8 | { |
| 9 | namespace phal |
| 10 | { |
| 11 | |
| 12 | using namespace phosphor::logging; |
Ramesh Iyyar | b181d3b | 2019-10-17 13:39:10 -0500 | [diff] [blame] | 13 | |
| 14 | /** |
| 15 | * @brief Starts the self boot engine on POWER processor position 0 |
| 16 | * to kick off a boot. |
| 17 | * @return void |
| 18 | */ |
| 19 | void startHost() |
| 20 | { |
Marri Devender Rao | 7847960 | 2020-01-06 03:45:11 -0600 | [diff] [blame] | 21 | // add callback methods for debug traces and for boot failures |
| 22 | openpower::pel::addBootErrorCallbacks(); |
| 23 | |
| 24 | // callback method will be called upon failure which will create the PEL |
Ramesh Iyyar | b181d3b | 2019-10-17 13:39:10 -0500 | [diff] [blame] | 25 | if (ipl_init() != 0) |
| 26 | { |
| 27 | log<level::ERR>("ipl_init failed"); |
Marri Devender Rao | 7847960 | 2020-01-06 03:45:11 -0600 | [diff] [blame] | 28 | throw std::runtime_error("Boot initialization failed"); |
Ramesh Iyyar | b181d3b | 2019-10-17 13:39:10 -0500 | [diff] [blame] | 29 | } |
| 30 | |
Marri Devender Rao | 7847960 | 2020-01-06 03:45:11 -0600 | [diff] [blame] | 31 | // callback method will be called upon failure which will create the PEL |
| 32 | int rc = ipl_run_major(0); |
| 33 | if (rc > 0) |
Ramesh Iyyar | b181d3b | 2019-10-17 13:39:10 -0500 | [diff] [blame] | 34 | { |
| 35 | log<level::ERR>("step 0 failed to start the host"); |
Marri Devender Rao | 7847960 | 2020-01-06 03:45:11 -0600 | [diff] [blame] | 36 | throw std::runtime_error("Failed to execute host start boot step"); |
Ramesh Iyyar | b181d3b | 2019-10-17 13:39:10 -0500 | [diff] [blame] | 37 | } |
| 38 | } |
| 39 | |
| 40 | REGISTER_PROCEDURE("startHost", startHost); |
| 41 | |
| 42 | } // namespace phal |
| 43 | } // namespace openpower |