|  | #include "error-HostEvent.hpp" | 
|  | #include "sensorhandler.hpp" | 
|  |  | 
|  | #include <systemd/sd-bus.h> | 
|  |  | 
|  | #include <ipmid/api.hpp> | 
|  | #include <ipmid/types.hpp> | 
|  | #include <phosphor-logging/elog-errors.hpp> | 
|  | #include <phosphor-logging/elog.hpp> | 
|  | #include <phosphor-logging/lg2.hpp> | 
|  | #include <xyz/openbmc_project/Logging/Entry/server.hpp> | 
|  |  | 
|  | #include <algorithm> | 
|  | #include <cstdlib> | 
|  | #include <cstring> | 
|  | #include <fstream> | 
|  | #include <iostream> | 
|  | #include <memory> | 
|  | #include <vector> | 
|  |  | 
|  | using namespace std; | 
|  | using namespace phosphor::logging; | 
|  | using namespace sdbusplus::server::xyz::openbmc_project::logging; | 
|  |  | 
|  | std::string readESEL(const char* fileName) | 
|  | { | 
|  | std::string content; | 
|  | std::ifstream handle(fileName); | 
|  |  | 
|  | if (handle.fail()) | 
|  | { | 
|  | lg2::error("Failed to open eSEL, file name: {FILENAME}", "FILENAME", | 
|  | fileName); | 
|  | return content; | 
|  | } | 
|  |  | 
|  | handle.seekg(0, std::ios::end); | 
|  | content.resize(handle.tellg()); | 
|  | handle.seekg(0, std::ios::beg); | 
|  | handle.read(&content[0], content.size()); | 
|  | handle.close(); | 
|  |  | 
|  | return content; | 
|  | } | 
|  |  | 
|  | void createProcedureLogEntry(uint8_t procedureNum) | 
|  | { | 
|  | // Read the eSEL data from the file. | 
|  | static constexpr auto eSELFile = "/tmp/esel"; | 
|  | auto eSELData = readESEL(eSELFile); | 
|  |  | 
|  | // Each byte in eSEL is formatted as %02x with a space between bytes and | 
|  | // insert '/0' at the end of the character array. | 
|  | static constexpr auto byteSeparator = 3; | 
|  | std::unique_ptr<char[]> data( | 
|  | new char[(eSELData.size() * byteSeparator) + 1]()); | 
|  |  | 
|  | for (size_t i = 0; i < eSELData.size(); i++) | 
|  | { | 
|  | sprintf(&data[i * byteSeparator], "%02x ", eSELData[i]); | 
|  | } | 
|  | data[eSELData.size() * byteSeparator] = '\0'; | 
|  |  | 
|  | using error = sdbusplus::error::org::open_power::host::MaintenanceProcedure; | 
|  | using metadata = org::open_power::host::MaintenanceProcedure; | 
|  |  | 
|  | report<error>(metadata::ESEL(data.get()), | 
|  | metadata::PROCEDURE(static_cast<uint32_t>(procedureNum))); | 
|  | } |