blob: 9bb92ce1e5aaeadbf2bb87feb60a8a2d5ac14dca [file] [log] [blame]
Vernon Mauery9e801a22018-10-12 13:20:49 -07001#include "sol_cmds.hpp"
2
Vernon Mauery2085ae02021-06-10 11:51:00 -07003#include "sessions_manager.hpp"
Tom Joseph64b3dec2017-04-03 01:53:44 +05304#include "sol/sol_context.hpp"
5#include "sol/sol_manager.hpp"
Vernon Mauery9e801a22018-10-12 13:20:49 -07006
George Liu7b7f25f2022-07-04 17:07:32 +08007#include <phosphor-logging/lg2.hpp>
Tom Joseph64b3dec2017-04-03 01:53:44 +05308
9namespace sol
10{
11
12namespace command
13{
14
15using namespace phosphor::logging;
16
Tom Joseph18a45e92017-04-11 11:30:44 +053017std::vector<uint8_t> payloadHandler(const std::vector<uint8_t>& inPayload,
Vernon Mauery41ff9b52021-06-11 11:37:40 -070018 std::shared_ptr<message::Handler>& handler)
Tom Joseph64b3dec2017-04-03 01:53:44 +053019{
Zhikui Ren2b1edef2020-07-24 14:32:13 -070020 // Check inPayload size is at least Payload
21 if (inPayload.size() < sizeof(Payload))
22 {
23 return std::vector<uint8_t>();
24 }
25
Tom Joseph18a45e92017-04-11 11:30:44 +053026 auto request = reinterpret_cast<const Payload*>(inPayload.data());
Tom Joseph64b3dec2017-04-03 01:53:44 +053027 auto solDataSize = inPayload.size() - sizeof(Payload);
28
Vernon Mauery70fd29c2017-11-30 13:11:43 -080029 std::vector<uint8_t> charData(solDataSize);
Vernon Mauery9e801a22018-10-12 13:20:49 -070030 if (solDataSize > 0)
Tom Joseph64b3dec2017-04-03 01:53:44 +053031 {
Vernon Mauery9e801a22018-10-12 13:20:49 -070032 std::copy_n(inPayload.data() + sizeof(Payload), solDataSize,
Tom Joseph64b3dec2017-04-03 01:53:44 +053033 charData.begin());
34 }
35
36 try
37 {
Vernon Mauery41ff9b52021-06-11 11:37:40 -070038 auto& context = sol::Manager::get().getContext(handler->sessionID);
Tom Joseph64b3dec2017-04-03 01:53:44 +053039
Vernon Mauery9e801a22018-10-12 13:20:49 -070040 context.processInboundPayload(
41 request->packetSeqNum, request->packetAckSeqNum,
Tingting Chenec437412022-09-27 18:35:22 +080042 request->acceptedCharCount, request->inOperation.ack,
43 request->inOperation.generateBreak, charData);
Tom Joseph64b3dec2017-04-03 01:53:44 +053044 }
Patrick Williams12d199b2021-10-06 12:36:48 -050045 catch (const std::exception& e)
Tom Joseph64b3dec2017-04-03 01:53:44 +053046 {
George Liu7b7f25f2022-07-04 17:07:32 +080047 lg2::error("Failed to call the getContext method: {ERROR}", "ERROR", e);
Tom Joseph64b3dec2017-04-03 01:53:44 +053048 return std::vector<uint8_t>();
49 }
50
51 return std::vector<uint8_t>();
52}
53
Tom Josephe14ac962017-04-03 01:56:04 +053054void activating(uint8_t payloadInstance, uint32_t sessionID)
55{
56 std::vector<uint8_t> outPayload(sizeof(ActivatingRequest));
57
Vernon Mauery9e801a22018-10-12 13:20:49 -070058 auto request = reinterpret_cast<ActivatingRequest*>(outPayload.data());
Tom Josephe14ac962017-04-03 01:56:04 +053059
60 request->sessionState = 0;
61 request->payloadInstance = payloadInstance;
62 request->majorVersion = MAJOR_VERSION;
63 request->minorVersion = MINOR_VERSION;
64
Vernon Mauery2085ae02021-06-10 11:51:00 -070065 auto session = session::Manager::get().getSession(sessionID);
Tom Josephe14ac962017-04-03 01:56:04 +053066
67 message::Handler msgHandler(session->channelPtr, sessionID);
68
Vernon Mauery9e801a22018-10-12 13:20:49 -070069 msgHandler.sendUnsolicitedIPMIPayload(netfnTransport, solActivatingCmd,
Tom Josephe14ac962017-04-03 01:56:04 +053070 outPayload);
71}
Tom Joseph64b3dec2017-04-03 01:53:44 +053072} // namespace command
73
74} // namespace sol