blob: dd92725050118670956e2a7d91b4390b2f8fbf8c [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 {
Chris Caina7b74dc2021-11-10 17:03:43 -060049 log<level::ERR>(fmt::format("OCC presence mismatch - BMC: {}, OCC: {}",
50 manager.getNumOCCs(), occsPresent)
51 .c_str());
Edward A. James636577f2017-10-06 10:53:55 -050052 if (callBack)
53 {
Eddie James9789e712022-05-25 15:43:40 -050054 callBack(occsPresent);
Edward A. James636577f2017-10-06 10:53:55 -050055 }
56 }
57}
58
59} // namespace occ
60} // namespace open_power