blob: 44204881ecb7b5e68ad8af27990d3511a99d3da8 [file] [log] [blame]
Matt Spinlere73446e2017-04-10 13:55:52 -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 */
16#include <sdbusplus/bus.hpp>
William A. Kennington III1cfc2f12018-10-19 17:29:46 -070017#include <sdeventplus/event.hpp>
Matthew Barth8600d9a2017-06-23 14:38:05 -050018#include <phosphor-logging/log.hpp>
Matt Spinleree7f6422017-05-09 11:03:14 -050019#include "argument.hpp"
Matt Spinlere10416e2017-04-10 14:15:53 -050020#include "manager.hpp"
Matt Spinlerba7b5fe2018-04-25 15:26:10 -050021#include "sdbusplus.hpp"
Matt Spinlere73446e2017-04-10 13:55:52 -050022
Matt Spinleree7f6422017-05-09 11:03:14 -050023using namespace phosphor::fan::control;
Matthew Barth8600d9a2017-06-23 14:38:05 -050024using namespace phosphor::logging;
Matt Spinleree7f6422017-05-09 11:03:14 -050025
Matt Spinlere73446e2017-04-10 13:55:52 -050026int main(int argc, char* argv[])
27{
William A. Kennington III1cfc2f12018-10-19 17:29:46 -070028 auto event = sdeventplus::Event::get_default();
Matt Spinlere73446e2017-04-10 13:55:52 -050029 auto bus = sdbusplus::bus::new_default();
Matt Spinleree7f6422017-05-09 11:03:14 -050030 phosphor::fan::util::ArgumentParser args(argc, argv);
Matt Spinlere73446e2017-04-10 13:55:52 -050031
Matt Spinleree7f6422017-05-09 11:03:14 -050032 if (argc != 2)
33 {
34 args.usage(argv);
William A. Kennington III3e781062018-10-19 17:18:34 -070035 return 1;
Matt Spinleree7f6422017-05-09 11:03:14 -050036 }
37
Matthew Barth14184132017-05-19 14:37:30 -050038 Mode mode;
Matt Spinleree7f6422017-05-09 11:03:14 -050039
40 if (args["init"] == "true")
41 {
Matthew Barth14184132017-05-19 14:37:30 -050042 mode = Mode::init;
Matt Spinleree7f6422017-05-09 11:03:14 -050043 }
44 else if (args["control"] == "true")
45 {
Matthew Barth14184132017-05-19 14:37:30 -050046 mode = Mode::control;
Matt Spinleree7f6422017-05-09 11:03:14 -050047 }
48 else
49 {
50 args.usage(argv);
William A. Kennington III3e781062018-10-19 17:18:34 -070051 return 1;
Matt Spinleree7f6422017-05-09 11:03:14 -050052 }
53
Matthew Barth8600d9a2017-06-23 14:38:05 -050054 //Attach the event object to the bus object so we can
55 //handle both sd_events (for the timers) and dbus signals.
William A. Kennington III1cfc2f12018-10-19 17:29:46 -070056 bus.attach_event(event.get(), SD_EVENT_PRIORITY_NORMAL);
Matthew Barth8600d9a2017-06-23 14:38:05 -050057
Matt Spinlerba7b5fe2018-04-25 15:26:10 -050058 try
59 {
William A. Kennington III1cfc2f12018-10-19 17:29:46 -070060 Manager manager(bus, event, mode);
Matt Spinleree7f6422017-05-09 11:03:14 -050061
Matt Spinlerba7b5fe2018-04-25 15:26:10 -050062 //Init mode will just set fans to max and delay
63 if (mode == Mode::init)
Matthew Barth8600d9a2017-06-23 14:38:05 -050064 {
Matt Spinlerba7b5fe2018-04-25 15:26:10 -050065 manager.doInit();
66 return 0;
Matthew Barth8600d9a2017-06-23 14:38:05 -050067 }
William A. Kennington III1cfc2f12018-10-19 17:29:46 -070068
69 return event.loop();
Matt Spinlerba7b5fe2018-04-25 15:26:10 -050070 }
71 //Log the useful metadata on these exceptions and let the app
William A. Kennington III3e781062018-10-19 17:18:34 -070072 //return 1 so it is restarted without a core dump.
Matt Spinlerba7b5fe2018-04-25 15:26:10 -050073 catch (phosphor::fan::util::DBusServiceError& e)
74 {
75 log<level::ERR>("Uncaught DBus service lookup failure exception",
76 entry("PATH=%s", e.path.c_str()),
77 entry("INTERFACE=%s", e.interface.c_str()));
78 }
79 catch (phosphor::fan::util::DBusMethodError& e)
80 {
81 log<level::ERR>("Uncaught DBus method failure exception",
82 entry("BUSNAME=%s", e.busName.c_str()),
83 entry("PATH=%s", e.path.c_str()),
84 entry("INTERFACE=%s", e.interface.c_str()),
85 entry("METHOD=%s", e.method.c_str()));
Matt Spinlere73446e2017-04-10 13:55:52 -050086 }
Matthew Barth88923a02018-05-11 10:14:44 -050087 catch (phosphor::fan::util::DBusPropertyError& e)
88 {
89 log<level::ERR>("Uncaught DBus property access failure exception",
90 entry("BUSNAME=%s", e.busName.c_str()),
91 entry("PATH=%s", e.path.c_str()),
92 entry("INTERFACE=%s", e.interface.c_str()),
93 entry("PROPERTY=%s", e.property.c_str()));
94 }
Matt Spinlere73446e2017-04-10 13:55:52 -050095
William A. Kennington III3e781062018-10-19 17:18:34 -070096 return 1;
Matt Spinlere73446e2017-04-10 13:55:52 -050097}