1 #pragma once 2 3 #include "libpldm/platform.h" 4 5 #include "common/types.hpp" 6 #include "numeric_sensor.hpp" 7 #include "requester/handler.hpp" 8 #include "terminus.hpp" 9 10 #include <sdbusplus/server/object.hpp> 11 #include <sdeventplus/event.hpp> 12 #include <xyz/openbmc_project/Inventory/Item/Board/server.hpp> 13 14 #include <algorithm> 15 #include <bitset> 16 #include <string> 17 #include <tuple> 18 #include <utility> 19 #include <vector> 20 21 namespace pldm 22 { 23 namespace platform_mc 24 { 25 26 using ContainerID = uint16_t; 27 using EntityInstanceNumber = uint16_t; 28 using EntityName = std::string; 29 using EntityType = uint16_t; 30 using SensorId = uint16_t; 31 using SensorCnt = uint8_t; 32 using NameLanguageTag = std::string; 33 using SensorName = std::string; 34 using SensorAuxiliaryNames = std::tuple< 35 SensorId, SensorCnt, 36 std::vector<std::vector<std::pair<NameLanguageTag, SensorName>>>>; 37 using InventoryItemBoardIntf = sdbusplus::server::object_t< 38 sdbusplus::xyz::openbmc_project::Inventory::Item::server::Board>; 39 40 /** @struct EntityKey 41 * 42 * EntityKey uniquely identifies the PLDM entity and a combination of Entity 43 * Type, Entity Instance Number, Entity Container ID 44 * 45 */ 46 struct EntityKey 47 { 48 EntityType type; //!< Entity type 49 EntityInstanceNumber instanceIdx; //!< Entity instance number 50 ContainerID containerId; //!< Entity container ID 51 52 bool operator==(const EntityKey& e) const 53 { 54 return ((type == e.type) && (instanceIdx == e.instanceIdx) && 55 (containerId == e.containerId)); 56 } 57 }; 58 59 using AuxiliaryNames = std::vector<std::pair<NameLanguageTag, std::string>>; 60 using EntityKey = struct EntityKey; 61 using EntityAuxiliaryNames = std::tuple<EntityKey, AuxiliaryNames>; 62 63 /** 64 * @brief Terminus 65 * 66 * Terminus class holds the TID, supported PLDM Type or PDRs which are needed by 67 * other manager class for sensor monitoring and control. 68 */ 69 class Terminus 70 { 71 public: 72 Terminus(pldm_tid_t tid, uint64_t supportedPLDMTypes); 73 74 /** @brief Check if the terminus supports the PLDM type message 75 * 76 * @param[in] type - PLDM Type 77 * @return support state - True if support, otherwise False 78 */ 79 bool doesSupportType(uint8_t type); 80 81 /** @brief Check if the terminus supports the PLDM command message 82 * 83 * @param[in] type - PLDM Type 84 * @param[in] command - PLDM command 85 * @return support state - True if support, otherwise False 86 */ 87 bool doesSupportCommand(uint8_t type, uint8_t command); 88 89 /** @brief Set the supported PLDM commands for terminus 90 * 91 * @param[in] cmds - bit mask of the supported PLDM commands 92 * @return success state - True if success, otherwise False 93 */ 94 bool setSupportedCommands(const std::vector<uint8_t>& cmds) 95 { 96 const size_t expectedSize = PLDM_MAX_TYPES * 97 (PLDM_MAX_CMDS_PER_TYPE / 8); 98 if (cmds.empty() || cmds.size() != expectedSize) 99 { 100 lg2::error( 101 "setSupportedCommands received invalid bit mask size. Expected: {EXPECTED}, Received: {RECEIVED}", 102 "EXPECTED", expectedSize, "RECEIVED", cmds.size()); 103 return false; 104 } 105 106 /* Assign Vector supportedCmds by Vector cmds */ 107 supportedCmds.resize(cmds.size()); 108 std::copy(cmds.begin(), cmds.begin() + cmds.size(), 109 supportedCmds.begin()); 110 111 return true; 112 } 113 114 /** @brief Parse the PDRs stored in the member variable, pdrs. 115 */ 116 void parseTerminusPDRs(); 117 118 /** @brief The getter to return terminus's TID */ 119 pldm_tid_t getTid() 120 { 121 return tid; 122 } 123 124 /** @brief The getter to get terminus's mctp medium */ 125 std::string_view getTerminusName() 126 { 127 return terminusName; 128 } 129 130 /** @brief A list of PDRs fetched from Terminus */ 131 std::vector<std::vector<uint8_t>> pdrs{}; 132 133 /** @brief A flag to indicate if terminus has been initialized */ 134 bool initialized = false; 135 136 /** @brief A list of numericSensors */ 137 std::vector<std::shared_ptr<NumericSensor>> numericSensors{}; 138 139 /** @brief Get Sensor Auxiliary Names by sensorID 140 * 141 * @param[in] id - sensor ID 142 * @return sensor auxiliary names 143 */ 144 std::shared_ptr<SensorAuxiliaryNames> getSensorAuxiliaryNames(SensorId id); 145 146 private: 147 /** @brief Find the Terminus Name from the Entity Auxiliary name list 148 * The Entity Auxiliary name list is entityAuxiliaryNamesTbl. 149 * @return terminus name in string option 150 */ 151 std::optional<std::string_view> findTerminusName(); 152 153 /** @brief Construct the NumericSensor sensor class for the PLDM sensor. 154 * The NumericSensor class will handle create D-Bus object path, 155 * provide the APIs to update sensor value, threshold... 156 * 157 * @param[in] pdr - the numeric sensor PDR info 158 */ 159 void addNumericSensor( 160 const std::shared_ptr<pldm_numeric_sensor_value_pdr> pdr); 161 162 /** @brief Parse the numeric sensor PDRs 163 * 164 * @param[in] pdrData - the response PDRs from GetPDR command 165 * @return pointer to numeric sensor info struct 166 */ 167 std::shared_ptr<pldm_numeric_sensor_value_pdr> 168 parseNumericSensorPDR(const std::vector<uint8_t>& pdrData); 169 170 /** @brief Parse the sensor Auxiliary name PDRs 171 * 172 * @param[in] pdrData - the response PDRs from GetPDR command 173 * @return pointer to sensor Auxiliary name info struct 174 */ 175 std::shared_ptr<SensorAuxiliaryNames> 176 parseSensorAuxiliaryNamesPDR(const std::vector<uint8_t>& pdrData); 177 178 /** @brief Parse the Entity Auxiliary name PDRs 179 * 180 * @param[in] pdrData - the response PDRs from GetPDR command 181 * @return pointer to Entity Auxiliary name info struct 182 */ 183 std::shared_ptr<EntityAuxiliaryNames> 184 parseEntityAuxiliaryNamesPDR(const std::vector<uint8_t>& pdrData); 185 186 /** @brief Construct the NumericSensor sensor class for the compact numeric 187 * PLDM sensor. 188 * 189 * @param[in] pdr - the compact numeric sensor PDR info 190 */ 191 void addCompactNumericSensor( 192 const std::shared_ptr<pldm_compact_numeric_sensor_pdr> pdr); 193 194 /** @brief Parse the compact numeric sensor PDRs 195 * 196 * @param[in] pdrData - the response PDRs from GetPDR command 197 * @return pointer to compact numeric sensor info struct 198 */ 199 std::shared_ptr<pldm_compact_numeric_sensor_pdr> 200 parseCompactNumericSensorPDR(const std::vector<uint8_t>& pdrData); 201 202 /** @brief Parse the sensor Auxiliary name from compact numeric sensor PDRs 203 * 204 * @param[in] pdrData - the response PDRs from GetPDR command 205 * @return pointer to sensor Auxiliary name info struct 206 */ 207 std::shared_ptr<SensorAuxiliaryNames> 208 parseCompactNumericSensorNames(const std::vector<uint8_t>& pdrData); 209 210 /** @brief Create the terminus inventory path to 211 * /xyz/openbmc_project/inventory/Item/Board/. 212 * 213 * @param[in] tName - the terminus name 214 * @return true/false: True if there is no error in creating inventory path 215 * 216 */ 217 bool createInventoryPath(std::string tName); 218 219 /* @brief The terminus's TID */ 220 pldm_tid_t tid; 221 222 /* @brief The supported PLDM command types of the terminus */ 223 std::bitset<64> supportedTypes; 224 225 /** @brief Store supported PLDM commands of a terminus 226 * Maximum number of PLDM Type is PLDM_MAX_TYPES 227 * Maximum number of PLDM command for each type is 228 * PLDM_MAX_CMDS_PER_TYPE. 229 * Each uint8_t can store the supported state of 8 PLDM commands. 230 * Size of supportedCmds will be 231 * PLDM_MAX_TYPES * (PLDM_MAX_CMDS_PER_TYPE / 8). 232 */ 233 std::vector<uint8_t> supportedCmds; 234 235 /* @brief Sensor Auxiliary Name list */ 236 std::vector<std::shared_ptr<SensorAuxiliaryNames>> 237 sensorAuxiliaryNamesTbl{}; 238 239 /* @brief Entity Auxiliary Name list */ 240 std::vector<std::shared_ptr<EntityAuxiliaryNames>> 241 entityAuxiliaryNamesTbl{}; 242 243 /** @brief Terminus name */ 244 EntityName terminusName{}; 245 /* @brief The pointer of iventory D-Bus interface for the terminus */ 246 std::unique_ptr<InventoryItemBoardIntf> inventoryItemBoardInft = nullptr; 247 248 /* @brief Inventory D-Bus object path of the terminus */ 249 std::string inventoryPath; 250 }; 251 } // namespace platform_mc 252 } // namespace pldm 253