blob: c71130b5fad8c8382f49cef070918da7c163b4d1 [file] [log] [blame]
#pragma once
#include "libpldm/pldm.h"
#include "common/types.hpp"
#include "pldmd/dbus_impl_requester.hpp"
#include "requester/handler.hpp"
namespace pldm
{
namespace fw_update
{
/** @class InventoryManager
*
* InventoryManager class manages the software inventory of firmware devices
* managed by the BMC. It discovers the firmware identifiers and the component
* details of the FD. Firmware identifiers, component details and update
* capabilities of FD are populated by the InventoryManager and is used for the
* firmware update of the FDs.
*/
class InventoryManager
{
public:
InventoryManager() = delete;
InventoryManager(const InventoryManager&) = delete;
InventoryManager(InventoryManager&&) = delete;
InventoryManager& operator=(const InventoryManager&) = delete;
InventoryManager& operator=(InventoryManager&&) = delete;
~InventoryManager() = default;
/** @brief Constructor
*
* @param[in] handler - PLDM request handler
* @param[in] requester - Managing instance ID for PLDM requests
* @param[out] descriptorMap - Populate the firmware identifers for the
* FDs managed by the BMC.
* @param[out] componentInfoMap - Populate the component info for the FDs
* managed by the BMC.
*/
explicit InventoryManager(
pldm::requester::Handler<pldm::requester::Request>& handler,
pldm::dbus_api::Requester& requester, DescriptorMap& descriptorMap,
ComponentInfoMap& componentInfoMap) :
handler(handler),
requester(requester), descriptorMap(descriptorMap),
componentInfoMap(componentInfoMap)
{}
/** @brief Discover the firmware identifiers and component details of FDs
*
* Inventory commands QueryDeviceIdentifiers and GetFirmwareParmeters
* commands are sent to every FD and the response is used to populate
* the firmware identifiers and component details of the FDs.
*
* @param[in] eids - MCTP endpoint ID of the FDs
*/
void discoverFDs(const std::vector<mctp_eid_t>& eids);
/** @brief Handler for QueryDeviceIdentifiers command response
*
* The response of the QueryDeviceIdentifiers is processed and firmware
* identifiers of the FD is updated. GetFirmwareParameters command request
* is sent to the FD.
*
* @param[in] eid - Remote MCTP endpoint
* @param[in] response - PLDM response message
* @param[in] respMsgLen - Response message length
*/
void queryDeviceIdentifiers(mctp_eid_t eid, const pldm_msg* response,
size_t respMsgLen);
/** @brief Handler for GetFirmwareParameters command response
*
* Handling the response of GetFirmwareParameters command and create
* software version D-Bus objects.
*
* @param[in] eid - Remote MCTP endpoint
* @param[in] response - PLDM response message
* @param[in] respMsgLen - Response message length
*/
void getFirmwareParameters(mctp_eid_t eid, const pldm_msg* response,
size_t respMsgLen);
private:
/** @brief Send GetFirmwareParameters command request
*
* @param[in] eid - Remote MCTP endpoint
*/
void sendGetFirmwareParametersRequest(mctp_eid_t eid);
/** @brief PLDM request handler */
pldm::requester::Handler<pldm::requester::Request>& handler;
/** @brief D-Bus API for managing instance ID*/
pldm::dbus_api::Requester& requester;
/** @brief Device identifiers of the managed FDs */
DescriptorMap& descriptorMap;
/** @brief Component information needed for the update of the managed FDs */
ComponentInfoMap& componentInfoMap;
};
} // namespace fw_update
} // namespace pldm