Implement get payload instance info command
Resolves openbmc/openbmc#2892
Change-Id: Id5f95df64bcdc97646f11d6d3630eead062c4193
Signed-off-by: Tom Joseph <tomjoseph@in.ibm.com>
diff --git a/command/payload_cmds.cpp b/command/payload_cmds.cpp
index 0cc52cc..2215046 100644
--- a/command/payload_cmds.cpp
+++ b/command/payload_cmds.cpp
@@ -189,6 +189,40 @@
return outPayload;
}
+std::vector<uint8_t> getPayloadInfo(const std::vector<uint8_t>& inPayload,
+ const message::Handler& handler)
+{
+ std::vector<uint8_t> outPayload(sizeof(GetPayloadInfoResponse));
+ auto request = reinterpret_cast<const GetPayloadInfoRequest*>
+ (inPayload.data());
+ auto response = reinterpret_cast<GetPayloadInfoResponse*>
+ (outPayload.data());
+
+ // SOL is the payload currently supported for payload status & only one
+ // instance of SOL is supported.
+ if (static_cast<uint8_t>(message::PayloadType::SOL) != request->payloadType
+ || request->payloadInstance != 1)
+ {
+ response->completionCode = IPMI_CC_INVALID_FIELD_REQUEST;
+ return outPayload;
+ }
+
+ auto status = std::get<sol::Manager&>(singletonPool).isPayloadActive(
+ request->payloadInstance);
+
+ if (!status)
+ {
+ response->completionCode = IPMI_CC_RESPONSE_ERROR;
+ return outPayload;
+ }
+
+ auto& context = std::get<sol::Manager&>(singletonPool).getContext
+ (request->payloadInstance);
+ response->sessionID = context.sessionID;
+
+ return outPayload;
+}
+
} // namespace command
} // namespace sol