blob: 1de26297a3470160ba8a2b7a721562aca0bea1e3 [file] [log] [blame]
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +05301#include <functional>
2#include <systemintfcmds.h>
3#include <ipmid-host-cmd.hpp>
Andrew Geissler1b9d4e52017-03-21 15:04:05 -05004#include <utils.hpp>
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +05305#include <phosphor-logging/log.hpp>
Andrew Geissler83159702017-04-03 13:31:13 -05006#include <config.h>
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +05307#include <host-interface.hpp>
Andrew Geisslerdd2c6fd2017-03-16 15:53:20 -05008namespace phosphor
9{
10namespace host
11{
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053012namespace command
Andrew Geissler83159702017-04-03 13:31:13 -050013{
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053014
15// When you see Base:: you know we're referencing our base class
16namespace Base = sdbusplus::xyz::openbmc_project::Control::server;
17
18// IPMI OEM command.
19// https://github.com/openbmc/openbmc/issues/2082 for handling
20// Non-OEM commands that need to send SMS_ATN
21using OEMCmd = uint8_t;
22
23// Map of IPMI OEM command to its equivalent interface command.
24// This is needed when invoking the callback handler to indicate
25// the status of the executed command.
26static const std::map<OEMCmd, Host::Command> intfCommand = {
Andrew Geissler83159702017-04-03 13:31:13 -050027 {
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053028 CMD_HEARTBEAT,
29 Base::Host::Command::Heartbeat
30 },
Andrew Geissler83159702017-04-03 13:31:13 -050031 {
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053032 CMD_POWER,
33 Base::Host::Command::SoftOff
Andrew Geissler83159702017-04-03 13:31:13 -050034 }
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053035};
Andrew Geissler83159702017-04-03 13:31:13 -050036
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053037// Map of Interface command to its corresponding IPMI OEM command.
38// This is needed when pushing IPMI commands to command manager's
39// queue. The same pair will be returned when IPMI asks us
40// why a SMS_ATN was sent
41static const std::map<Host::Command, IpmiCmdData> ipmiCommand = {
42 {
43 Base::Host::Command::Heartbeat,
44 std::make_pair(CMD_HEARTBEAT, 0x00)
45 },
46 {
47 Base::Host::Command::SoftOff,
48 std::make_pair(CMD_POWER, SOFT_OFF)
49 }
50};
Andrew Geissler83159702017-04-03 13:31:13 -050051
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053052// Called at user request
53void Host::execute(Base::Host::Command command)
Andrew Geissler83159702017-04-03 13:31:13 -050054{
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053055 using namespace phosphor::logging;
Andrew Geissler1b9d4e52017-03-21 15:04:05 -050056
Andrew Geissler0c07c322017-03-22 14:02:30 -050057 log<level::INFO>("Pushing cmd on to queue",
58 entry("CONTROL_HOST_CMD=%s",
59 convertForMessage(command)));
60
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053061 auto cmd = std::make_tuple(ipmiCommand.at(command),
62 std::bind(&Host::commandStatusHandler,
63 this, std::placeholders::_1,
64 std::placeholders::_2));
Andrew Geissler0c07c322017-03-22 14:02:30 -050065
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053066 return ipmid_send_cmd_to_host(std::move(cmd));
Andrew Geissler62817fa92017-03-20 14:20:49 -050067}
68
Vishwanatha Subbanna3eb117a2017-07-12 16:13:49 +053069// Called into by Command Manager
70void Host::commandStatusHandler(IpmiCmdData cmd, bool status)
71{
72 // Need to convert <cmd> to the equivalent one mentioned in spec
73 auto value = status ? Result::Success : Result::Failure;
74
75 // Fire a signal
76 this->commandComplete(intfCommand.at(std::get<0>(cmd)), value);
77}
78
79} // namespace command
Andrew Geisslerdd2c6fd2017-03-16 15:53:20 -050080} // namespace host
81} // namepsace phosphor