blob: 682b1a7b5c0592bc07a8f8c42d1040abe46a5baa [file] [log] [blame]
Deepak Kodihalli1b24f972019-02-01 04:09:13 -06001#include "libpldm/base.h"
2
3#include "base.hpp"
Jinu Joy Thomasf666db12019-05-29 05:22:31 -05004#include "registration.hpp"
Deepak Kodihalli1b24f972019-02-01 04:09:13 -06005
6#include <array>
Sampa Misra432e1872019-02-13 03:49:43 -06007#include <cstring>
Deepak Kodihalli1b24f972019-02-01 04:09:13 -06008#include <map>
9#include <stdexcept>
10#include <vector>
11
12namespace pldm
13{
14namespace responder
15{
16
17using Cmd = std::vector<uint8_t>;
18
19static const std::map<Type, Cmd> capabilities{
20 {PLDM_BASE, {PLDM_GET_PLDM_TYPES, PLDM_GET_PLDM_COMMANDS}}};
21
Deepak Kodihalli97e0bd52019-02-21 03:54:22 -060022static const std::map<Type, ver32_t> versions{
Sampa Misra432e1872019-02-13 03:49:43 -060023 {PLDM_BASE, {0xF1, 0xF0, 0xF0, 0x00}},
Zahed Hossain74c1c1e2019-06-18 02:13:48 -050024 {PLDM_PLATFORM, {0xF1, 0xF1, 0xF1, 0x00}},
25 {PLDM_BIOS, {0xF1, 0xF0, 0xF0, 0x00}},
Sampa Misra432e1872019-02-13 03:49:43 -060026};
27
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050028namespace base
29{
30
31void registerHandlers()
32{
33 registerHandler(PLDM_BASE, PLDM_GET_PLDM_TYPES, std::move(getPLDMTypes));
34 registerHandler(PLDM_BASE, PLDM_GET_PLDM_COMMANDS,
35 std::move(getPLDMCommands));
36 registerHandler(PLDM_BASE, PLDM_GET_PLDM_VERSION,
37 std::move(getPLDMVersion));
38}
39
40} // namespace base
41
vkaverapa6575b82019-04-03 05:33:52 -050042Response getPLDMTypes(const pldm_msg* request, size_t payloadLength)
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060043{
44 // DSP0240 has this as a bitfield8[N], where N = 0 to 7
Deepak Kodihalli97e0bd52019-02-21 03:54:22 -060045 std::array<bitfield8_t, 8> types{};
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060046 for (const auto& type : capabilities)
47 {
48 auto index = type.first / 8;
49 // <Type Number> = <Array Index> * 8 + <bit position>
50 auto bit = type.first - (index * 8);
Deepak Kodihalli97e0bd52019-02-21 03:54:22 -060051 types[index].byte |= 1 << bit;
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060052 }
53
vkaverapa6575b82019-04-03 05:33:52 -050054 Response response(sizeof(pldm_msg_hdr) + PLDM_GET_TYPES_RESP_BYTES, 0);
55 auto responsePtr = reinterpret_cast<pldm_msg*>(response.data());
56 encode_get_types_resp(0, PLDM_SUCCESS, types.data(), responsePtr);
57
58 return response;
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060059}
60
vkaverapa6575b82019-04-03 05:33:52 -050061Response getPLDMCommands(const pldm_msg* request, size_t payloadLength)
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060062{
Deepak Kodihalli97e0bd52019-02-21 03:54:22 -060063 ver32_t version{};
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060064 Type type;
65
vkaverapa6575b82019-04-03 05:33:52 -050066 Response response(sizeof(pldm_msg_hdr) + PLDM_GET_COMMANDS_RESP_BYTES, 0);
67 auto responsePtr = reinterpret_cast<pldm_msg*>(response.data());
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060068
vkaverapa6575b82019-04-03 05:33:52 -050069 auto rc = decode_get_commands_req(request->payload, payloadLength, &type,
70 &version);
71
72 if (rc != PLDM_SUCCESS)
73 {
74 encode_get_commands_resp(0, rc, nullptr, responsePtr);
75 return response;
76 }
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060077
78 // DSP0240 has this as a bitfield8[N], where N = 0 to 31
Deepak Kodihalli97e0bd52019-02-21 03:54:22 -060079 std::array<bitfield8_t, 32> cmds{};
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060080 if (capabilities.find(type) == capabilities.end())
81 {
82 encode_get_commands_resp(0, PLDM_ERROR_INVALID_PLDM_TYPE, nullptr,
vkaverapa6575b82019-04-03 05:33:52 -050083 responsePtr);
84 return response;
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060085 }
86
87 for (const auto& cmd : capabilities.at(type))
88 {
89 auto index = cmd / 8;
90 // <Type Number> = <Array Index> * 8 + <bit position>
91 auto bit = cmd - (index * 8);
Deepak Kodihalli97e0bd52019-02-21 03:54:22 -060092 cmds[index].byte |= 1 << bit;
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060093 }
94
vkaverapa6575b82019-04-03 05:33:52 -050095 encode_get_commands_resp(0, PLDM_SUCCESS, cmds.data(), responsePtr);
96
97 return response;
Deepak Kodihalli1b24f972019-02-01 04:09:13 -060098}
99
vkaverapa6575b82019-04-03 05:33:52 -0500100Response getPLDMVersion(const pldm_msg* request, size_t payloadLength)
Sampa Misra432e1872019-02-13 03:49:43 -0600101{
102 uint32_t transferHandle;
103 Type type;
104 uint8_t transferFlag;
105
vkaverapa6575b82019-04-03 05:33:52 -0500106 Response response(sizeof(pldm_msg_hdr) + PLDM_GET_VERSION_RESP_BYTES, 0);
107 auto responsePtr = reinterpret_cast<pldm_msg*>(response.data());
Sampa Misra432e1872019-02-13 03:49:43 -0600108
vkaverapa6575b82019-04-03 05:33:52 -0500109 uint8_t rc = decode_get_version_req(request->payload, payloadLength,
110 &transferHandle, &transferFlag, &type);
111
112 if (rc != PLDM_SUCCESS)
113 {
114 encode_get_version_resp(0, rc, 0, 0, nullptr, 4, responsePtr);
115 return response;
116 }
Sampa Misra432e1872019-02-13 03:49:43 -0600117
Deepak Kodihalli97e0bd52019-02-21 03:54:22 -0600118 ver32_t version{};
Sampa Misra432e1872019-02-13 03:49:43 -0600119 auto search = versions.find(type);
120
121 if (search == versions.end())
122 {
123 encode_get_version_resp(0, PLDM_ERROR_INVALID_PLDM_TYPE, 0, 0, nullptr,
vkaverapa6575b82019-04-03 05:33:52 -0500124 4, responsePtr);
125 return response;
Sampa Misra432e1872019-02-13 03:49:43 -0600126 }
127
128 memcpy(&version, &(search->second), sizeof(version));
129 encode_get_version_resp(0, PLDM_SUCCESS, 0, PLDM_START_AND_END, &version,
vkaverapa6575b82019-04-03 05:33:52 -0500130 sizeof(pldm_version), responsePtr);
131
132 return response;
Sampa Misra432e1872019-02-13 03:49:43 -0600133}
134
Deepak Kodihalli1b24f972019-02-01 04:09:13 -0600135} // namespace responder
136} // namespace pldm