blob: 6f1dca0208b5b4e6fcaaecd9a7eec1675c8749d8 [file] [log] [blame]
Matt Spinlerafb39132017-08-14 13:53:07 -05001/**
2 * Copyright © 2017 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 */
Andy YF Wang40247cc2019-09-06 18:30:56 +080016#include "config.h"
17
Andy YF Wang40247cc2019-09-06 18:30:56 +080018#include "mihawk-cpld.hpp"
Matt Spinler56d90a82017-08-14 14:05:11 -050019#include "pgood_monitor.hpp"
Matt Spinler70849272017-08-22 09:14:40 -050020#include "runtime_monitor.hpp"
Matt Spinlerb2d72512017-08-22 09:07:01 -050021#include "ucd90160.hpp"
Matt Spinlerafb39132017-08-14 13:53:07 -050022
George Liu130ac972023-08-14 18:01:59 +080023#include <CLI/CLI.hpp>
Matt Spinlerf0f02b92018-10-25 16:12:43 -050024#include <phosphor-logging/log.hpp>
25#include <sdeventplus/event.hpp>
26
Brandon Wymand1bc4ce2019-12-13 14:20:34 -060027#include <chrono>
28#include <iostream>
29
Lei YUab093322019-10-09 16:43:22 +080030using namespace phosphor::power;
Matt Spinler56d90a82017-08-14 14:05:11 -050031using namespace phosphor::logging;
Matt Spinlerafb39132017-08-14 13:53:07 -050032
33int main(int argc, char** argv)
34{
George Liu130ac972023-08-14 18:01:59 +080035 CLI::App app{"Phosphor sequencer monitor"};
36 std::string action{};
37 std::string interVal{};
Matt Spinlerafb39132017-08-14 13:53:07 -050038
George Liu130ac972023-08-14 18:01:59 +080039 std::vector<std::string> actionTypes = {"pgood-monitor", "runtime-monitor"};
40 app.add_option("-a,--action", action,
41 "Action: pgood-monitor or runtime-monitor\n")
42 ->required()
43 ->transform(CLI::IsMember(actionTypes));
44 app.add_option("-i,--interval", interVal,
45 "Interval in milliseconds:\n"
46 "PGOOD monitor: time allowed for PGOOD to come up\n"
47 "Runtime monitor: polling interval.\n")
48 ->required();
49
50 try
Matt Spinlerafb39132017-08-14 13:53:07 -050051 {
George Liu130ac972023-08-14 18:01:59 +080052 app.parse(argc, argv);
53 }
54 catch (CLI::Error& e)
55 {
56 return app.exit(e);
Matt Spinlerafb39132017-08-14 13:53:07 -050057 }
58
George Liu130ac972023-08-14 18:01:59 +080059 auto i = strtoul(interVal.c_str(), nullptr, 10);
Matt Spinlerafb39132017-08-14 13:53:07 -050060 if (i == 0)
61 {
62 std::cerr << "Invalid interval value\n";
63 exit(EXIT_FAILURE);
64 }
65
Matt Spinler78c5c2b2017-12-14 10:42:07 -060066 std::chrono::milliseconds interval{i};
Matt Spinlerafb39132017-08-14 13:53:07 -050067
Matt Spinlerf0f02b92018-10-25 16:12:43 -050068 auto event = sdeventplus::Event::get_default();
Matt Spinler56d90a82017-08-14 14:05:11 -050069 auto bus = sdbusplus::bus::new_default();
70 bus.attach_event(event.get(), SD_EVENT_PRIORITY_NORMAL);
71
Andy YF Wang40247cc2019-09-06 18:30:56 +080072 auto device = std::make_unique<SEQUENCER>(0, bus);
Matt Spinlerb2d72512017-08-22 09:07:01 -050073
Matt Spinler70849272017-08-22 09:14:40 -050074 std::unique_ptr<DeviceMonitor> monitor;
Matt Spinler56d90a82017-08-14 14:05:11 -050075
Matt Spinler70849272017-08-22 09:14:40 -050076 if (action == "pgood-monitor")
77 {
Matt Spinlerf0f02b92018-10-25 16:12:43 -050078 // If PGOOD doesn't turn on within a certain
79 // time, analyze the device for errors
80 monitor = std::make_unique<PGOODMonitor>(std::move(device), bus, event,
81 interval);
Matt Spinler70849272017-08-22 09:14:40 -050082 }
Matt Spinlerf0f02b92018-10-25 16:12:43 -050083 else // runtime-monitor
Matt Spinler70849272017-08-22 09:14:40 -050084 {
Matt Spinlerf0f02b92018-10-25 16:12:43 -050085 // Continuously monitor this device both by polling
86 // and on 'power lost' signals.
87 monitor = std::make_unique<RuntimeMonitor>(std::move(device), bus,
88 event, interval);
Matt Spinler70849272017-08-22 09:14:40 -050089 }
90
91 return monitor->run();
Matt Spinlerafb39132017-08-14 13:53:07 -050092}