blob: a8fa41074492f26aa2dae429115d918915847cd2 [file] [log] [blame]
#include "sol_cmds.hpp"
#include "main.hpp"
#include "sol/sol_context.hpp"
#include "sol/sol_manager.hpp"
#include <phosphor-logging/log.hpp>
namespace sol
{
namespace command
{
using namespace phosphor::logging;
std::vector<uint8_t> payloadHandler(const std::vector<uint8_t>& inPayload,
const message::Handler& handler)
{
auto request = reinterpret_cast<const Payload*>(inPayload.data());
auto solDataSize = inPayload.size() - sizeof(Payload);
std::vector<uint8_t> charData(solDataSize);
if (solDataSize > 0)
{
std::copy_n(inPayload.data() + sizeof(Payload), solDataSize,
charData.begin());
}
try
{
auto& context = std::get<sol::Manager&>(singletonPool)
.getContext(handler.sessionID);
context.processInboundPayload(
request->packetSeqNum, request->packetAckSeqNum,
request->acceptedCharCount, request->inOperation.ack, charData);
}
catch (std::exception& e)
{
log<level::ERR>(e.what());
return std::vector<uint8_t>();
}
return std::vector<uint8_t>();
}
void activating(uint8_t payloadInstance, uint32_t sessionID)
{
std::vector<uint8_t> outPayload(sizeof(ActivatingRequest));
auto request = reinterpret_cast<ActivatingRequest*>(outPayload.data());
request->sessionState = 0;
request->payloadInstance = payloadInstance;
request->majorVersion = MAJOR_VERSION;
request->minorVersion = MINOR_VERSION;
auto session =
std::get<session::Manager&>(singletonPool).getSession(sessionID);
message::Handler msgHandler(session->channelPtr, sessionID);
msgHandler.sendUnsolicitedIPMIPayload(netfnTransport, solActivatingCmd,
outPayload);
}
std::vector<uint8_t> setConfParams(const std::vector<uint8_t>& inPayload,
const message::Handler& handler)
{
std::vector<uint8_t> outPayload(sizeof(SetConfParamsResponse));
auto request =
reinterpret_cast<const SetConfParamsRequest*>(inPayload.data());
auto response = reinterpret_cast<SetConfParamsResponse*>(outPayload.data());
response->completionCode = IPMI_CC_OK;
switch (static_cast<Parameter>(request->paramSelector))
{
case Parameter::PROGRESS:
{
uint8_t progress = request->value & progressMask;
std::get<sol::Manager&>(singletonPool).progress = progress;
break;
}
case Parameter::ENABLE:
{
bool enable = request->value & enableMask;
std::get<sol::Manager&>(singletonPool).enable = enable;
break;
}
case Parameter::AUTHENTICATION:
{
if (!request->auth.auth || !request->auth.encrypt)
{
response->completionCode = ipmiCCWriteReadParameter;
}
else if (request->auth.privilege <
static_cast<uint8_t>(session::Privilege::USER) ||
request->auth.privilege >
static_cast<uint8_t>(session::Privilege::OEM))
{
response->completionCode = IPMI_CC_INVALID_FIELD_REQUEST;
}
else
{
std::get<sol::Manager&>(singletonPool).solMinPrivilege =
static_cast<session::Privilege>(request->auth.privilege);
}
break;
}
case Parameter::ACCUMULATE:
{
using namespace std::chrono_literals;
if (request->acc.threshold == 0)
{
response->completionCode = IPMI_CC_INVALID_FIELD_REQUEST;
break;
}
std::get<sol::Manager&>(singletonPool).accumulateInterval =
request->acc.interval * sol::accIntervalFactor * 1ms;
std::get<sol::Manager&>(singletonPool).sendThreshold =
request->acc.threshold;
break;
}
case Parameter::RETRY:
{
using namespace std::chrono_literals;
std::get<sol::Manager&>(singletonPool).retryCount =
request->retry.count;
std::get<sol::Manager&>(singletonPool).retryInterval =
request->retry.interval * sol::retryIntervalFactor * 1ms;
break;
}
case Parameter::PORT:
{
response->completionCode = ipmiCCWriteReadParameter;
break;
}
case Parameter::NVBITRATE:
case Parameter::VBITRATE:
case Parameter::CHANNEL:
default:
response->completionCode = ipmiCCParamNotSupported;
}
return outPayload;
}
std::vector<uint8_t> getConfParams(const std::vector<uint8_t>& inPayload,
const message::Handler& handler)
{
std::vector<uint8_t> outPayload(sizeof(GetConfParamsResponse));
auto request =
reinterpret_cast<const GetConfParamsRequest*>(inPayload.data());
auto response = reinterpret_cast<GetConfParamsResponse*>(outPayload.data());
response->completionCode = IPMI_CC_OK;
response->paramRev = parameterRevision;
if (request->getParamRev)
{
return outPayload;
}
switch (static_cast<Parameter>(request->paramSelector))
{
case Parameter::PROGRESS:
{
outPayload.push_back(
std::get<sol::Manager&>(singletonPool).progress);
break;
}
case Parameter::ENABLE:
{
outPayload.push_back(std::get<sol::Manager&>(singletonPool).enable);
break;
}
case Parameter::AUTHENTICATION:
{
Auth value{0};
value.encrypt = std::get<sol::Manager&>(singletonPool).forceEncrypt;
value.auth = std::get<sol::Manager&>(singletonPool).forceAuth;
value.privilege = static_cast<uint8_t>(
std::get<sol::Manager&>(singletonPool).solMinPrivilege);
auto buffer = reinterpret_cast<const uint8_t*>(&value);
std::copy_n(buffer, sizeof(value), std::back_inserter(outPayload));
break;
}
case Parameter::ACCUMULATE:
{
Accumulate value{0};
value.interval = std::get<sol::Manager&>(singletonPool)
.accumulateInterval.count() /
sol::accIntervalFactor;
value.threshold =
std::get<sol::Manager&>(singletonPool).sendThreshold;
auto buffer = reinterpret_cast<const uint8_t*>(&value);
std::copy_n(buffer, sizeof(value), std::back_inserter(outPayload));
break;
}
case Parameter::RETRY:
{
Retry value{0};
value.count = std::get<sol::Manager&>(singletonPool).retryCount;
value.interval =
std::get<sol::Manager&>(singletonPool).retryInterval.count() /
sol::retryIntervalFactor;
auto buffer = reinterpret_cast<const uint8_t*>(&value);
std::copy_n(buffer, sizeof(value), std::back_inserter(outPayload));
break;
}
case Parameter::PORT:
{
auto port = endian::to_ipmi<uint16_t>(IPMI_STD_PORT);
auto buffer = reinterpret_cast<const uint8_t*>(&port);
std::copy_n(buffer, sizeof(port), std::back_inserter(outPayload));
break;
}
case Parameter::CHANNEL:
{
outPayload.push_back(
std::get<sol::Manager&>(singletonPool).channel);
break;
}
case Parameter::NVBITRATE:
case Parameter::VBITRATE:
default:
response->completionCode = ipmiCCParamNotSupported;
}
return outPayload;
}
} // namespace command
} // namespace sol