blob: ab9b322e856e000dbfe95fc6c3eb9aeba0eadb34 [file] [log] [blame]
Edward A. James636577f2017-10-06 10:53:55 -05001#include "occ_presence.hpp"
Gunnar Mills94df8c92018-09-14 14:50:03 -05002
Edward A. James636577f2017-10-06 10:53:55 -05003#include "elog-errors.hpp"
Gunnar Mills94df8c92018-09-14 14:50:03 -05004#include "occ_manager.hpp"
5
6#include <errno.h>
7#include <fcntl.h>
8#include <sys/ioctl.h>
9#include <unistd.h>
10
11#include <org/open_power/OCC/Device/error.hpp>
12#include <phosphor-logging/elog.hpp>
13#include <phosphor-logging/log.hpp>
14#include <xyz/openbmc_project/Common/error.hpp>
Edward A. James636577f2017-10-06 10:53:55 -050015
16namespace open_power
17{
18namespace occ
19{
20
21// Reads the occs_present file and analyzes the data
22void Presence::analyzeEvent()
23{
24 using namespace phosphor::logging;
25 using namespace sdbusplus::org::open_power::OCC::Device::Error;
26
27 // Get the number of bytes to read
28 int len = -1;
29 auto r = ioctl(fd, FIONREAD, &len);
30 if (r < 0)
31 {
32 elog<ConfigFailure>(
Gunnar Mills94df8c92018-09-14 14:50:03 -050033 phosphor::logging::org::open_power::OCC::Device::ConfigFailure::
34 CALLOUT_ERRNO(errno),
35 phosphor::logging::org::open_power::OCC::Device::ConfigFailure::
36 CALLOUT_DEVICE_PATH(file.c_str()));
Edward A. James636577f2017-10-06 10:53:55 -050037 }
38
39 auto data = readFile(len);
40 if (data.empty())
41 {
42 return;
43 }
44
45 // Let stoi determine the base
46 auto occsPresent = std::stoi(data, nullptr, 0);
47 if (manager.getNumOCCs() != occsPresent)
48 {
49 log<level::INFO>("OCC presence mismatch",
Joseph Reynolds13ae5002018-05-30 10:29:20 -050050 entry("BMC_OCCS=%d", manager.getNumOCCs()),
51 entry("OCC_OCCS=%d", occsPresent));
Edward A. James636577f2017-10-06 10:53:55 -050052 if (callBack)
53 {
Eddie James482e31f2017-09-14 13:17:17 -050054 callBack(true);
Edward A. James636577f2017-10-06 10:53:55 -050055 }
56 }
57}
58
59} // namespace occ
60} // namespace open_power