blob: a37df2c44b6ec2190eb478ad36efb9586ab228a9 [file] [log] [blame]
#pragma once
#include "sbe_type.hpp"
#include <sdbusplus/server.hpp>
#include <filesystem>
#include <map>
#include <string>
#include <variant>
namespace openpower::dump::util
{
constexpr auto SBE_DUMP_TIMEOUT = 4 * 60; // Timeout in seconds
using DumpCreateParams =
std::map<std::string, std::variant<std::string, uint64_t>>;
/** @struct DumpPtr
* @brief a structure holding the data pointer
* @details This is a RAII container for the dump data
* returned by the SBE
*/
struct DumpDataPtr
{
public:
/** @brief Destructor for the object, free the allocated memory.
*/
~DumpDataPtr()
{
// The memory is allocated using malloc
free(dataPtr);
}
/** @brief Returns the pointer to the data
*/
uint8_t** getPtr()
{
return &dataPtr;
}
/** @brief Returns the stored data
*/
uint8_t* getData()
{
return dataPtr;
}
private:
/** The pointer to the data */
uint8_t* dataPtr = nullptr;
};
/**
* @brief Get DBUS service for input interface via mapper call
*
* @param[in] bus - DBUS Bus Object
* @param[in] intf - DBUS Interface
* @param[in] path - DBUS Object Path
*
* @return distinct dbus name for input interface/path
**/
std::string getService(sdbusplus::bus_t& bus, const std::string& intf,
const std::string& path);
/**
* @brief Set the property value based on the inputs
*
* @param[in] interface - the interface the property is on
* @param[in] propertName - the name of the property
* @param[in] path - the D-Bus path
* @param[in] service - the D-Bus service
* @param[in] bus - the D-Bus object
* @param[in] value - the value to set the property to
*/
template <typename T>
void setProperty(const std::string& interface, const std::string& propertyName,
const std::string& path, sdbusplus::bus_t& bus, const T& value)
{
constexpr auto PROPERTY_INTF = "org.freedesktop.DBus.Properties";
auto service = getService(bus, interface, path);
auto method = bus.new_method_call(service.c_str(), path.c_str(),
PROPERTY_INTF, "Set");
method.append(interface, propertyName, value);
auto reply = bus.call(method);
}
/**
* Request SBE dump from the dump manager
*
* Request SBE dump from the dump manager and register a monitor for observing
* the dump progress.
*
* @param failingUnit The id of the proc containing failed SBE
* @param eid Error log id associated with dump
* @param sbeType Type of the SBE
*/
void requestSBEDump(const uint32_t failingUnit, const uint32_t eid,
SBETypes sbeType);
} // namespace openpower::dump::util