Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 1 | #include "platform.hpp" |
| 2 | |
Tom Joseph | b70a196 | 2020-07-13 12:56:31 +0530 | [diff] [blame] | 3 | #include "common/types.hpp" |
Deepak Kodihalli | d130e1a | 2020-06-17 05:55:32 -0500 | [diff] [blame] | 4 | #include "common/utils.hpp" |
Tom Joseph | c4959c3 | 2020-04-20 19:50:16 +0530 | [diff] [blame] | 5 | #include "event_parser.hpp" |
Sampa Misra | 12afe11 | 2020-05-25 11:40:44 -0500 | [diff] [blame] | 6 | #include "pdr.hpp" |
George Liu | 456c9a2 | 2020-01-13 11:36:22 +0800 | [diff] [blame] | 7 | #include "pdr_numeric_effecter.hpp" |
George Liu | a287072 | 2020-02-11 11:09:30 +0800 | [diff] [blame] | 8 | #include "pdr_state_effecter.hpp" |
George Liu | adbe172 | 2020-05-09 19:20:19 +0800 | [diff] [blame] | 9 | #include "pdr_state_sensor.hpp" |
George Liu | 362c18d | 2020-05-14 09:46:36 +0800 | [diff] [blame] | 10 | #include "pdr_utils.hpp" |
George Liu | eccb0c5 | 2020-01-14 11:09:56 +0800 | [diff] [blame] | 11 | #include "platform_numeric_effecter.hpp" |
George Liu | 0d7aca8 | 2020-03-30 15:01:36 +0800 | [diff] [blame] | 12 | #include "platform_state_effecter.hpp" |
George Liu | 362c18d | 2020-05-14 09:46:36 +0800 | [diff] [blame] | 13 | #include "platform_state_sensor.hpp" |
Sagar Srinivas | 90314a3 | 2023-10-17 10:38:03 -0500 | [diff] [blame] | 14 | #include "pldmd/dbus_impl_requester.hpp" |
| 15 | #include "pldmd/handler.hpp" |
| 16 | #include "requester/handler.hpp" |
George Liu | 8340957 | 2019-12-24 18:42:54 +0800 | [diff] [blame] | 17 | |
George Liu | c453e16 | 2022-12-21 17:16:23 +0800 | [diff] [blame] | 18 | #include <libpldm/entity.h> |
| 19 | #include <libpldm/state_set.h> |
Manojkiran Eda | cc5f158 | 2021-09-29 17:03:06 +0530 | [diff] [blame] | 20 | |
Riya Dixit | 49cfb13 | 2023-03-02 04:26:53 -0600 | [diff] [blame] | 21 | #include <phosphor-logging/lg2.hpp> |
| 22 | |
| 23 | PHOSPHOR_LOG2_USING; |
| 24 | |
Brad Bishop | 5079ac4 | 2021-08-19 18:35:06 -0400 | [diff] [blame] | 25 | using namespace pldm::utils; |
| 26 | using namespace pldm::responder::pdr; |
| 27 | using namespace pldm::responder::pdr_utils; |
| 28 | |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 29 | namespace pldm |
| 30 | { |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 31 | namespace responder |
| 32 | { |
Sampa Misra | a2fa070 | 2019-05-31 01:28:55 -0500 | [diff] [blame] | 33 | namespace platform |
| 34 | { |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 35 | using InternalFailure = |
| 36 | sdbusplus::xyz::openbmc_project::Common::Error::InternalFailure; |
| 37 | |
George Liu | 1ec85d4 | 2020-02-12 16:05:32 +0800 | [diff] [blame] | 38 | static const Json empty{}; |
| 39 | |
George Liu | a287072 | 2020-02-11 11:09:30 +0800 | [diff] [blame] | 40 | void Handler::addDbusObjMaps( |
George Liu | adbe172 | 2020-05-09 19:20:19 +0800 | [diff] [blame] | 41 | uint16_t id, |
| 42 | std::tuple<pdr_utils::DbusMappings, pdr_utils::DbusValMaps> dbusObj, |
| 43 | TypeId typeId) |
George Liu | 1ec85d4 | 2020-02-12 16:05:32 +0800 | [diff] [blame] | 44 | { |
George Liu | adbe172 | 2020-05-09 19:20:19 +0800 | [diff] [blame] | 45 | if (typeId == TypeId::PLDM_SENSOR_ID) |
| 46 | { |
| 47 | sensorDbusObjMaps.emplace(id, dbusObj); |
| 48 | } |
| 49 | else |
| 50 | { |
| 51 | effecterDbusObjMaps.emplace(id, dbusObj); |
| 52 | } |
George Liu | 1ec85d4 | 2020-02-12 16:05:32 +0800 | [diff] [blame] | 53 | } |
| 54 | |
George Liu | a287072 | 2020-02-11 11:09:30 +0800 | [diff] [blame] | 55 | const std::tuple<pdr_utils::DbusMappings, pdr_utils::DbusValMaps>& |
George Liu | adbe172 | 2020-05-09 19:20:19 +0800 | [diff] [blame] | 56 | Handler::getDbusObjMaps(uint16_t id, TypeId typeId) const |
George Liu | 1ec85d4 | 2020-02-12 16:05:32 +0800 | [diff] [blame] | 57 | { |
George Liu | adbe172 | 2020-05-09 19:20:19 +0800 | [diff] [blame] | 58 | if (typeId == TypeId::PLDM_SENSOR_ID) |
| 59 | { |
| 60 | return sensorDbusObjMaps.at(id); |
| 61 | } |
| 62 | else |
| 63 | { |
| 64 | return effecterDbusObjMaps.at(id); |
| 65 | } |
George Liu | 1ec85d4 | 2020-02-12 16:05:32 +0800 | [diff] [blame] | 66 | } |
| 67 | |
George Liu | 36e8135 | 2020-07-01 14:40:30 +0800 | [diff] [blame] | 68 | void Handler::generate(const pldm::utils::DBusHandler& dBusIntf, |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 69 | const std::vector<fs::path>& dir, Repo& repo) |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 70 | { |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 71 | for (const auto& directory : dir) |
Deepak Kodihalli | c6e49c4 | 2020-07-01 03:39:27 -0500 | [diff] [blame] | 72 | { |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 73 | info("Checking if directory '{DIRECTORY}' exists", "DIRECTORY", |
| 74 | directory); |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 75 | if (!fs::exists(directory)) |
| 76 | { |
| 77 | return; |
| 78 | } |
Deepak Kodihalli | c6e49c4 | 2020-07-01 03:39:27 -0500 | [diff] [blame] | 79 | } |
| 80 | |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 81 | // A map of PDR type to a lambda that handles creation of that PDR type. |
| 82 | // The lambda essentially would parse the platform specific PDR JSONs to |
| 83 | // generate the PDR structures. This function iterates through the map to |
| 84 | // invoke all lambdas, so that all PDR types can be created. |
George Liu | a287072 | 2020-02-11 11:09:30 +0800 | [diff] [blame] | 85 | |
Patrick Williams | a675662 | 2023-10-20 11:19:15 -0500 | [diff] [blame] | 86 | const std::map<Type, generatePDR> generateHandlers = { |
| 87 | {PLDM_STATE_EFFECTER_PDR, |
| 88 | [this](const DBusHandler& dBusIntf, const auto& json, |
| 89 | RepoInterface& repo) { |
Patrick Williams | 6da4f91 | 2023-05-10 07:50:53 -0500 | [diff] [blame] | 90 | pdr_state_effecter::generateStateEffecterPDR<pldm::utils::DBusHandler, |
| 91 | Handler>(dBusIntf, json, |
| 92 | *this, repo); |
Patrick Williams | a675662 | 2023-10-20 11:19:15 -0500 | [diff] [blame] | 93 | }}, |
| 94 | {PLDM_NUMERIC_EFFECTER_PDR, |
| 95 | [this](const DBusHandler& dBusIntf, const auto& json, |
| 96 | RepoInterface& repo) { |
Patrick Williams | 6da4f91 | 2023-05-10 07:50:53 -0500 | [diff] [blame] | 97 | pdr_numeric_effecter::generateNumericEffecterPDR< |
| 98 | pldm::utils::DBusHandler, Handler>(dBusIntf, json, *this, repo); |
Patrick Williams | a675662 | 2023-10-20 11:19:15 -0500 | [diff] [blame] | 99 | }}, |
George Liu | adbe172 | 2020-05-09 19:20:19 +0800 | [diff] [blame] | 100 | {PLDM_STATE_SENSOR_PDR, [this](const DBusHandler& dBusIntf, |
| 101 | const auto& json, RepoInterface& repo) { |
Patrick Williams | a675662 | 2023-10-20 11:19:15 -0500 | [diff] [blame] | 102 | pdr_state_sensor::generateStateSensorPDR<pldm::utils::DBusHandler, |
| 103 | Handler>(dBusIntf, json, *this, |
| 104 | repo); |
| 105 | }}}; |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 106 | |
| 107 | Type pdrType{}; |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 108 | for (const auto& directory : dir) |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 109 | { |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 110 | for (const auto& dirEntry : fs::directory_iterator(directory)) |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 111 | { |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 112 | try |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 113 | { |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 114 | if (fs::is_regular_file(dirEntry.path().string())) |
George Liu | 1ec85d4 | 2020-02-12 16:05:32 +0800 | [diff] [blame] | 115 | { |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 116 | auto json = readJson(dirEntry.path().string()); |
| 117 | if (!json.empty()) |
| 118 | { |
| 119 | auto effecterPDRs = json.value("effecterPDRs", empty); |
| 120 | for (const auto& effecter : effecterPDRs) |
| 121 | { |
| 122 | pdrType = effecter.value("pdrType", 0); |
| 123 | generateHandlers.at(pdrType)(dBusIntf, effecter, |
| 124 | repo); |
| 125 | } |
George Liu | adbe172 | 2020-05-09 19:20:19 +0800 | [diff] [blame] | 126 | |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 127 | auto sensorPDRs = json.value("sensorPDRs", empty); |
| 128 | for (const auto& sensor : sensorPDRs) |
| 129 | { |
| 130 | pdrType = sensor.value("pdrType", 0); |
| 131 | generateHandlers.at(pdrType)(dBusIntf, sensor, |
| 132 | repo); |
| 133 | } |
| 134 | } |
George Liu | adbe172 | 2020-05-09 19:20:19 +0800 | [diff] [blame] | 135 | } |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 136 | } |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 137 | catch (const InternalFailure& e) |
| 138 | { |
| 139 | error( |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 140 | "PDR config directory '{PATH}' does not exist or empty for '{TYPE}' pdr, error - {ERROR}", |
| 141 | "PATH", dirEntry.path(), "TYPE", pdrType, "ERROR", e); |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 142 | } |
| 143 | catch (const Json::exception& e) |
| 144 | { |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 145 | error( |
| 146 | "Failed to parse PDR JSON file for '{TYPE}' pdr, error - {ERROR}", |
| 147 | "TYPE", pdrType, "ERROR", e); |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 148 | pldm::utils::reportError( |
| 149 | "xyz.openbmc_project.PLDM.Error.Generate.PDRJsonFileParseFail"); |
| 150 | } |
| 151 | catch (const std::exception& e) |
| 152 | { |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 153 | error( |
| 154 | "Failed to parse PDR JSON file for '{TYPE}' pdr, error - {ERROR}", |
| 155 | "TYPE", pdrType, "ERROR", e); |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 156 | pldm::utils::reportError( |
| 157 | "xyz.openbmc_project.PLDM.Error.Generate.PDRJsonFileParseFail"); |
| 158 | } |
Deepak Kodihalli | c682fe2 | 2020-03-04 00:42:54 -0600 | [diff] [blame] | 159 | } |
| 160 | } |
| 161 | } |
Manojkiran Eda | 92fb0b5 | 2024-04-17 10:48:17 +0530 | [diff] [blame] | 162 | |
Deepak Kodihalli | bc669f1 | 2019-11-28 08:52:07 -0600 | [diff] [blame] | 163 | Response Handler::getPDR(const pldm_msg* request, size_t payloadLength) |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 164 | { |
Manojkiran Eda | c5a1120 | 2024-07-03 12:12:57 +0530 | [diff] [blame] | 165 | if (oemPlatformHandler) |
Pavithra Barithaya | 99854a7 | 2021-09-29 06:58:11 -0500 | [diff] [blame] | 166 | { |
Manojkiran Eda | c5a1120 | 2024-07-03 12:12:57 +0530 | [diff] [blame] | 167 | auto rc = oemPlatformHandler->checkBMCState(); |
| 168 | if (rc != PLDM_SUCCESS) |
Pavithra Barithaya | 99854a7 | 2021-09-29 06:58:11 -0500 | [diff] [blame] | 169 | { |
Manojkiran Eda | c5a1120 | 2024-07-03 12:12:57 +0530 | [diff] [blame] | 170 | return ccOnlyResponse(request, PLDM_ERROR_NOT_READY); |
Pavithra Barithaya | 99854a7 | 2021-09-29 06:58:11 -0500 | [diff] [blame] | 171 | } |
| 172 | } |
| 173 | |
| 174 | // Build FRU table if not built, since entity association PDR's |
| 175 | // are built when the FRU table is constructed. |
Tom Joseph | 33e9c7e | 2020-06-11 22:09:52 +0530 | [diff] [blame] | 176 | if (fruHandler) |
| 177 | { |
| 178 | fruHandler->buildFRUTable(); |
| 179 | } |
| 180 | |
George Liu | d680ae0 | 2020-07-17 09:11:14 +0800 | [diff] [blame] | 181 | if (!pdrCreated) |
| 182 | { |
| 183 | generateTerminusLocatorPDR(pdrRepo); |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 184 | if (platformConfigHandler) |
| 185 | { |
| 186 | auto systemType = platformConfigHandler->getPlatformName(); |
| 187 | if (systemType.has_value()) |
| 188 | { |
| 189 | // In case of normal poweron , the system type would have been |
| 190 | // already filled by entity manager when ever BMC reaches Ready |
| 191 | // state. If this is not filled by time we get a getpdr request |
| 192 | // we can assume that the entity manager service is not present |
| 193 | // on this system & continue to build the common PDR's. |
| 194 | pdrJsonsDir.push_back(pdrJsonDir / systemType.value()); |
| 195 | } |
| 196 | } |
| 197 | |
Sagar Srinivas | 78a225a | 2020-08-27 00:52:20 -0500 | [diff] [blame] | 198 | if (oemPlatformHandler != nullptr) |
| 199 | { |
| 200 | oemPlatformHandler->buildOEMPDR(pdrRepo); |
| 201 | } |
Kamalkumar Patel | 3c50c82 | 2024-01-30 07:14:40 -0600 | [diff] [blame] | 202 | generate(*dBusIntf, pdrJsonsDir, pdrRepo); |
Sagar Srinivas | 78a225a | 2020-08-27 00:52:20 -0500 | [diff] [blame] | 203 | |
George Liu | d680ae0 | 2020-07-17 09:11:14 +0800 | [diff] [blame] | 204 | pdrCreated = true; |
George Liu | 5eed8e5 | 2020-12-18 11:24:37 +0800 | [diff] [blame] | 205 | |
| 206 | if (dbusToPLDMEventHandler) |
| 207 | { |
Sampa Misra | 5fb37d5 | 2021-03-06 07:26:00 -0600 | [diff] [blame] | 208 | deferredGetPDREvent = std::make_unique<sdeventplus::source::Defer>( |
| 209 | event, |
| 210 | std::bind(std::mem_fn(&pldm::responder::platform::Handler:: |
| 211 | _processPostGetPDRActions), |
| 212 | this, std::placeholders::_1)); |
George Liu | 5eed8e5 | 2020-12-18 11:24:37 +0800 | [diff] [blame] | 213 | } |
George Liu | d680ae0 | 2020-07-17 09:11:14 +0800 | [diff] [blame] | 214 | } |
| 215 | |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 216 | Response response(sizeof(pldm_msg_hdr) + PLDM_GET_PDR_MIN_RESP_BYTES, 0); |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 217 | |
| 218 | if (payloadLength != PLDM_GET_PDR_REQ_BYTES) |
| 219 | { |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 220 | return CmdHandler::ccOnlyResponse(request, PLDM_ERROR_INVALID_LENGTH); |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 221 | } |
| 222 | |
| 223 | uint32_t recordHandle{}; |
| 224 | uint32_t dataTransferHandle{}; |
| 225 | uint8_t transferOpFlag{}; |
| 226 | uint16_t reqSizeBytes{}; |
| 227 | uint16_t recordChangeNum{}; |
| 228 | |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 229 | auto rc = decode_get_pdr_req(request, payloadLength, &recordHandle, |
| 230 | &dataTransferHandle, &transferOpFlag, |
| 231 | &reqSizeBytes, &recordChangeNum); |
| 232 | if (rc != PLDM_SUCCESS) |
| 233 | { |
| 234 | return CmdHandler::ccOnlyResponse(request, rc); |
| 235 | } |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 236 | |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 237 | uint16_t respSizeBytes{}; |
| 238 | uint8_t* recordData = nullptr; |
| 239 | try |
| 240 | { |
George Liu | e53193f | 2020-02-24 09:23:26 +0800 | [diff] [blame] | 241 | pdr_utils::PdrEntry e; |
| 242 | auto record = pdr::getRecordByHandle(pdrRepo, recordHandle, e); |
| 243 | if (record == NULL) |
| 244 | { |
| 245 | return CmdHandler::ccOnlyResponse( |
| 246 | request, PLDM_PLATFORM_INVALID_RECORD_HANDLE); |
| 247 | } |
| 248 | |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 249 | if (reqSizeBytes) |
| 250 | { |
George Liu | e53193f | 2020-02-24 09:23:26 +0800 | [diff] [blame] | 251 | respSizeBytes = e.size; |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 252 | if (respSizeBytes > reqSizeBytes) |
| 253 | { |
| 254 | respSizeBytes = reqSizeBytes; |
| 255 | } |
George Liu | e53193f | 2020-02-24 09:23:26 +0800 | [diff] [blame] | 256 | recordData = e.data; |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 257 | } |
| 258 | response.resize(sizeof(pldm_msg_hdr) + PLDM_GET_PDR_MIN_RESP_BYTES + |
| 259 | respSizeBytes, |
| 260 | 0); |
Manojkiran Eda | 31a7844 | 2021-09-12 15:18:25 +0530 | [diff] [blame] | 261 | auto responsePtr = reinterpret_cast<pldm_msg*>(response.data()); |
Deepak Kodihalli | 22b5a7d | 2020-03-17 23:28:41 -0500 | [diff] [blame] | 262 | rc = encode_get_pdr_resp( |
| 263 | request->hdr.instance_id, PLDM_SUCCESS, e.handle.nextRecordHandle, |
| 264 | 0, PLDM_START_AND_END, respSizeBytes, recordData, 0, responsePtr); |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 265 | if (rc != PLDM_SUCCESS) |
| 266 | { |
| 267 | return ccOnlyResponse(request, rc); |
| 268 | } |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 269 | } |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 270 | catch (const std::exception& e) |
| 271 | { |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 272 | error( |
| 273 | "Failed to access PDR record handle '{RECORD_HANDLE}', error - {ERROR}", |
| 274 | "RECORD_HANDLE", recordHandle, "ERROR", e); |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 275 | return CmdHandler::ccOnlyResponse(request, PLDM_ERROR); |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 276 | } |
| 277 | return response; |
| 278 | } |
| 279 | |
Deepak Kodihalli | bc669f1 | 2019-11-28 08:52:07 -0600 | [diff] [blame] | 280 | Response Handler::setStateEffecterStates(const pldm_msg* request, |
| 281 | size_t payloadLength) |
Sampa Misra | a2fa070 | 2019-05-31 01:28:55 -0500 | [diff] [blame] | 282 | { |
| 283 | Response response( |
| 284 | sizeof(pldm_msg_hdr) + PLDM_SET_STATE_EFFECTER_STATES_RESP_BYTES, 0); |
| 285 | auto responsePtr = reinterpret_cast<pldm_msg*>(response.data()); |
| 286 | uint16_t effecterId; |
| 287 | uint8_t compEffecterCnt; |
| 288 | constexpr auto maxCompositeEffecterCnt = 8; |
| 289 | std::vector<set_effecter_state_field> stateField(maxCompositeEffecterCnt, |
| 290 | {0, 0}); |
| 291 | |
| 292 | if ((payloadLength > PLDM_SET_STATE_EFFECTER_STATES_REQ_BYTES) || |
| 293 | (payloadLength < sizeof(effecterId) + sizeof(compEffecterCnt) + |
| 294 | sizeof(set_effecter_state_field))) |
| 295 | { |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 296 | return CmdHandler::ccOnlyResponse(request, PLDM_ERROR_INVALID_LENGTH); |
Sampa Misra | a2fa070 | 2019-05-31 01:28:55 -0500 | [diff] [blame] | 297 | } |
| 298 | |
| 299 | int rc = decode_set_state_effecter_states_req(request, payloadLength, |
| 300 | &effecterId, &compEffecterCnt, |
| 301 | stateField.data()); |
| 302 | |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 303 | if (rc != PLDM_SUCCESS) |
Sampa Misra | a2fa070 | 2019-05-31 01:28:55 -0500 | [diff] [blame] | 304 | { |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 305 | return CmdHandler::ccOnlyResponse(request, rc); |
Sampa Misra | a2fa070 | 2019-05-31 01:28:55 -0500 | [diff] [blame] | 306 | } |
| 307 | |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 308 | stateField.resize(compEffecterCnt); |
| 309 | const pldm::utils::DBusHandler dBusIntf; |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 310 | uint16_t entityType{}; |
| 311 | uint16_t entityInstance{}; |
| 312 | uint16_t stateSetId{}; |
| 313 | |
| 314 | if (isOemStateEffecter(*this, effecterId, compEffecterCnt, entityType, |
| 315 | entityInstance, stateSetId) && |
Manojkiran Eda | 321804e | 2022-03-03 12:36:54 +0530 | [diff] [blame] | 316 | oemPlatformHandler != nullptr && |
| 317 | !effecterDbusObjMaps.contains(effecterId)) |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 318 | { |
Sampa Misra | 3a0e3b9 | 2020-10-21 05:58:00 -0500 | [diff] [blame] | 319 | rc = oemPlatformHandler->oemSetStateEffecterStatesHandler( |
Varsha Kaverappa | 3fbd39e | 2020-09-28 01:40:22 -0500 | [diff] [blame] | 320 | entityType, entityInstance, stateSetId, compEffecterCnt, stateField, |
| 321 | effecterId); |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 322 | } |
| 323 | else |
| 324 | { |
| 325 | rc = platform_state_effecter::setStateEffecterStatesHandler< |
| 326 | pldm::utils::DBusHandler, Handler>(dBusIntf, *this, effecterId, |
| 327 | stateField); |
| 328 | } |
George Liu | fb8611d | 2019-12-06 10:14:15 +0800 | [diff] [blame] | 329 | if (rc != PLDM_SUCCESS) |
| 330 | { |
| 331 | return CmdHandler::ccOnlyResponse(request, rc); |
| 332 | } |
| 333 | |
| 334 | rc = encode_set_state_effecter_states_resp(request->hdr.instance_id, rc, |
| 335 | responsePtr); |
| 336 | if (rc != PLDM_SUCCESS) |
| 337 | { |
| 338 | return ccOnlyResponse(request, rc); |
| 339 | } |
| 340 | |
Sampa Misra | a2fa070 | 2019-05-31 01:28:55 -0500 | [diff] [blame] | 341 | return response; |
| 342 | } |
| 343 | |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 344 | Response Handler::platformEventMessage(const pldm_msg* request, |
| 345 | size_t payloadLength) |
| 346 | { |
| 347 | uint8_t formatVersion{}; |
| 348 | uint8_t tid{}; |
| 349 | uint8_t eventClass{}; |
| 350 | size_t offset{}; |
| 351 | |
| 352 | auto rc = decode_platform_event_message_req( |
| 353 | request, payloadLength, &formatVersion, &tid, &eventClass, &offset); |
| 354 | if (rc != PLDM_SUCCESS) |
| 355 | { |
| 356 | return CmdHandler::ccOnlyResponse(request, rc); |
| 357 | } |
| 358 | |
Sagar Srinivas | a6a8ccd | 2021-04-01 07:58:33 -0500 | [diff] [blame] | 359 | if (eventClass == PLDM_HEARTBEAT_TIMER_ELAPSED_EVENT) |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 360 | { |
Sagar Srinivas | a6a8ccd | 2021-04-01 07:58:33 -0500 | [diff] [blame] | 361 | rc = PLDM_SUCCESS; |
Sagar Srinivas | 79669c9 | 2021-04-28 15:43:30 -0500 | [diff] [blame] | 362 | if (oemPlatformHandler) |
| 363 | { |
Sagar Srinivas | 18145f7 | 2022-04-11 07:38:26 -0500 | [diff] [blame] | 364 | if (oemPlatformHandler->watchDogRunning()) |
| 365 | { |
| 366 | oemPlatformHandler->resetWatchDogTimer(); |
| 367 | } |
| 368 | else |
| 369 | { |
| 370 | oemPlatformHandler->setSurvTimer(tid, true); |
| 371 | } |
Sagar Srinivas | 79669c9 | 2021-04-28 15:43:30 -0500 | [diff] [blame] | 372 | } |
Sagar Srinivas | a6a8ccd | 2021-04-01 07:58:33 -0500 | [diff] [blame] | 373 | } |
| 374 | else |
| 375 | { |
| 376 | try |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 377 | { |
Sagar Srinivas | a6a8ccd | 2021-04-01 07:58:33 -0500 | [diff] [blame] | 378 | const auto& handlers = eventHandlers.at(eventClass); |
| 379 | for (const auto& handler : handlers) |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 380 | { |
Patrick Williams | 6da4f91 | 2023-05-10 07:50:53 -0500 | [diff] [blame] | 381 | auto rc = handler(request, payloadLength, formatVersion, tid, |
| 382 | offset); |
Sagar Srinivas | a6a8ccd | 2021-04-01 07:58:33 -0500 | [diff] [blame] | 383 | if (rc != PLDM_SUCCESS) |
| 384 | { |
| 385 | return CmdHandler::ccOnlyResponse(request, rc); |
| 386 | } |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 387 | } |
| 388 | } |
Sagar Srinivas | a6a8ccd | 2021-04-01 07:58:33 -0500 | [diff] [blame] | 389 | catch (const std::out_of_range& e) |
| 390 | { |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 391 | error("Failed to handle platform event msg, error - {ERROR}", |
| 392 | "ERROR", e); |
Sagar Srinivas | a6a8ccd | 2021-04-01 07:58:33 -0500 | [diff] [blame] | 393 | return CmdHandler::ccOnlyResponse(request, PLDM_ERROR_INVALID_DATA); |
| 394 | } |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 395 | } |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 396 | Response response( |
| 397 | sizeof(pldm_msg_hdr) + PLDM_PLATFORM_EVENT_MESSAGE_RESP_BYTES, 0); |
| 398 | auto responsePtr = reinterpret_cast<pldm_msg*>(response.data()); |
| 399 | |
| 400 | rc = encode_platform_event_message_resp(request->hdr.instance_id, rc, |
| 401 | PLDM_EVENT_NO_LOGGING, responsePtr); |
| 402 | if (rc != PLDM_SUCCESS) |
| 403 | { |
| 404 | return ccOnlyResponse(request, rc); |
| 405 | } |
| 406 | |
| 407 | return response; |
| 408 | } |
| 409 | |
| 410 | int Handler::sensorEvent(const pldm_msg* request, size_t payloadLength, |
Tom Joseph | c4959c3 | 2020-04-20 19:50:16 +0530 | [diff] [blame] | 411 | uint8_t /*formatVersion*/, uint8_t tid, |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 412 | size_t eventDataOffset) |
| 413 | { |
| 414 | uint16_t sensorId{}; |
| 415 | uint8_t eventClass{}; |
| 416 | size_t eventClassDataOffset{}; |
Patrick Williams | 6da4f91 | 2023-05-10 07:50:53 -0500 | [diff] [blame] | 417 | auto eventData = reinterpret_cast<const uint8_t*>(request->payload) + |
| 418 | eventDataOffset; |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 419 | auto eventDataSize = payloadLength - eventDataOffset; |
| 420 | |
| 421 | auto rc = decode_sensor_event_data(eventData, eventDataSize, &sensorId, |
| 422 | &eventClass, &eventClassDataOffset); |
| 423 | if (rc != PLDM_SUCCESS) |
| 424 | { |
| 425 | return rc; |
| 426 | } |
| 427 | |
Zahed Hossain | 75330f3 | 2020-03-24 02:15:03 -0500 | [diff] [blame] | 428 | auto eventClassData = reinterpret_cast<const uint8_t*>(request->payload) + |
| 429 | eventDataOffset + eventClassDataOffset; |
Patrick Williams | 6da4f91 | 2023-05-10 07:50:53 -0500 | [diff] [blame] | 430 | auto eventClassDataSize = payloadLength - eventDataOffset - |
| 431 | eventClassDataOffset; |
Zahed Hossain | 75330f3 | 2020-03-24 02:15:03 -0500 | [diff] [blame] | 432 | |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 433 | if (eventClass == PLDM_STATE_SENSOR_STATE) |
| 434 | { |
| 435 | uint8_t sensorOffset{}; |
| 436 | uint8_t eventState{}; |
| 437 | uint8_t previousEventState{}; |
| 438 | |
Zahed Hossain | 75330f3 | 2020-03-24 02:15:03 -0500 | [diff] [blame] | 439 | rc = decode_state_sensor_data(eventClassData, eventClassDataSize, |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 440 | &sensorOffset, &eventState, |
| 441 | &previousEventState); |
Zahed Hossain | 75330f3 | 2020-03-24 02:15:03 -0500 | [diff] [blame] | 442 | if (rc != PLDM_SUCCESS) |
| 443 | { |
| 444 | return PLDM_ERROR; |
| 445 | } |
| 446 | |
Chicago Duan | fe4d88b | 2020-06-12 16:44:13 +0800 | [diff] [blame] | 447 | // Emitting state sensor event signal |
| 448 | emitStateSensorEventSignal(tid, sensorId, sensorOffset, eventState, |
| 449 | previousEventState); |
| 450 | |
Tom Joseph | c4959c3 | 2020-04-20 19:50:16 +0530 | [diff] [blame] | 451 | // If there are no HOST PDR's, there is no further action |
| 452 | if (hostPDRHandler == NULL) |
| 453 | { |
| 454 | return PLDM_SUCCESS; |
| 455 | } |
| 456 | |
| 457 | // Handle PLDM events for which PDR is available |
| 458 | SensorEntry sensorEntry{tid, sensorId}; |
Tom Joseph | b70a196 | 2020-07-13 12:56:31 +0530 | [diff] [blame] | 459 | |
| 460 | pldm::pdr::EntityInfo entityInfo{}; |
| 461 | pldm::pdr::CompositeSensorStates compositeSensorStates{}; |
Sagar Srinivas | e3607a3 | 2024-02-16 03:50:53 -0600 | [diff] [blame] | 462 | std::vector<pldm::pdr::StateSetId> stateSetIds{}; |
Tom Joseph | b70a196 | 2020-07-13 12:56:31 +0530 | [diff] [blame] | 463 | |
Tom Joseph | c4959c3 | 2020-04-20 19:50:16 +0530 | [diff] [blame] | 464 | try |
| 465 | { |
Sagar Srinivas | e3607a3 | 2024-02-16 03:50:53 -0600 | [diff] [blame] | 466 | std::tie(entityInfo, compositeSensorStates, stateSetIds) = |
Tom Joseph | c4959c3 | 2020-04-20 19:50:16 +0530 | [diff] [blame] | 467 | hostPDRHandler->lookupSensorInfo(sensorEntry); |
Tom Joseph | c4959c3 | 2020-04-20 19:50:16 +0530 | [diff] [blame] | 468 | } |
Kamalkumar Patel | 58cbcaf | 2023-10-06 03:48:25 -0500 | [diff] [blame] | 469 | catch (const std::out_of_range&) |
Tom Joseph | c4959c3 | 2020-04-20 19:50:16 +0530 | [diff] [blame] | 470 | { |
Tom Joseph | b70a196 | 2020-07-13 12:56:31 +0530 | [diff] [blame] | 471 | // If there is no mapping for tid, sensorId combination, try |
| 472 | // PLDM_TID_RESERVED, sensorId for terminus that is yet to |
| 473 | // implement TL PDR. |
| 474 | try |
| 475 | { |
| 476 | sensorEntry.terminusID = PLDM_TID_RESERVED; |
Sagar Srinivas | e3607a3 | 2024-02-16 03:50:53 -0600 | [diff] [blame] | 477 | std::tie(entityInfo, compositeSensorStates, stateSetIds) = |
Tom Joseph | b70a196 | 2020-07-13 12:56:31 +0530 | [diff] [blame] | 478 | hostPDRHandler->lookupSensorInfo(sensorEntry); |
| 479 | } |
| 480 | // If there is no mapping for events return PLDM_SUCCESS |
Kamalkumar Patel | 58cbcaf | 2023-10-06 03:48:25 -0500 | [diff] [blame] | 481 | catch (const std::out_of_range&) |
Tom Joseph | b70a196 | 2020-07-13 12:56:31 +0530 | [diff] [blame] | 482 | { |
| 483 | return PLDM_SUCCESS; |
| 484 | } |
Zahed Hossain | 75330f3 | 2020-03-24 02:15:03 -0500 | [diff] [blame] | 485 | } |
Tom Joseph | b70a196 | 2020-07-13 12:56:31 +0530 | [diff] [blame] | 486 | |
| 487 | if (sensorOffset >= compositeSensorStates.size()) |
| 488 | { |
| 489 | return PLDM_ERROR_INVALID_DATA; |
| 490 | } |
| 491 | |
| 492 | const auto& possibleStates = compositeSensorStates[sensorOffset]; |
Sagar Srinivas | 06f9b29 | 2024-03-31 11:35:28 -0500 | [diff] [blame] | 493 | if (!possibleStates.contains(eventState)) |
Tom Joseph | b70a196 | 2020-07-13 12:56:31 +0530 | [diff] [blame] | 494 | { |
| 495 | return PLDM_ERROR_INVALID_DATA; |
| 496 | } |
| 497 | |
| 498 | const auto& [containerId, entityType, entityInstance] = entityInfo; |
Manojkiran Eda | fa08470 | 2024-05-27 10:20:30 +0530 | [diff] [blame] | 499 | events::StateSensorEntry stateSensorEntry{containerId, |
| 500 | entityType, |
| 501 | entityInstance, |
| 502 | sensorOffset, |
| 503 | stateSetIds[sensorOffset], |
| 504 | false}; |
Pavithra Barithaya | 3aec997 | 2020-12-14 01:55:44 -0600 | [diff] [blame] | 505 | return hostPDRHandler->handleStateSensorEvent(stateSensorEntry, |
| 506 | eventState); |
Tom Joseph | 56e45c5 | 2020-03-16 10:01:45 +0530 | [diff] [blame] | 507 | } |
| 508 | else |
| 509 | { |
| 510 | return PLDM_ERROR_INVALID_DATA; |
| 511 | } |
| 512 | |
| 513 | return PLDM_SUCCESS; |
| 514 | } |
| 515 | |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 516 | int Handler::pldmPDRRepositoryChgEvent(const pldm_msg* request, |
| 517 | size_t payloadLength, |
Manojkiran Eda | 3ca4045 | 2021-10-04 22:51:37 +0530 | [diff] [blame] | 518 | uint8_t /*formatVersion*/, uint8_t tid, |
| 519 | size_t eventDataOffset) |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 520 | { |
| 521 | uint8_t eventDataFormat{}; |
| 522 | uint8_t numberOfChangeRecords{}; |
| 523 | size_t dataOffset{}; |
| 524 | |
Patrick Williams | 6da4f91 | 2023-05-10 07:50:53 -0500 | [diff] [blame] | 525 | auto eventData = reinterpret_cast<const uint8_t*>(request->payload) + |
| 526 | eventDataOffset; |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 527 | auto eventDataSize = payloadLength - eventDataOffset; |
| 528 | |
| 529 | auto rc = decode_pldm_pdr_repository_chg_event_data( |
| 530 | eventData, eventDataSize, &eventDataFormat, &numberOfChangeRecords, |
| 531 | &dataOffset); |
| 532 | if (rc != PLDM_SUCCESS) |
| 533 | { |
| 534 | return rc; |
| 535 | } |
| 536 | |
| 537 | PDRRecordHandles pdrRecordHandles; |
Deepak Kodihalli | 7246e0c | 2020-07-08 06:40:18 -0500 | [diff] [blame] | 538 | |
| 539 | if (eventDataFormat == FORMAT_IS_PDR_TYPES) |
| 540 | { |
| 541 | return PLDM_ERROR_INVALID_DATA; |
| 542 | } |
| 543 | |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 544 | if (eventDataFormat == FORMAT_IS_PDR_HANDLES) |
| 545 | { |
| 546 | uint8_t eventDataOperation{}; |
| 547 | uint8_t numberOfChangeEntries{}; |
| 548 | |
| 549 | auto changeRecordData = eventData + dataOffset; |
| 550 | auto changeRecordDataSize = eventDataSize - dataOffset; |
| 551 | |
| 552 | while (changeRecordDataSize) |
| 553 | { |
| 554 | rc = decode_pldm_pdr_repository_change_record_data( |
| 555 | changeRecordData, changeRecordDataSize, &eventDataOperation, |
| 556 | &numberOfChangeEntries, &dataOffset); |
| 557 | |
| 558 | if (rc != PLDM_SUCCESS) |
| 559 | { |
| 560 | return rc; |
| 561 | } |
| 562 | |
Pavithra Barithaya | ae5c97e | 2022-08-29 02:57:59 -0500 | [diff] [blame] | 563 | if (eventDataOperation == PLDM_RECORDS_ADDED || |
| 564 | eventDataOperation == PLDM_RECORDS_MODIFIED) |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 565 | { |
Pavithra Barithaya | ae5c97e | 2022-08-29 02:57:59 -0500 | [diff] [blame] | 566 | if (eventDataOperation == PLDM_RECORDS_MODIFIED) |
| 567 | { |
| 568 | hostPDRHandler->isHostPdrModified = true; |
| 569 | } |
| 570 | |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 571 | rc = getPDRRecordHandles( |
| 572 | reinterpret_cast<const ChangeEntry*>(changeRecordData + |
| 573 | dataOffset), |
| 574 | changeRecordDataSize - dataOffset, |
| 575 | static_cast<size_t>(numberOfChangeEntries), |
| 576 | pdrRecordHandles); |
| 577 | |
| 578 | if (rc != PLDM_SUCCESS) |
| 579 | { |
| 580 | return rc; |
| 581 | } |
| 582 | } |
| 583 | |
Patrick Williams | 6da4f91 | 2023-05-10 07:50:53 -0500 | [diff] [blame] | 584 | changeRecordData += dataOffset + |
| 585 | (numberOfChangeEntries * sizeof(ChangeEntry)); |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 586 | changeRecordDataSize -= |
| 587 | dataOffset + (numberOfChangeEntries * sizeof(ChangeEntry)); |
| 588 | } |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 589 | } |
Deepak Kodihalli | 7246e0c | 2020-07-08 06:40:18 -0500 | [diff] [blame] | 590 | if (hostPDRHandler) |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 591 | { |
Manojkiran Eda | 3ca4045 | 2021-10-04 22:51:37 +0530 | [diff] [blame] | 592 | // if we get a Repository change event with the eventDataFormat |
| 593 | // as REFRESH_ENTIRE_REPOSITORY, then delete all the PDR's that |
| 594 | // have the matched Terminus handle |
| 595 | if (eventDataFormat == REFRESH_ENTIRE_REPOSITORY) |
| 596 | { |
| 597 | // We cannot get the Repo change event from the Terminus |
| 598 | // that is not already added to the BMC repository |
| 599 | |
Pavithra Barithaya | 52aad39 | 2022-08-02 04:18:52 -0500 | [diff] [blame] | 600 | for (auto it = hostPDRHandler->tlPDRInfo.cbegin(); |
| 601 | it != hostPDRHandler->tlPDRInfo.cend();) |
Manojkiran Eda | 3ca4045 | 2021-10-04 22:51:37 +0530 | [diff] [blame] | 602 | { |
Pavithra Barithaya | 52aad39 | 2022-08-02 04:18:52 -0500 | [diff] [blame] | 603 | if (std::get<0>(it->second) == tid) |
Manojkiran Eda | 3ca4045 | 2021-10-04 22:51:37 +0530 | [diff] [blame] | 604 | { |
| 605 | pldm_pdr_remove_pdrs_by_terminus_handle(pdrRepo.getPdr(), |
Pavithra Barithaya | 52aad39 | 2022-08-02 04:18:52 -0500 | [diff] [blame] | 606 | it->first); |
| 607 | hostPDRHandler->tlPDRInfo.erase(it++); |
| 608 | } |
| 609 | else |
| 610 | { |
| 611 | ++it; |
Manojkiran Eda | 3ca4045 | 2021-10-04 22:51:37 +0530 | [diff] [blame] | 612 | } |
| 613 | } |
| 614 | } |
Deepak Kodihalli | 7246e0c | 2020-07-08 06:40:18 -0500 | [diff] [blame] | 615 | hostPDRHandler->fetchPDR(std::move(pdrRecordHandles)); |
Deepak Kodihalli | 8cb6f66 | 2020-04-10 02:55:43 -0500 | [diff] [blame] | 616 | } |
| 617 | |
| 618 | return PLDM_SUCCESS; |
| 619 | } |
| 620 | |
| 621 | int Handler::getPDRRecordHandles(const ChangeEntry* changeEntryData, |
| 622 | size_t changeEntryDataSize, |
| 623 | size_t numberOfChangeEntries, |
| 624 | PDRRecordHandles& pdrRecordHandles) |
| 625 | { |
| 626 | if (numberOfChangeEntries > (changeEntryDataSize / sizeof(ChangeEntry))) |
| 627 | { |
| 628 | return PLDM_ERROR_INVALID_DATA; |
| 629 | } |
| 630 | for (size_t i = 0; i < numberOfChangeEntries; i++) |
| 631 | { |
| 632 | pdrRecordHandles.push_back(changeEntryData[i]); |
| 633 | } |
| 634 | return PLDM_SUCCESS; |
| 635 | } |
| 636 | |
Archana Kakani | 6ece21fb | 2023-10-10 08:21:52 -0500 | [diff] [blame] | 637 | Response Handler::getNumericEffecterValue(const pldm_msg* request, |
| 638 | size_t payloadLength) |
| 639 | { |
| 640 | if (payloadLength != PLDM_GET_NUMERIC_EFFECTER_VALUE_REQ_BYTES) |
| 641 | { |
| 642 | return ccOnlyResponse(request, PLDM_ERROR_INVALID_LENGTH); |
| 643 | } |
| 644 | |
| 645 | uint16_t effecterId{}; |
| 646 | auto rc = decode_get_numeric_effecter_value_req(request, payloadLength, |
| 647 | &effecterId); |
| 648 | if (rc != PLDM_SUCCESS) |
| 649 | { |
| 650 | return ccOnlyResponse(request, rc); |
| 651 | } |
| 652 | |
| 653 | const pldm::utils::DBusHandler dBusIntf; |
| 654 | uint8_t effecterDataSize{}; |
| 655 | pldm::utils::PropertyValue dbusValue; |
| 656 | std::string propertyType; |
| 657 | using effecterOperationalState = uint8_t; |
| 658 | using completionCode = uint8_t; |
| 659 | |
| 660 | rc = platform_numeric_effecter::getNumericEffecterData< |
| 661 | pldm::utils::DBusHandler, Handler>( |
| 662 | dBusIntf, *this, effecterId, effecterDataSize, propertyType, dbusValue); |
| 663 | |
| 664 | if (rc != PLDM_SUCCESS) |
| 665 | { |
| 666 | return ccOnlyResponse(request, rc); |
| 667 | } |
| 668 | |
| 669 | // Refer DSP0248_1.2.0.pdf (section 22.3, Table 48) |
| 670 | // Completion Code (uint8), Effecter Data Size(uint8), Effecter Operational |
| 671 | // State(uint8), PendingValue (uint8|sint8|uint16|sint16|uint32|sint32 ) |
| 672 | // PresentValue (uint8|sint8|uint16|sint16|uint32|sint32 ) |
| 673 | // Size of PendingValue and PresentValue calculated based on size is |
| 674 | // provided in effecter data size |
| 675 | size_t responsePayloadLength = sizeof(completionCode) + |
| 676 | sizeof(effecterDataSize) + |
| 677 | sizeof(effecterOperationalState) + |
| 678 | getEffecterDataSize(effecterDataSize) + |
| 679 | getEffecterDataSize(effecterDataSize); |
| 680 | |
| 681 | Response response(responsePayloadLength + sizeof(pldm_msg_hdr)); |
| 682 | auto responsePtr = reinterpret_cast<pldm_msg*>(response.data()); |
| 683 | |
| 684 | rc = platform_numeric_effecter::getNumericEffecterValueHandler( |
| 685 | propertyType, dbusValue, effecterDataSize, responsePtr, |
| 686 | responsePayloadLength, request->hdr.instance_id); |
| 687 | |
| 688 | if (rc != PLDM_SUCCESS) |
| 689 | { |
| 690 | error( |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 691 | "Failed to get response of GetNumericEffecterValue for effecter ID '{EFFECTERID}', response code '{RC}'.", |
| 692 | "EFFECTERID", effecterId, "RC", rc); |
Archana Kakani | 6ece21fb | 2023-10-10 08:21:52 -0500 | [diff] [blame] | 693 | return ccOnlyResponse(request, rc); |
| 694 | } |
| 695 | return response; |
| 696 | } |
| 697 | |
George Liu | eccb0c5 | 2020-01-14 11:09:56 +0800 | [diff] [blame] | 698 | Response Handler::setNumericEffecterValue(const pldm_msg* request, |
| 699 | size_t payloadLength) |
| 700 | { |
| 701 | Response response(sizeof(pldm_msg_hdr) + |
| 702 | PLDM_SET_NUMERIC_EFFECTER_VALUE_RESP_BYTES); |
| 703 | uint16_t effecterId{}; |
| 704 | uint8_t effecterDataSize{}; |
| 705 | uint8_t effecterValue[4] = {}; |
| 706 | |
| 707 | if ((payloadLength > sizeof(effecterId) + sizeof(effecterDataSize) + |
| 708 | sizeof(union_effecter_data_size)) || |
| 709 | (payloadLength < sizeof(effecterId) + sizeof(effecterDataSize) + 1)) |
| 710 | { |
| 711 | return ccOnlyResponse(request, PLDM_ERROR_INVALID_LENGTH); |
| 712 | } |
| 713 | |
| 714 | int rc = decode_set_numeric_effecter_value_req( |
Andrew Jeffery | 8fbf3cc | 2023-04-12 13:42:29 +0930 | [diff] [blame] | 715 | request, payloadLength, &effecterId, &effecterDataSize, effecterValue); |
George Liu | eccb0c5 | 2020-01-14 11:09:56 +0800 | [diff] [blame] | 716 | |
| 717 | if (rc == PLDM_SUCCESS) |
| 718 | { |
| 719 | const pldm::utils::DBusHandler dBusIntf; |
| 720 | rc = platform_numeric_effecter::setNumericEffecterValueHandler< |
| 721 | pldm::utils::DBusHandler, Handler>(dBusIntf, *this, effecterId, |
| 722 | effecterDataSize, effecterValue, |
| 723 | sizeof(effecterValue)); |
| 724 | } |
| 725 | |
| 726 | return ccOnlyResponse(request, rc); |
| 727 | } |
| 728 | |
Sampa Misra | 12afe11 | 2020-05-25 11:40:44 -0500 | [diff] [blame] | 729 | void Handler::generateTerminusLocatorPDR(Repo& repo) |
| 730 | { |
| 731 | std::vector<uint8_t> pdrBuffer(sizeof(pldm_terminus_locator_pdr)); |
| 732 | |
| 733 | auto pdr = reinterpret_cast<pldm_terminus_locator_pdr*>(pdrBuffer.data()); |
| 734 | |
| 735 | pdr->hdr.record_handle = 0; |
| 736 | pdr->hdr.version = 1; |
| 737 | pdr->hdr.type = PLDM_TERMINUS_LOCATOR_PDR; |
| 738 | pdr->hdr.record_change_num = 0; |
| 739 | pdr->hdr.length = sizeof(pldm_terminus_locator_pdr) - sizeof(pldm_pdr_hdr); |
Manojkiran Eda | cc5f158 | 2021-09-29 17:03:06 +0530 | [diff] [blame] | 740 | pdr->terminus_handle = TERMINUS_HANDLE; |
Sampa Misra | 12afe11 | 2020-05-25 11:40:44 -0500 | [diff] [blame] | 741 | pdr->validity = PLDM_TL_PDR_VALID; |
Manojkiran Eda | cc5f158 | 2021-09-29 17:03:06 +0530 | [diff] [blame] | 742 | pdr->tid = TERMINUS_ID; |
Sampa Misra | 12afe11 | 2020-05-25 11:40:44 -0500 | [diff] [blame] | 743 | pdr->container_id = 0x0; |
| 744 | pdr->terminus_locator_type = PLDM_TERMINUS_LOCATOR_TYPE_MCTP_EID; |
| 745 | pdr->terminus_locator_value_size = |
| 746 | sizeof(pldm_terminus_locator_type_mctp_eid); |
| 747 | auto locatorValue = reinterpret_cast<pldm_terminus_locator_type_mctp_eid*>( |
| 748 | pdr->terminus_locator_value); |
| 749 | locatorValue->eid = BmcMctpEid; |
| 750 | |
| 751 | PdrEntry pdrEntry{}; |
| 752 | pdrEntry.data = pdrBuffer.data(); |
| 753 | pdrEntry.size = pdrBuffer.size(); |
| 754 | repo.addRecord(pdrEntry); |
Manojkiran Eda | 60e1fe9 | 2021-10-08 15:58:16 +0530 | [diff] [blame] | 755 | if (hostPDRHandler) |
| 756 | { |
| 757 | hostPDRHandler->tlPDRInfo.insert_or_assign( |
| 758 | pdr->terminus_handle, |
| 759 | std::make_tuple(pdr->tid, locatorValue->eid, pdr->validity)); |
| 760 | } |
Sampa Misra | 12afe11 | 2020-05-25 11:40:44 -0500 | [diff] [blame] | 761 | } |
George Liu | 362c18d | 2020-05-14 09:46:36 +0800 | [diff] [blame] | 762 | |
| 763 | Response Handler::getStateSensorReadings(const pldm_msg* request, |
| 764 | size_t payloadLength) |
| 765 | { |
| 766 | uint16_t sensorId{}; |
| 767 | bitfield8_t sensorRearm{}; |
| 768 | uint8_t reserved{}; |
| 769 | |
Pavithra Barithaya | 87083f2 | 2023-04-17 01:27:49 -0500 | [diff] [blame] | 770 | if (payloadLength != PLDM_GET_STATE_SENSOR_READINGS_REQ_BYTES) |
George Liu | 362c18d | 2020-05-14 09:46:36 +0800 | [diff] [blame] | 771 | { |
| 772 | return ccOnlyResponse(request, PLDM_ERROR_INVALID_LENGTH); |
| 773 | } |
| 774 | |
| 775 | int rc = decode_get_state_sensor_readings_req( |
| 776 | request, payloadLength, &sensorId, &sensorRearm, &reserved); |
| 777 | |
| 778 | if (rc != PLDM_SUCCESS) |
| 779 | { |
| 780 | return ccOnlyResponse(request, rc); |
| 781 | } |
| 782 | |
| 783 | // 0x01 to 0x08 |
George Liu | c1230ca | 2021-08-03 16:06:50 +0800 | [diff] [blame] | 784 | uint8_t sensorRearmCount = std::popcount(sensorRearm.byte); |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 785 | std::vector<get_sensor_state_field> stateField(sensorRearmCount); |
George Liu | 362c18d | 2020-05-14 09:46:36 +0800 | [diff] [blame] | 786 | uint8_t comSensorCnt{}; |
| 787 | const pldm::utils::DBusHandler dBusIntf; |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 788 | |
| 789 | uint16_t entityType{}; |
| 790 | uint16_t entityInstance{}; |
| 791 | uint16_t stateSetId{}; |
| 792 | |
| 793 | if (isOemStateSensor(*this, sensorId, sensorRearmCount, comSensorCnt, |
| 794 | entityType, entityInstance, stateSetId) && |
Manojkiran Eda | 321804e | 2022-03-03 12:36:54 +0530 | [diff] [blame] | 795 | oemPlatformHandler != nullptr && !sensorDbusObjMaps.contains(sensorId)) |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 796 | { |
| 797 | rc = oemPlatformHandler->getOemStateSensorReadingsHandler( |
| 798 | entityType, entityInstance, stateSetId, comSensorCnt, stateField); |
| 799 | } |
| 800 | else |
| 801 | { |
| 802 | rc = platform_state_sensor::getStateSensorReadingsHandler< |
Manojkiran Eda | ae933cc | 2024-02-21 17:19:21 +0530 | [diff] [blame] | 803 | pldm::utils::DBusHandler, Handler>( |
| 804 | dBusIntf, *this, sensorId, sensorRearmCount, comSensorCnt, |
| 805 | stateField, dbusToPLDMEventHandler->getSensorCache()); |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 806 | } |
George Liu | 362c18d | 2020-05-14 09:46:36 +0800 | [diff] [blame] | 807 | |
| 808 | if (rc != PLDM_SUCCESS) |
| 809 | { |
| 810 | return ccOnlyResponse(request, rc); |
| 811 | } |
| 812 | |
| 813 | Response response(sizeof(pldm_msg_hdr) + |
| 814 | PLDM_GET_STATE_SENSOR_READINGS_MIN_RESP_BYTES + |
| 815 | sizeof(get_sensor_state_field) * comSensorCnt); |
| 816 | auto responsePtr = reinterpret_cast<pldm_msg*>(response.data()); |
| 817 | rc = encode_get_state_sensor_readings_resp(request->hdr.instance_id, rc, |
| 818 | comSensorCnt, stateField.data(), |
| 819 | responsePtr); |
| 820 | if (rc != PLDM_SUCCESS) |
| 821 | { |
| 822 | return ccOnlyResponse(request, rc); |
| 823 | } |
| 824 | |
| 825 | return response; |
| 826 | } |
| 827 | |
Pavithra Barithaya | 99854a7 | 2021-09-29 06:58:11 -0500 | [diff] [blame] | 828 | void Handler::_processPostGetPDRActions(sdeventplus::source::EventBase& |
| 829 | /*source */) |
Sampa Misra | 5fb37d5 | 2021-03-06 07:26:00 -0600 | [diff] [blame] | 830 | { |
| 831 | deferredGetPDREvent.reset(); |
| 832 | dbusToPLDMEventHandler->listenSensorEvent(pdrRepo, sensorDbusObjMaps); |
| 833 | } |
| 834 | |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 835 | bool isOemStateSensor(Handler& handler, uint16_t sensorId, |
| 836 | uint8_t sensorRearmCount, uint8_t& compSensorCnt, |
| 837 | uint16_t& entityType, uint16_t& entityInstance, |
| 838 | uint16_t& stateSetId) |
| 839 | { |
| 840 | pldm_state_sensor_pdr* pdr = nullptr; |
| 841 | |
| 842 | std::unique_ptr<pldm_pdr, decltype(&pldm_pdr_destroy)> stateSensorPdrRepo( |
| 843 | pldm_pdr_init(), pldm_pdr_destroy); |
Andrew Jeffery | acb2029 | 2023-06-30 11:47:44 +0930 | [diff] [blame] | 844 | if (!stateSensorPdrRepo) |
| 845 | { |
| 846 | error("Failed to instantiate state sensor PDR repository"); |
| 847 | return false; |
| 848 | } |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 849 | Repo stateSensorPDRs(stateSensorPdrRepo.get()); |
| 850 | getRepoByType(handler.getRepo(), stateSensorPDRs, PLDM_STATE_SENSOR_PDR); |
| 851 | if (stateSensorPDRs.empty()) |
| 852 | { |
Riya Dixit | 49cfb13 | 2023-03-02 04:26:53 -0600 | [diff] [blame] | 853 | error("Failed to get record by PDR type"); |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 854 | return false; |
| 855 | } |
| 856 | |
| 857 | PdrEntry pdrEntry{}; |
| 858 | auto pdrRecord = stateSensorPDRs.getFirstRecord(pdrEntry); |
| 859 | while (pdrRecord) |
| 860 | { |
| 861 | pdr = reinterpret_cast<pldm_state_sensor_pdr*>(pdrEntry.data); |
| 862 | assert(pdr != NULL); |
| 863 | if (pdr->sensor_id != sensorId) |
| 864 | { |
| 865 | pdr = nullptr; |
| 866 | pdrRecord = stateSensorPDRs.getNextRecord(pdrRecord, pdrEntry); |
| 867 | continue; |
| 868 | } |
| 869 | auto tmpEntityType = pdr->entity_type; |
| 870 | auto tmpEntityInstance = pdr->entity_instance; |
| 871 | auto tmpCompSensorCnt = pdr->composite_sensor_count; |
| 872 | auto tmpPossibleStates = |
| 873 | reinterpret_cast<state_sensor_possible_states*>( |
| 874 | pdr->possible_states); |
| 875 | auto tmpStateSetId = tmpPossibleStates->state_set_id; |
| 876 | |
| 877 | if (sensorRearmCount > tmpCompSensorCnt) |
| 878 | { |
Riya Dixit | 49cfb13 | 2023-03-02 04:26:53 -0600 | [diff] [blame] | 879 | error( |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 880 | "The requester sent wrong sensor rearm count '{SENSOR_REARM_COUNT}' for the sensor ID '{SENSORID}'.", |
| 881 | "SENSOR_REARM_COUNT", (uint16_t)sensorRearmCount, "SENSORID", |
| 882 | sensorId); |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 883 | break; |
| 884 | } |
| 885 | |
| 886 | if ((tmpEntityType >= PLDM_OEM_ENTITY_TYPE_START && |
| 887 | tmpEntityType <= PLDM_OEM_ENTITY_TYPE_END) || |
| 888 | (tmpStateSetId >= PLDM_OEM_STATE_SET_ID_START && |
| 889 | tmpStateSetId < PLDM_OEM_STATE_SET_ID_END)) |
| 890 | { |
| 891 | entityType = tmpEntityType; |
| 892 | entityInstance = tmpEntityInstance; |
| 893 | stateSetId = tmpStateSetId; |
| 894 | compSensorCnt = tmpCompSensorCnt; |
| 895 | return true; |
| 896 | } |
| 897 | else |
| 898 | { |
| 899 | return false; |
| 900 | } |
| 901 | } |
| 902 | return false; |
| 903 | } |
| 904 | |
| 905 | bool isOemStateEffecter(Handler& handler, uint16_t effecterId, |
| 906 | uint8_t compEffecterCnt, uint16_t& entityType, |
| 907 | uint16_t& entityInstance, uint16_t& stateSetId) |
| 908 | { |
| 909 | pldm_state_effecter_pdr* pdr = nullptr; |
| 910 | |
| 911 | std::unique_ptr<pldm_pdr, decltype(&pldm_pdr_destroy)> stateEffecterPdrRepo( |
| 912 | pldm_pdr_init(), pldm_pdr_destroy); |
Andrew Jeffery | acb2029 | 2023-06-30 11:47:44 +0930 | [diff] [blame] | 913 | if (!stateEffecterPdrRepo) |
| 914 | { |
| 915 | error("Failed to instantiate state effecter PDR repository"); |
| 916 | return false; |
| 917 | } |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 918 | Repo stateEffecterPDRs(stateEffecterPdrRepo.get()); |
| 919 | getRepoByType(handler.getRepo(), stateEffecterPDRs, |
| 920 | PLDM_STATE_EFFECTER_PDR); |
| 921 | if (stateEffecterPDRs.empty()) |
| 922 | { |
Riya Dixit | 49cfb13 | 2023-03-02 04:26:53 -0600 | [diff] [blame] | 923 | error("Failed to get record by PDR type"); |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 924 | return false; |
| 925 | } |
| 926 | |
| 927 | PdrEntry pdrEntry{}; |
| 928 | auto pdrRecord = stateEffecterPDRs.getFirstRecord(pdrEntry); |
| 929 | while (pdrRecord) |
| 930 | { |
| 931 | pdr = reinterpret_cast<pldm_state_effecter_pdr*>(pdrEntry.data); |
| 932 | assert(pdr != NULL); |
| 933 | if (pdr->effecter_id != effecterId) |
| 934 | { |
| 935 | pdr = nullptr; |
| 936 | pdrRecord = stateEffecterPDRs.getNextRecord(pdrRecord, pdrEntry); |
| 937 | continue; |
| 938 | } |
| 939 | |
| 940 | auto tmpEntityType = pdr->entity_type; |
| 941 | auto tmpEntityInstance = pdr->entity_instance; |
| 942 | auto tmpPossibleStates = |
| 943 | reinterpret_cast<state_effecter_possible_states*>( |
| 944 | pdr->possible_states); |
| 945 | auto tmpStateSetId = tmpPossibleStates->state_set_id; |
| 946 | |
| 947 | if (compEffecterCnt > pdr->composite_effecter_count) |
| 948 | { |
Riya Dixit | 49cfb13 | 2023-03-02 04:26:53 -0600 | [diff] [blame] | 949 | error( |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 950 | "The requester sent wrong composite effecter count '{COMPOSITE_EFFECTER_COUNT}' for the effecter ID '{EFFECTERID}'.", |
Riya Dixit | 1e5c81e | 2024-05-03 07:54:00 -0500 | [diff] [blame] | 951 | "COMPOSITE_EFFECTER_COUNT", compEffecterCnt, "EFFECTERID", |
| 952 | effecterId); |
Sampa Misra | aea5dde | 2020-08-31 08:33:47 -0500 | [diff] [blame] | 953 | return false; |
| 954 | } |
| 955 | |
| 956 | if ((tmpEntityType >= PLDM_OEM_ENTITY_TYPE_START && |
| 957 | tmpEntityType <= PLDM_OEM_ENTITY_TYPE_END) || |
| 958 | (tmpStateSetId >= PLDM_OEM_STATE_SET_ID_START && |
| 959 | tmpStateSetId < PLDM_OEM_STATE_SET_ID_END)) |
| 960 | { |
| 961 | entityType = tmpEntityType; |
| 962 | entityInstance = tmpEntityInstance; |
| 963 | stateSetId = tmpStateSetId; |
| 964 | return true; |
| 965 | } |
| 966 | else |
| 967 | { |
| 968 | return false; |
| 969 | } |
| 970 | } |
| 971 | return false; |
| 972 | } |
| 973 | |
Sagar Srinivas | 90314a3 | 2023-10-17 10:38:03 -0500 | [diff] [blame] | 974 | void Handler::setEventReceiver() |
| 975 | { |
| 976 | std::vector<uint8_t> requestMsg(sizeof(pldm_msg_hdr) + |
| 977 | PLDM_SET_EVENT_RECEIVER_REQ_BYTES); |
| 978 | auto request = reinterpret_cast<pldm_msg*>(requestMsg.data()); |
| 979 | auto instanceId = instanceIdDb->next(eid); |
| 980 | uint8_t eventMessageGlobalEnable = |
| 981 | PLDM_EVENT_MESSAGE_GLOBAL_ENABLE_ASYNC_KEEP_ALIVE; |
| 982 | uint8_t transportProtocolType = PLDM_TRANSPORT_PROTOCOL_TYPE_MCTP; |
| 983 | uint8_t eventReceiverAddressInfo = pldm::responder::pdr::BmcMctpEid; |
| 984 | uint16_t heartbeatTimer = HEARTBEAT_TIMEOUT; |
| 985 | |
| 986 | auto rc = encode_set_event_receiver_req( |
| 987 | instanceId, eventMessageGlobalEnable, transportProtocolType, |
| 988 | eventReceiverAddressInfo, heartbeatTimer, request); |
| 989 | if (rc != PLDM_SUCCESS) |
| 990 | { |
| 991 | instanceIdDb->free(eid, instanceId); |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 992 | error( |
| 993 | "Failed to encode set event receiver request, response code '{RC}'", |
| 994 | "RC", lg2::hex, rc); |
Sagar Srinivas | 90314a3 | 2023-10-17 10:38:03 -0500 | [diff] [blame] | 995 | return; |
| 996 | } |
| 997 | |
| 998 | auto processSetEventReceiverResponse = |
| 999 | [](mctp_eid_t /*eid*/, const pldm_msg* response, size_t respMsgLen) { |
| 1000 | if (response == nullptr || !respMsgLen) |
| 1001 | { |
| 1002 | error("Failed to receive response for setEventReceiver command"); |
| 1003 | return; |
| 1004 | } |
| 1005 | |
| 1006 | uint8_t completionCode{}; |
| 1007 | auto rc = decode_set_event_receiver_resp(response, respMsgLen, |
| 1008 | &completionCode); |
| 1009 | if (rc || completionCode) |
| 1010 | { |
| 1011 | error( |
Riya Dixit | 8964444 | 2024-03-31 05:39:59 -0500 | [diff] [blame] | 1012 | "Failed to decode setEventReceiver command, response code '{RC}' and completion code '{CC}'", |
Riya Dixit | 1e5c81e | 2024-05-03 07:54:00 -0500 | [diff] [blame] | 1013 | "RC", rc, "CC", completionCode); |
Sagar Srinivas | 90314a3 | 2023-10-17 10:38:03 -0500 | [diff] [blame] | 1014 | pldm::utils::reportError( |
Manojkiran Eda | 92fb0b5 | 2024-04-17 10:48:17 +0530 | [diff] [blame] | 1015 | "xyz.openbmc_project.bmc.pldm.InternalFailure"); |
Sagar Srinivas | 90314a3 | 2023-10-17 10:38:03 -0500 | [diff] [blame] | 1016 | } |
| 1017 | }; |
| 1018 | rc = handler->registerRequest( |
| 1019 | eid, instanceId, PLDM_PLATFORM, PLDM_SET_EVENT_RECEIVER, |
| 1020 | std::move(requestMsg), std::move(processSetEventReceiverResponse)); |
| 1021 | |
| 1022 | if (rc != PLDM_SUCCESS) |
| 1023 | { |
| 1024 | error("Failed to send the setEventReceiver request"); |
| 1025 | } |
| 1026 | |
| 1027 | if (oemPlatformHandler) |
| 1028 | { |
| 1029 | oemPlatformHandler->countSetEventReceiver(); |
| 1030 | oemPlatformHandler->checkAndDisableWatchDog(); |
| 1031 | } |
| 1032 | } |
| 1033 | |
Deepak Kodihalli | bc669f1 | 2019-11-28 08:52:07 -0600 | [diff] [blame] | 1034 | } // namespace platform |
Deepak Kodihalli | 557dfb0 | 2019-05-12 13:11:17 +0530 | [diff] [blame] | 1035 | } // namespace responder |
| 1036 | } // namespace pldm |