blob: c48c73a925eb467886b7b9d196ac5651d9c02a99 [file] [log] [blame]
Brandon Wyman2ad76bd2019-08-26 17:15:04 -05001/**
2 * Copyright © 2019 IBM Corporation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Brandon Wyman2bac8602019-09-12 18:12:21 -050016#include "psu_manager.hpp"
17
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050018#include <CLI/CLI.hpp>
Brandon Wyman57939e82019-08-26 17:53:57 -050019#include <phosphor-logging/log.hpp>
Brandon Wyman2bac8602019-09-12 18:12:21 -050020#include <sdbusplus/bus.hpp>
21#include <sdeventplus/event.hpp>
Brandon Wyman57939e82019-08-26 17:53:57 -050022
23#include <filesystem>
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050024
Brandon Wyman2fe51862019-11-25 16:43:21 -060025using namespace phosphor::power;
Brandon Wymana0f33ce2019-10-17 18:32:29 -050026
Brandon Wymanb3028762020-11-09 17:05:36 -060027int main(void)
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050028{
Brandon Wymana0f33ce2019-10-17 18:32:29 -050029 try
Brandon Wyman57939e82019-08-26 17:53:57 -050030 {
Brandon Wymana0f33ce2019-10-17 18:32:29 -050031 using namespace phosphor::logging;
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050032
Brandon Wymana0f33ce2019-10-17 18:32:29 -050033 CLI::App app{"OpenBMC Power Supply Unit Monitor"};
34
Brandon Wymana0f33ce2019-10-17 18:32:29 -050035 auto bus = sdbusplus::bus::new_default();
36 auto event = sdeventplus::Event::get_default();
37
38 // Attach the event object to the bus object so we can
39 // handle both sd_events (for the timers) and dbus signals.
40 bus.attach_event(event.get(), SD_EVENT_PRIORITY_NORMAL);
41
Brandon Wymanb3028762020-11-09 17:05:36 -060042 manager::PSUManager manager(bus, event);
Brandon Wymana0f33ce2019-10-17 18:32:29 -050043
44 return manager.run();
45 }
46 catch (const std::exception& e)
Brandon Wyman57939e82019-08-26 17:53:57 -050047 {
Brandon Wymana0f33ce2019-10-17 18:32:29 -050048 log<level::ERR>(e.what());
49 return -2;
Brandon Wyman57939e82019-08-26 17:53:57 -050050 }
Brandon Wymana0f33ce2019-10-17 18:32:29 -050051 catch (...)
52 {
53 log<level::ERR>("Caught unexpected exception type");
54 return -3;
55 }
Brandon Wyman2ad76bd2019-08-26 17:15:04 -050056}