#include "config.h" #include "ramoops_manager.hpp" #include "dump_manager.hpp" #include #include #include #include #include #include #include #include namespace phosphor { namespace dump { namespace ramoops { Manager::Manager(const std::string& filePath) { std::filesystem::path dir(filePath); if (!std::filesystem::exists(dir) || std::filesystem::is_empty(dir)) { return; } // Create error to notify user that a ramoops has been detected createError(); std::vector files; files.push_back(filePath); createHelper(files); } void Manager::createError() { try { std::map additionalData; // Always add the _PID on for some extra logging debug additionalData.emplace("_PID", std::to_string(getpid())); auto bus = sdbusplus::bus::new_default(); auto method = bus.new_method_call( "xyz.openbmc_project.Logging", "/xyz/openbmc_project/logging", "xyz.openbmc_project.Logging.Create", "Create"); method.append("xyz.openbmc_project.Dump.Error.Ramoops", sdbusplus::server::xyz::openbmc_project::logging::Entry:: Level::Error, additionalData); auto resp = bus.call(method); } catch (const sdbusplus::exception_t& e) { lg2::error( "sdbusplus D-Bus call exception, error {ERROR} trying to create " "an error for ramoops detection", "ERROR", e); // This is a best-effort logging situation so don't throw anything } catch (const std::exception& e) { lg2::error("D-bus call exception: {ERROR}", "ERROR", e); // This is a best-effort logging situation so don't throw anything } } void Manager::createHelper(const std::vector& files) { constexpr auto MAPPER_BUSNAME = "xyz.openbmc_project.ObjectMapper"; constexpr auto MAPPER_PATH = "/xyz/openbmc_project/object_mapper"; constexpr auto MAPPER_INTERFACE = "xyz.openbmc_project.ObjectMapper"; constexpr auto DUMP_CREATE_IFACE = "xyz.openbmc_project.Dump.Create"; auto b = sdbusplus::bus::new_default(); auto mapper = b.new_method_call(MAPPER_BUSNAME, MAPPER_PATH, MAPPER_INTERFACE, "GetObject"); mapper.append(BMC_DUMP_OBJPATH, std::set({DUMP_CREATE_IFACE})); std::map> mapperResponse; try { auto mapperResponseMsg = b.call(mapper); mapperResponseMsg.read(mapperResponse); } catch (const sdbusplus::exception_t& e) { lg2::error("Failed to parse dump create message, error: {ERROR}", "ERROR", e); return; } if (mapperResponse.empty()) { lg2::error("Error reading mapper response"); return; } const auto& host = mapperResponse.cbegin()->first; auto m = b.new_method_call(host.c_str(), BMC_DUMP_OBJPATH, DUMP_CREATE_IFACE, "CreateDump"); phosphor::dump::DumpCreateParams params; using CreateParameters = sdbusplus::common::xyz::openbmc_project::dump::Create::CreateParameters; using DumpType = sdbusplus::common::xyz::openbmc_project::dump::Create::DumpType; using DumpIntr = sdbusplus::common::xyz::openbmc_project::dump::Create; params[DumpIntr::convertCreateParametersToString( CreateParameters::DumpType)] = DumpIntr::convertDumpTypeToString(DumpType::Ramoops); params[DumpIntr::convertCreateParametersToString( CreateParameters::FilePath)] = files.front(); m.append(params); try { b.call_noreply(m); } catch (const sdbusplus::exception_t& e) { lg2::error("Failed to create ramoops dump, errormsg: {ERROR}", "ERROR", e); } } } // namespace ramoops } // namespace dump } // namespace phosphor