146470a38SPatrick Venture #include "globalhandler.hpp"
20b02be92SPatrick Venture 
346470a38SPatrick Venture #include "utils.hpp"
446470a38SPatrick Venture 
5*194375f2SWilliam A. Kennington III #include <ipmid/api.h>
60b02be92SPatrick Venture 
70b02be92SPatrick Venture #include <phosphor-logging/elog-errors.hpp>
80b02be92SPatrick Venture #include <phosphor-logging/log.hpp>
934e3d3f1SNagaraju Goruganti #include <string>
100b02be92SPatrick Venture #include <xyz/openbmc_project/Common/error.hpp>
110b02be92SPatrick Venture #include <xyz/openbmc_project/State/BMC/server.hpp>
120b02be92SPatrick Venture 
1334e3d3f1SNagaraju Goruganti static constexpr auto bmcStateRoot = "/xyz/openbmc_project/state";
1434e3d3f1SNagaraju Goruganti static constexpr auto bmcStateIntf = "xyz.openbmc_project.State.BMC";
1534e3d3f1SNagaraju Goruganti static constexpr auto reqTransition = "RequestedBMCTransition";
1634e3d3f1SNagaraju Goruganti static constexpr auto match = "bmc0";
1734e3d3f1SNagaraju Goruganti 
1834e3d3f1SNagaraju Goruganti using namespace phosphor::logging;
1934e3d3f1SNagaraju Goruganti using BMC = sdbusplus::xyz::openbmc_project::State::server::BMC;
2098a23840SMatthew Barth 
2198a23840SMatthew Barth void register_netfn_global_functions() __attribute__((constructor));
2298a23840SMatthew Barth 
2334e3d3f1SNagaraju Goruganti void resetBMC()
2498a23840SMatthew Barth {
2534e3d3f1SNagaraju Goruganti     sdbusplus::bus::bus bus{ipmid_get_sd_bus_connection()};
2698a23840SMatthew Barth 
270b02be92SPatrick Venture     auto bmcStateObj =
280b02be92SPatrick Venture         ipmi::getDbusObject(bus, bmcStateIntf, bmcStateRoot, match);
2934e3d3f1SNagaraju Goruganti 
3034e3d3f1SNagaraju Goruganti     auto service = ipmi::getService(bus, bmcStateIntf, bmcStateObj.first);
3134e3d3f1SNagaraju Goruganti 
3234e3d3f1SNagaraju Goruganti     ipmi::setDbusProperty(bus, service, bmcStateObj.first, bmcStateIntf,
330b02be92SPatrick Venture                           reqTransition,
340b02be92SPatrick Venture                           convertForMessage(BMC::Transition::Reboot));
3598a23840SMatthew Barth }
3698a23840SMatthew Barth 
3734e3d3f1SNagaraju Goruganti ipmi_ret_t ipmi_global_reset(ipmi_netfn_t netfn, ipmi_cmd_t cmd,
3898a23840SMatthew Barth                              ipmi_request_t request, ipmi_response_t response,
3998a23840SMatthew Barth                              ipmi_data_len_t data_len, ipmi_context_t context)
4098a23840SMatthew Barth {
4134e3d3f1SNagaraju Goruganti     try
42bc759884SNan Li     {
4334e3d3f1SNagaraju Goruganti         resetBMC();
4434e3d3f1SNagaraju Goruganti     }
4534e3d3f1SNagaraju Goruganti     catch (std::exception& e)
4634e3d3f1SNagaraju Goruganti     {
4734e3d3f1SNagaraju Goruganti         log<level::ERR>(e.what());
4834e3d3f1SNagaraju Goruganti         return IPMI_CC_UNSPECIFIED_ERROR;
4934e3d3f1SNagaraju Goruganti     }
50bc759884SNan Li 
51bc759884SNan Li     // Status code.
52bc759884SNan Li     ipmi_ret_t rc = IPMI_CC_OK;
53bc759884SNan Li     *data_len = 0;
54bc759884SNan Li     return rc;
55bc759884SNan Li }
5698a23840SMatthew Barth 
5798a23840SMatthew Barth void register_netfn_global_functions()
5898a23840SMatthew Barth {
590573237fSTom     // Cold Reset
6034e3d3f1SNagaraju Goruganti     ipmi_register_callback(NETFUN_APP, IPMI_CMD_COLD_RESET, NULL,
6134e3d3f1SNagaraju Goruganti                            ipmi_global_reset, PRIVILEGE_ADMIN);
62bc759884SNan Li 
630573237fSTom     // <Warm Reset>
6434e3d3f1SNagaraju Goruganti     ipmi_register_callback(NETFUN_APP, IPMI_CMD_WARM_RESET, NULL,
6534e3d3f1SNagaraju Goruganti                            ipmi_global_reset, PRIVILEGE_ADMIN);
6698a23840SMatthew Barth 
6798a23840SMatthew Barth     return;
6898a23840SMatthew Barth }
69