blob: d0d75547136d6331c641dcaa7a631dddf4dc5669 [file] [log] [blame]
Gunnar Millsf6ed5892018-09-07 17:08:02 -05001#include "config.h"
2
Lei YUf3ce4332019-02-21 14:09:49 +08003#ifdef UBIFS_LAYOUT
4#include "ubi/item_updater_ubi.hpp"
5#endif
Gunnar Millsf6ed5892018-09-07 17:08:02 -05006#include "watch.hpp"
7
8#include <phosphor-logging/log.hpp>
Adriana Kobylak2d8fa222017-03-15 12:34:32 -05009#include <sdbusplus/bus.hpp>
10#include <sdbusplus/server/manager.hpp>
Gunnar Mills6bd6d7b2017-09-18 09:22:36 -050011#include <system_error>
Adriana Kobylak2d8fa222017-03-15 12:34:32 -050012
13int main(int argc, char* argv[])
14{
Gunnar Mills6bd6d7b2017-09-18 09:22:36 -050015 using namespace openpower::software::updater;
16 using namespace phosphor::logging;
Adriana Kobylak2d8fa222017-03-15 12:34:32 -050017 auto bus = sdbusplus::bus::new_default();
18
Gunnar Mills6bd6d7b2017-09-18 09:22:36 -050019 sd_event* loop = nullptr;
20 auto rc = sd_event_default(&loop);
21 if (rc < 0)
22 {
23 log<level::ERR>("Error occurred during the sd_event_default",
24 entry("RC=%d", rc));
25 return -1;
26 }
27
Adriana Kobylak2d8fa222017-03-15 12:34:32 -050028 // Add sdbusplus ObjectManager.
29 sdbusplus::server::manager::manager objManager(bus, SOFTWARE_OBJPATH);
30
Lei YUf3ce4332019-02-21 14:09:49 +080031#ifdef UBIFS_LAYOUT
32 ItemUpdaterUbi updater(bus, SOFTWARE_OBJPATH);
33#endif
Adriana Kobylak2d8fa222017-03-15 12:34:32 -050034
35 bus.request_name(BUSNAME_UPDATER);
Gunnar Mills6bd6d7b2017-09-18 09:22:36 -050036 try
Adriana Kobylak2d8fa222017-03-15 12:34:32 -050037 {
Gunnar Mills6bd6d7b2017-09-18 09:22:36 -050038 openpower::software::updater::Watch watch(
Adriana Kobylak70dcb632018-02-27 15:46:52 -060039 loop,
40 std::bind(std::mem_fn(&ItemUpdater::updateFunctionalAssociation),
41 &updater, std::placeholders::_1));
Gunnar Mills6bd6d7b2017-09-18 09:22:36 -050042 bus.attach_event(loop, SD_EVENT_PRIORITY_NORMAL);
43 auto rc = sd_event_loop(loop);
44 if (rc < 0)
45 {
46 log<level::ERR>("Error occurred during the sd_event_loop",
47 entry("RC=%d", rc));
48 return -1;
49 }
Adriana Kobylak2d8fa222017-03-15 12:34:32 -050050 }
Gunnar Mills6bd6d7b2017-09-18 09:22:36 -050051 catch (const std::system_error& e)
52 {
53 log<level::ERR>(e.what());
54 return -1;
55 }
56
57 sd_event_unref(loop);
58
Adriana Kobylak2d8fa222017-03-15 12:34:32 -050059 return 0;
60}