blob: 24f24fbfdf0d9872af828e0be2fa90362392c96b [file] [log] [blame]
Vishwanatha Subbanna2180b2d2017-06-28 14:05:57 +05301#include "config.h"
Deepak Kodihalli92a63412017-03-17 05:01:00 -05002
Gunnar Mills94df8c92018-09-14 14:50:03 -05003#include "occ_events.hpp"
4#include "occ_manager.hpp"
Chris Cain1be43372021-12-09 19:29:37 -06005#include "powermode.hpp"
Sheldon Bailey16a5adb2025-06-10 14:10:06 -05006#include "utils.hpp"
Gunnar Mills94df8c92018-09-14 14:50:03 -05007
8#include <org/open_power/OCC/Device/error.hpp>
Chris Cain37abe9b2024-10-31 17:20:31 -05009#include <phosphor-logging/lg2.hpp>
Chris Cainffb63212025-08-01 14:39:38 -050010#include <sdeventplus/source/signal.hpp>
11#include <stdplus/signal.hpp>
Gunnar Mills94df8c92018-09-14 14:50:03 -050012#include <xyz/openbmc_project/Common/error.hpp>
13
Vishwanatha Subbannaee4d83d2017-06-29 18:35:00 +053014using namespace sdbusplus::org::open_power::OCC::Device::Error;
Gunnar Mills94df8c92018-09-14 14:50:03 -050015using InternalFailure =
16 sdbusplus::xyz::openbmc_project::Common::Error::InternalFailure;
Vishwanatha Subbannaee4d83d2017-06-29 18:35:00 +053017
George Liud0345ae2021-09-10 13:13:28 +080018int main(int /*argc*/, char** /*argv[]*/)
Deepak Kodihalli92a63412017-03-17 05:01:00 -050019{
George Liuf3b75142021-06-10 11:22:50 +080020 auto& bus = open_power::occ::utils::getBus();
Vishwanatha Subbannaee4d83d2017-06-29 18:35:00 +053021
22 // Need sd_event to watch for OCC device errors
23 sd_event* event = nullptr;
24 auto r = sd_event_default(&event);
25 if (r < 0)
Deepak Kodihalli92a63412017-03-17 05:01:00 -050026 {
Chris Cain37abe9b2024-10-31 17:20:31 -050027 lg2::error("Error creating a default sd_event handler");
Vishwanatha Subbannaee4d83d2017-06-29 18:35:00 +053028 return r;
Deepak Kodihalli6b492fb2017-03-18 01:09:28 -050029 }
Vishwanatha Subbannaee4d83d2017-06-29 18:35:00 +053030 open_power::occ::EventPtr eventP{event};
31 event = nullptr;
32
33 // Attach the bus to sd_event to service user requests
34 bus.attach_event(eventP.get(), SD_EVENT_PRIORITY_NORMAL);
35
Chris Cainc86d80f2023-05-04 15:49:18 -050036 // Add object manager interfaces (for mapper)
Patrick Williamsaf408082022-07-22 19:26:54 -050037 sdbusplus::server::manager_t objManager(bus, OCC_CONTROL_ROOT);
Sheldon Bailey16a5adb2025-06-10 14:10:06 -050038
Patrick Williamsaf408082022-07-22 19:26:54 -050039 sdbusplus::server::manager_t objManagerXyz(bus, OCC_SENSORS_ROOT);
Sheldon Bailey16a5adb2025-06-10 14:10:06 -050040
Patrick Williamsaf408082022-07-22 19:26:54 -050041 sdbusplus::server::manager_t objManagerXyzControl(
Chris Cain1be43372021-12-09 19:29:37 -060042 bus, "/xyz/openbmc_project/control");
Sheldon Bailey16a5adb2025-06-10 14:10:06 -050043
Chris Cainc86d80f2023-05-04 15:49:18 -050044 sdbusplus::server::manager_t objManagerXyzInventory(
45 bus, "/xyz/openbmc_project/inventory");
George Liuf3b75142021-06-10 11:22:50 +080046 open_power::occ::Manager mgr(eventP);
Chris Cain720a3842025-01-09 10:23:36 -060047 mgr.createPldmHandle();
Vishwanatha Subbannaee4d83d2017-06-29 18:35:00 +053048
Chris Cainffb63212025-08-01 14:39:38 -050049 try
50 {
51 // Enable SIGUSR1 handling to collect data on dump request
52 stdplus::signal::block(SIGUSR1);
53 sdeventplus::source::Signal sigUsr1(
54 eventP.get(), SIGUSR1,
55 std::bind(&open_power::occ::Manager::collectDumpData, &mgr,
56 std::placeholders::_1, std::placeholders::_2));
57 sigUsr1.set_floating(true);
58 lg2::info("USR1 signal handler enabled");
59 }
60 catch (const std::exception& e)
61 {
62 lg2::error("Failed to enable SIGUSR1 handler: {ERR}", "ERR", e.what());
63 }
64
Vishwanatha Subbannaee4d83d2017-06-29 18:35:00 +053065 // Claim the bus since all the house keeping is done now
66 bus.request_name(OCC_CONTROL_BUSNAME);
67
68 // Wait for requests
69 sd_event_loop(eventP.get());
Deepak Kodihalli92a63412017-03-17 05:01:00 -050070
71 return 0;
72}