blob: 23db1192b8c36185b5f4959bae3a54d7bde70db4 [file] [log] [blame]
Sampa Misra032bd502019-03-06 05:03:22 -06001#pragma once
2
Sampa Misraaea5dde2020-08-31 08:33:47 -05003#include "types.hpp"
4
George Liuc453e162022-12-21 17:16:23 +08005#include <libpldm/base.h>
6#include <libpldm/bios.h>
George Liudf9a6d32020-12-22 16:27:16 +08007#include <libpldm/entity.h>
8#include <libpldm/pdr.h>
George Liuc453e162022-12-21 17:16:23 +08009#include <libpldm/platform.h>
10#include <libpldm/utils.h>
Sampa Misra032bd502019-03-06 05:03:22 -060011#include <systemd/sd-bus.h>
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050012#include <unistd.h>
Sampa Misra032bd502019-03-06 05:03:22 -060013
George Liu6492f522020-06-16 10:34:05 +080014#include <nlohmann/json.hpp>
15#include <sdbusplus/server.hpp>
Riya Dixit754041d2024-02-20 06:15:49 -060016#include <xyz/openbmc_project/Inventory/Manager/client.hpp>
George Liu6492f522020-06-16 10:34:05 +080017#include <xyz/openbmc_project/Logging/Entry/server.hpp>
Gilbert Chen44524a52022-02-14 12:12:25 +000018#include <xyz/openbmc_project/ObjectMapper/client.hpp>
George Liu6492f522020-06-16 10:34:05 +080019
Pavithra Barithayab3b84b42024-08-23 11:43:57 +053020#include <cstdint>
George Liudf9a6d32020-12-22 16:27:16 +080021#include <deque>
Sampa Misraa2fa0702019-05-31 01:28:55 -050022#include <exception>
Deepak Kodihalli3cd61812020-03-10 06:38:45 -050023#include <filesystem>
Sampa Misraaa8ae722019-12-12 03:20:40 -060024#include <iostream>
George Liudf9a6d32020-12-22 16:27:16 +080025#include <map>
Sampa Misra032bd502019-03-06 05:03:22 -060026#include <string>
Sampa Misraa2fa0702019-05-31 01:28:55 -050027#include <variant>
28#include <vector>
Sampa Misra032bd502019-03-06 05:03:22 -060029
vkaverap@in.ibm.com5b71b862023-08-21 05:19:04 +000030constexpr uint64_t dbusTimeout =
31 std::chrono::duration_cast<std::chrono::microseconds>(
32 std::chrono::seconds(DBUS_TIMEOUT))
33 .count();
34
Sampa Misra032bd502019-03-06 05:03:22 -060035namespace pldm
36{
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050037namespace utils
38{
Thu Nguyena34a64b2022-03-31 08:56:39 +070039
Gilbert Chen77e6fe72024-08-06 09:23:30 +000040enum class Level
41{
42 WARNING,
43 CRITICAL,
44 PERFORMANCELOSS,
45 SOFTSHUTDOWN,
46 HARDSHUTDOWN,
47 ERROR
48};
49enum class Direction
50{
51 HIGH,
52 LOW,
53 ERROR
54};
55
Thu Nguyena34a64b2022-03-31 08:56:39 +070056const std::set<std::string_view> dbusValueTypeNames = {
57 "bool", "uint8_t", "int16_t", "uint16_t",
58 "int32_t", "uint32_t", "int64_t", "uint64_t",
59 "double", "string", "vector<uint8_t>", "vector<string>"};
60const std::set<std::string_view> dbusValueNumericTypeNames = {
61 "uint8_t", "int16_t", "uint16_t", "int32_t",
62 "uint32_t", "int64_t", "uint64_t", "double"};
63
Deepak Kodihalli3cd61812020-03-10 06:38:45 -050064namespace fs = std::filesystem;
Tom Joseph250c4752020-04-15 10:32:45 +053065using Json = nlohmann::json;
Tom Josephe5268cd2021-09-07 13:04:03 +053066constexpr bool Tx = true;
67constexpr bool Rx = false;
Gilbert Chen44524a52022-02-14 12:12:25 +000068using ObjectMapper = sdbusplus::client::xyz::openbmc_project::ObjectMapper<>;
Gilbert Chen44524a52022-02-14 12:12:25 +000069using inventoryManager =
70 sdbusplus::client::xyz::openbmc_project::inventory::Manager<>;
71
72constexpr auto dbusProperties = "org.freedesktop.DBus.Properties";
73constexpr auto mapperService = ObjectMapper::default_service;
74constexpr auto inventoryPath = "/xyz/openbmc_project/inventory";
Unive Tienc40d4a62025-03-12 11:36:07 +080075
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050076/** @struct CustomFD
77 *
78 * RAII wrapper for file descriptor.
79 */
80struct CustomFD
81{
82 CustomFD(const CustomFD&) = delete;
83 CustomFD& operator=(const CustomFD&) = delete;
84 CustomFD(CustomFD&&) = delete;
85 CustomFD& operator=(CustomFD&&) = delete;
86
Patrick Williams6da4f912023-05-10 07:50:53 -050087 CustomFD(int fd) : fd(fd) {}
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050088
89 ~CustomFD()
90 {
91 if (fd >= 0)
92 {
93 close(fd);
94 }
95 }
96
97 int operator()() const
98 {
99 return fd;
100 }
101
102 private:
103 int fd = -1;
104};
105
Sampa Misrab37be312019-07-03 02:26:41 -0500106/** @brief Calculate the pad for PLDM data
107 *
108 * @param[in] data - Length of the data
109 * @return - uint8_t - number of pad bytes
110 */
111uint8_t getNumPadBytes(uint32_t data);
112
George Liu83409572019-12-24 18:42:54 +0800113/** @brief Convert uint64 to date
114 *
115 * @param[in] data - time date of uint64
116 * @param[out] year - year number in dec
117 * @param[out] month - month number in dec
118 * @param[out] day - day of the month in dec
119 * @param[out] hour - number of hours in dec
120 * @param[out] min - number of minutes in dec
121 * @param[out] sec - number of seconds in dec
Manojkiran Eda2576aec2024-06-17 12:05:17 +0530122 * @return true if decode success, false if decode failed
George Liu83409572019-12-24 18:42:54 +0800123 */
124bool uintToDate(uint64_t data, uint16_t* year, uint8_t* month, uint8_t* day,
125 uint8_t* hour, uint8_t* min, uint8_t* sec);
126
127/** @brief Convert effecter data to structure of set_effecter_state_field
128 *
129 * @param[in] effecterData - the date of effecter
George Liuba4c1fb2020-02-05 14:13:30 +0800130 * @param[in] effecterCount - the number of individual sets of effecter
131 * information
132 * @return[out] parse success and get a valid set_effecter_state_field
133 * structure, return nullopt means parse failed
George Liu83409572019-12-24 18:42:54 +0800134 */
Patrick Williams16c2a0a2024-08-16 15:20:59 -0400135std::optional<std::vector<set_effecter_state_field>> parseEffecterData(
136 const std::vector<uint8_t>& effecterData, uint8_t effecterCount);
Sampa Misra032bd502019-03-06 05:03:22 -0600137
138/**
Sampa Misraaa8ae722019-12-12 03:20:40 -0600139 * @brief creates an error log
140 * @param[in] errorMsg - the error message
141 */
Manojkiran Eda92fb0b52024-04-17 10:48:17 +0530142void reportError(const char* errorMsg);
Sampa Misraaa8ae722019-12-12 03:20:40 -0600143
Sampa Misra032bd502019-03-06 05:03:22 -0600144/** @brief Convert any Decimal number to BCD
145 *
146 * @tparam[in] decimal - Decimal number
147 * @return Corresponding BCD number
148 */
149template <typename T>
150T decimalToBcd(T decimal)
151{
152 T bcd = 0;
153 T rem = 0;
154 auto cnt = 0;
155
156 while (decimal)
157 {
158 rem = decimal % 10;
159 bcd = bcd + (rem << cnt);
160 decimal = decimal / 10;
161 cnt += 4;
162 }
163
164 return bcd;
165}
166
George Liu1e44c732020-02-28 20:20:06 +0800167struct DBusMapping
168{
169 std::string objectPath; //!< D-Bus object path
170 std::string interface; //!< D-Bus interface
171 std::string propertyName; //!< D-Bus property name
172 std::string propertyType; //!< D-Bus property type
173};
174
175using PropertyValue =
176 std::variant<bool, uint8_t, int16_t, uint16_t, int32_t, uint32_t, int64_t,
Riya Dixit754041d2024-02-20 06:15:49 -0600177 uint64_t, double, std::string, std::vector<uint8_t>,
Unive Tienc40d4a62025-03-12 11:36:07 +0800178 std::vector<uint64_t>, std::vector<std::string>>;
Deepak Kodihalli6b1d1ca2020-04-27 07:24:51 -0500179using DbusProp = std::string;
180using DbusChangedProps = std::map<DbusProp, PropertyValue>;
Sampa Misraaea5dde2020-08-31 08:33:47 -0500181using DBusInterfaceAdded = std::vector<
182 std::pair<pldm::dbus::Interface,
183 std::vector<std::pair<pldm::dbus::Property,
184 std::variant<pldm::dbus::Property>>>>>;
Kamalkumar Patel7d427f12024-05-16 03:44:00 -0500185
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530186using ObjectPath = std::string;
Kamalkumar Patel7d427f12024-05-16 03:44:00 -0500187using EntityName = std::string;
188using Entities = std::vector<pldm_entity_node*>;
189using EntityAssociations = std::vector<Entities>;
190using ObjectPathMaps = std::map<fs::path, pldm_entity_node*>;
191using EntityMaps = std::map<pldm::pdr::EntityType, EntityName>;
192
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530193using ServiceName = std::string;
194using Interfaces = std::vector<std::string>;
195using MapperServiceMap = std::vector<std::pair<ServiceName, Interfaces>>;
196using GetSubTreeResponse = std::vector<std::pair<ObjectPath, MapperServiceMap>>;
Pavithra Barithaya2ec82692024-04-29 06:31:10 -0500197using GetSubTreePathsResponse = std::vector<std::string>;
Unive Tienc40d4a62025-03-12 11:36:07 +0800198using GetAssociatedSubTreeResponse =
199 std::map<std::string, std::map<std::string, std::vector<std::string>>>;
Delphine CC Chiu549e4bc2024-03-06 11:24:05 +0800200using GetAncestorsResponse =
201 std::vector<std::pair<ObjectPath, MapperServiceMap>>;
Sridevi Ramesheefe49b2022-06-27 11:51:02 -0500202using PropertyMap = std::map<std::string, PropertyValue>;
203using InterfaceMap = std::map<std::string, PropertyMap>;
Riya Dixit754041d2024-02-20 06:15:49 -0600204using ObjectValueTree = std::map<sdbusplus::message::object_path, InterfaceMap>;
George Liu1e44c732020-02-28 20:20:06 +0800205
Pavithra Barithaya36ac5592025-06-16 11:41:37 +0530206using SensorPDR = std::vector<uint8_t>;
207using SensorPDRs = std::vector<SensorPDR>;
Pavithra Barithayaa206b602025-08-21 14:37:13 +0530208using EffecterPDR = std::vector<uint8_t>;
209using EffecterPDRs = std::vector<EffecterPDR>;
Pavithra Barithaya36ac5592025-06-16 11:41:37 +0530210
George Liu1e44c732020-02-28 20:20:06 +0800211/**
212 * @brief The interface for DBusHandler
213 */
214class DBusHandlerInterface
215{
216 public:
217 virtual ~DBusHandlerInterface() = default;
218
George Liu36e81352020-07-01 14:40:30 +0800219 virtual std::string getService(const char* path,
220 const char* interface) const = 0;
Patrick Williams366507c2025-02-03 14:28:01 -0500221 virtual GetSubTreeResponse getSubtree(
222 const std::string& path, int depth,
223 const std::vector<std::string>& ifaceList) const = 0;
George Liu36e81352020-07-01 14:40:30 +0800224
Patrick Williams366507c2025-02-03 14:28:01 -0500225 virtual GetSubTreePathsResponse getSubTreePaths(
226 const std::string& objectPath, int depth,
227 const std::vector<std::string>& ifaceList) const = 0;
Pavithra Barithaya2ec82692024-04-29 06:31:10 -0500228
Delphine CC Chiu549e4bc2024-03-06 11:24:05 +0800229 virtual GetAncestorsResponse getAncestors(
230 const std::string& path,
231 const std::vector<std::string>& ifaceList) const = 0;
232
George Liu1e44c732020-02-28 20:20:06 +0800233 virtual void setDbusProperty(const DBusMapping& dBusMap,
234 const PropertyValue& value) const = 0;
John Wang9e242422020-03-05 08:37:50 +0800235
Patrick Williams366507c2025-02-03 14:28:01 -0500236 virtual PropertyValue getDbusPropertyVariant(
237 const char* objPath, const char* dbusProp,
238 const char* dbusInterface) const = 0;
Gilbert Chen44524a52022-02-14 12:12:25 +0000239
Patrick Williams366507c2025-02-03 14:28:01 -0500240 virtual PropertyMap getDbusPropertiesVariant(
241 const char* serviceName, const char* objPath,
242 const char* dbusInterface) const = 0;
Unive Tienc40d4a62025-03-12 11:36:07 +0800243
244 virtual GetAssociatedSubTreeResponse getAssociatedSubTree(
245 const sdbusplus::message::object_path& objectPath,
246 const sdbusplus::message::object_path& subtree, int depth,
247 const std::vector<std::string>& ifaceList) const = 0;
George Liu1e44c732020-02-28 20:20:06 +0800248};
249
Sampa Misraa2fa0702019-05-31 01:28:55 -0500250/**
251 * @class DBusHandler
252 *
253 * Wrapper class to handle the D-Bus calls
254 *
255 * This class contains the APIs to handle the D-Bus calls
256 * to cater the request from pldm requester.
257 * A class is created to mock the apis in the test cases
258 */
George Liu1e44c732020-02-28 20:20:06 +0800259class DBusHandler : public DBusHandlerInterface
Sampa Misraa2fa0702019-05-31 01:28:55 -0500260{
261 public:
George Liu0e02c322020-01-01 09:41:51 +0800262 /** @brief Get the bus connection. */
263 static auto& getBus()
264 {
265 static auto bus = sdbusplus::bus::new_default();
266 return bus;
267 }
268
269 /**
270 * @brief Get the DBUS Service name for the input dbus path
John Wang9e242422020-03-05 08:37:50 +0800271 *
George Liu0e02c322020-01-01 09:41:51 +0800272 * @param[in] path - DBUS object path
273 * @param[in] interface - DBUS Interface
John Wang9e242422020-03-05 08:37:50 +0800274 *
George Liu0e02c322020-01-01 09:41:51 +0800275 * @return std::string - the dbus service name
John Wang9e242422020-03-05 08:37:50 +0800276 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500277 * @throw sdbusplus::exception_t when it fails
George Liu0e02c322020-01-01 09:41:51 +0800278 */
George Liu36e81352020-07-01 14:40:30 +0800279 std::string getService(const char* path,
280 const char* interface) const override;
George Liu0e02c322020-01-01 09:41:51 +0800281
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530282 /**
283 * @brief Get the Subtree response from the mapper
284 *
285 * @param[in] path - DBUS object path
286 * @param[in] depth - Search depth
287 * @param[in] ifaceList - list of the interface that are being
288 * queried from the mapper
289 *
290 * @return GetSubTreeResponse - the mapper subtree response
291 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500292 * @throw sdbusplus::exception_t when it fails
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530293 */
Patrick Williams366507c2025-02-03 14:28:01 -0500294 GetSubTreeResponse getSubtree(
295 const std::string& path, int depth,
296 const std::vector<std::string>& ifaceList) const override;
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530297
Pavithra Barithaya2ec82692024-04-29 06:31:10 -0500298 /** @brief Get Subtree path response from the mapper
299 *
300 * @param[in] path - DBUS object path
301 * @param[in] depth - Search depth
302 * @param[in] ifaceList - list of the interface that are being
303 * queried from the mapper
304 *
305 * @return std::vector<std::string> vector of subtree paths
306 */
307 GetSubTreePathsResponse getSubTreePaths(
308 const std::string& objectPath, int depth,
309 const std::vector<std::string>& ifaceList) const override;
310
Delphine CC Chiu549e4bc2024-03-06 11:24:05 +0800311 /**
312 * @brief Get the Ancestors response from the mapper
313 *
314 * @param[in] path - D-Bus object path
315 * @param[in] ifaceList - an optional list of interfaces to constrain the
316 * search to queried from the mapper
317 *
318 * @return GetAncestorsResponse - the mapper GetAncestors response
319 *
320 * @throw sdbusplus::exception_t when it fails
321 */
322 GetAncestorsResponse getAncestors(
323 const std::string& path,
324 const std::vector<std::string>& ifaceList) const override;
325
John Wang9e242422020-03-05 08:37:50 +0800326 /** @brief Get property(type: variant) from the requested dbus
327 *
328 * @param[in] objPath - The Dbus object path
329 * @param[in] dbusProp - The property name to get
330 * @param[in] dbusInterface - The Dbus interface
331 *
332 * @return The value of the property(type: variant)
333 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500334 * @throw sdbusplus::exception_t when it fails
John Wang9e242422020-03-05 08:37:50 +0800335 */
Patrick Williams366507c2025-02-03 14:28:01 -0500336 PropertyValue getDbusPropertyVariant(
337 const char* objPath, const char* dbusProp,
338 const char* dbusInterface) const override;
George Liu0e02c322020-01-01 09:41:51 +0800339
Gilbert Chen44524a52022-02-14 12:12:25 +0000340 /** @brief Get All properties(type: variant) from the requested dbus
341 *
342 * @param[in] serviceName - The Dbus service name
343 * @param[in] objPath - The Dbus object path
344 * @param[in] dbusInterface - The Dbus interface
345 *
346 * @return The values of the properties(type: variant)
347 *
348 * @throw sdbusplus::exception_t when it fails
349 */
Patrick Williams366507c2025-02-03 14:28:01 -0500350 PropertyMap getDbusPropertiesVariant(
351 const char* serviceName, const char* objPath,
352 const char* dbusInterface) const override;
Gilbert Chen44524a52022-02-14 12:12:25 +0000353
John Wang9e242422020-03-05 08:37:50 +0800354 /** @brief The template function to get property from the requested dbus
355 * path
356 *
357 * @tparam Property - Excepted type of the property on dbus
358 *
359 * @param[in] objPath - The Dbus object path
360 * @param[in] dbusProp - The property name to get
361 * @param[in] dbusInterface - The Dbus interface
362 *
363 * @return The value of the property
364 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500365 * @throw sdbusplus::exception_t when dbus request fails
John Wang9e242422020-03-05 08:37:50 +0800366 * std::bad_variant_access when \p Property and property on dbus do
367 * not match
368 */
John Wang92b3c972019-10-17 11:06:41 +0800369 template <typename Property>
370 auto getDbusProperty(const char* objPath, const char* dbusProp,
371 const char* dbusInterface)
372 {
Patrick Williams16c2a0a2024-08-16 15:20:59 -0400373 auto VariantValue =
374 getDbusPropertyVariant(objPath, dbusProp, dbusInterface);
John Wang92b3c972019-10-17 11:06:41 +0800375 return std::get<Property>(VariantValue);
376 }
George Liu1e44c732020-02-28 20:20:06 +0800377
Unive Tienc40d4a62025-03-12 11:36:07 +0800378 /** @brief Get the associated subtree from the mapper
379 *
380 * @param[in] path - The D-Bus object path
381 *
382 * @param[in] interface - The D-Bus interface
383 *
384 * @return GetAssociatedSubtreeResponse - The associated subtree
385 */
386 GetAssociatedSubTreeResponse getAssociatedSubTree(
387 const sdbusplus::message::object_path& objectPath,
388 const sdbusplus::message::object_path& subtree, int depth,
389 const std::vector<std::string>& ifaceList) const override;
390
George Liu1e44c732020-02-28 20:20:06 +0800391 /** @brief Set Dbus property
392 *
393 * @param[in] dBusMap - Object path, property name, interface and property
394 * type for the D-Bus object
395 * @param[in] value - The value to be set
John Wang9e242422020-03-05 08:37:50 +0800396 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500397 * @throw sdbusplus::exception_t when it fails
George Liu1e44c732020-02-28 20:20:06 +0800398 */
399 void setDbusProperty(const DBusMapping& dBusMap,
400 const PropertyValue& value) const override;
Riya Dixit754041d2024-02-20 06:15:49 -0600401
402 /** @brief This function retrieves the properties of an object managed
403 * by the specified D-Bus service located at the given object path.
404 *
405 * @param[in] service - The D-Bus service providing the managed object
406 * @param[in] value - The object path of the managed object
407 *
408 * @return A hierarchical structure representing the properties of the
409 * managed object.
Patrick Williams897b0f82024-04-14 02:31:48 -0500410 * @throw sdbusplus::exception_t when it fails
Riya Dixit754041d2024-02-20 06:15:49 -0600411 */
412 static ObjectValueTree getManagedObj(const char* service, const char* path);
413
414 /** @brief Retrieve the inventory objects managed by a specified class.
415 * The retrieved inventory objects are cached statically
416 * and returned upon subsequent calls to this function.
417 *
418 * @tparam ClassType - The class type that manages the inventory objects.
419 *
420 * @return A reference to the cached inventory objects.
421 */
422 template <typename ClassType>
423 static auto& getInventoryObjects()
424 {
425 static ObjectValueTree object = ClassType::getManagedObj(
426 inventoryManager::interface, inventoryPath);
427 return object;
428 }
Sampa Misraa2fa0702019-05-31 01:28:55 -0500429};
430
Deepak Kodihalli3cd61812020-03-10 06:38:45 -0500431/** @brief Fetch parent D-Bus object based on pathname
432 *
433 * @param[in] dbusObj - child D-Bus object
434 *
435 * @return std::string - the parent D-Bus object path
436 */
437inline std::string findParent(const std::string& dbusObj)
438{
439 fs::path p(dbusObj);
440 return p.parent_path().string();
441}
442
Pavithra Barithaya51efaf82020-04-02 02:42:27 -0500443/** @brief Read (static) MCTP EID of host firmware from a file
444 *
445 * @return uint8_t - MCTP EID
446 */
447uint8_t readHostEID();
Tom Joseph250c4752020-04-15 10:32:45 +0530448
Gilbert Chen6c7fed42022-02-22 15:40:17 +0000449/** @brief Validate the MCTP EID of MCTP endpoint
450 * In `Table 2 - Special endpoint IDs` of DSP0236. EID 0 is NULL_EID.
451 * EID from 1 to 7 is reserved EID. EID 0xFF is broadcast EID.
452 * Those are invalid EID of one MCTP Endpoint.
453 *
454 * @param[in] eid - MCTP EID
455 *
456 * @return true if the MCTP EID is valid otherwise return false.
457 */
458bool isValidEID(eid mctpEid);
459
TOM JOSEPHd4d97a52020-03-23 14:36:34 +0530460/** @brief Convert a value in the JSON to a D-Bus property value
461 *
462 * @param[in] type - type of the D-Bus property
463 * @param[in] value - value in the JSON file
464 *
465 * @return PropertyValue - the D-Bus property value
466 */
467PropertyValue jsonEntryToDbusVal(std::string_view type,
468 const nlohmann::json& value);
Pavithra Barithaya51efaf82020-04-02 02:42:27 -0500469
Pavithra Barithaya0f74c982020-04-27 02:17:10 -0500470/** @brief Find State Effecter PDR
471 * @param[in] tid - PLDM terminus ID.
472 * @param[in] entityID - entity that can be associated with PLDM State set.
473 * @param[in] stateSetId - value that identifies PLDM State set.
474 * @param[in] repo - pointer to BMC's primary PDR repo.
475 * @return array[array[uint8_t]] - StateEffecterPDRs
476 */
Patrick Williams16c2a0a2024-08-16 15:20:59 -0400477std::vector<std::vector<uint8_t>> findStateEffecterPDR(
478 uint8_t tid, uint16_t entityID, uint16_t stateSetId, const pldm_pdr* repo);
Chicago Duan738e4d82020-05-28 16:39:19 +0800479/** @brief Find State Sensor PDR
480 * @param[in] tid - PLDM terminus ID.
481 * @param[in] entityID - entity that can be associated with PLDM State set.
482 * @param[in] stateSetId - value that identifies PLDM State set.
483 * @param[in] repo - pointer to BMC's primary PDR repo.
484 * @return array[array[uint8_t]] - StateSensorPDRs
485 */
Patrick Williams16c2a0a2024-08-16 15:20:59 -0400486std::vector<std::vector<uint8_t>> findStateSensorPDR(
487 uint8_t tid, uint16_t entityID, uint16_t stateSetId, const pldm_pdr* repo);
Pavithra Barithaya0f74c982020-04-27 02:17:10 -0500488
Sampa Misra3a0e3b92020-10-21 05:58:00 -0500489/** @brief Find sensor id from a state sensor PDR
490 *
491 * @param[in] pdrRepo - PDR repository
492 * @param[in] tid - terminus id
493 * @param[in] entityType - entity type
494 * @param[in] entityInstance - entity instance number
495 * @param[in] containerId - container id
496 * @param[in] stateSetId - state set id
497 *
498 * @return uint16_t - the sensor id
499 */
500uint16_t findStateSensorId(const pldm_pdr* pdrRepo, uint8_t tid,
501 uint16_t entityType, uint16_t entityInstance,
502 uint16_t containerId, uint16_t stateSetId);
503
Tom Joseph250c4752020-04-15 10:32:45 +0530504/** @brief Find effecter id from a state effecter pdr
505 * @param[in] pdrRepo - PDR repository
506 * @param[in] entityType - entity type
507 * @param[in] entityInstance - entity instance number
508 * @param[in] containerId - container id
509 * @param[in] stateSetId - state set id
Sampa Misraa4a96162020-07-14 05:33:46 -0500510 * @param[in] localOrRemote - true for checking local repo and false for remote
511 * repo
Tom Joseph250c4752020-04-15 10:32:45 +0530512 *
513 * @return uint16_t - the effecter id
514 */
515uint16_t findStateEffecterId(const pldm_pdr* pdrRepo, uint16_t entityType,
516 uint16_t entityInstance, uint16_t containerId,
Sampa Misraa4a96162020-07-14 05:33:46 -0500517 uint16_t stateSetId, bool localOrRemote);
Tom Joseph250c4752020-04-15 10:32:45 +0530518
Pavithra Barithaya36ac5592025-06-16 11:41:37 +0530519/** @brief Method to find all state sensor PDRs by type
520 *
521 * @param[in] entityType - the entity type
522 * @param[in] repo - opaque pointer acting as a PDR repo handle
523 *
524 * @return vector of vector of all state sensor PDRs
525 */
526SensorPDRs getStateSensorPDRsByType(uint16_t entityType, const pldm_pdr* repo);
527
528/** @brief method to find sensor IDs based on the pldm_entity
529 *
530 * @param[in] pdrRepo - opaque pointer acting as a PDR repo handle
531 * @param[in] entityType - the entity type
532 * @param[in] entityInstance - the entity instance number
533 * @param[in] containerId - the container ID
534 *
535 * @return vector of all sensor IDs
536 */
537std::vector<pldm::pdr::SensorID> findSensorIds(
538 const pldm_pdr* pdrRepo, uint16_t entityType, uint16_t entityInstance,
539 uint16_t containerId);
540
Pavithra Barithayaa206b602025-08-21 14:37:13 +0530541/** @brief Method to find all state effecter PDRs by type
542 *
543 * @param[in] entityType - the entity type
544 * @param[in] repo - opaque pointer acting as a PDR repo handle
545 *
546 * @return vector of vector of all state effecter PDRs
547 */
548EffecterPDRs getStateEffecterPDRsByType(uint16_t entityType,
549 const pldm_pdr* repo);
550
551/** @brief method to find effecter IDs based on the pldm_entity
552 *
553 * @param[in] pdrRepo - opaque pointer acting as a PDR repo handle
554 * @param[in] entityType - the entity type
555 * @param[in] entityInstance - the entity instance number
556 * @param[in] containerId - the container ID
557 *
558 * @return vector of all effecter IDs
559 */
560std::vector<pldm::pdr::EffecterID> findEffecterIds(
561 const pldm_pdr* pdrRepo, uint16_t entityType, uint16_t entityInstance,
562 uint16_t containerId);
563
Chicago Duanfe4d88b2020-06-12 16:44:13 +0800564/** @brief Emit the sensor event signal
565 *
566 * @param[in] tid - the terminus id
567 * @param[in] sensorId - sensorID value of the sensor
568 * @param[in] sensorOffset - Identifies which state sensor within a
569 * composite state sensor the event is being returned for
570 * @param[in] eventState - The event state value from the state change that
571 * triggered the event message
572 * @param[in] previousEventState - The event state value for the state from
573 * which the present event state was entered.
574 * @return PLDM completion code
575 */
576int emitStateSensorEventSignal(uint8_t tid, uint16_t sensorId,
577 uint8_t sensorOffset, uint8_t eventState,
578 uint8_t previousEventState);
579
Chau Ly8fa40db2024-04-02 09:32:01 +0000580/**
581 * @brief call Recover() method to recover an MCTP Endpoint
582 * @param[in] MCTP Endpoint's object path
583 */
584void recoverMctpEndpoint(const std::string& endpointObjPath);
585
Sridevi Rameshae28bc72020-12-10 07:21:16 -0600586/** @brief Print the buffer
587 *
Tom Josephe5268cd2021-09-07 13:04:03 +0530588 * @param[in] isTx - True if the buffer is an outgoing PLDM message, false if
589 the buffer is an incoming PLDM message
590 * @param[in] buffer - Buffer to print
Sridevi Rameshae28bc72020-12-10 07:21:16 -0600591 *
592 * @return - None
593 */
Tom Josephe5268cd2021-09-07 13:04:03 +0530594void printBuffer(bool isTx, const std::vector<uint8_t>& buffer);
Sridevi Rameshae28bc72020-12-10 07:21:16 -0600595
Tom Joseph54922072021-06-19 02:45:46 -0700596/** @brief Convert the buffer to std::string
597 *
598 * If there are characters that are not printable characters, it is replaced
599 * with space(0x20).
600 *
601 * @param[in] var - pointer to data and length of the data
602 *
603 * @return std::string equivalent of variable field
604 */
605std::string toString(const struct variable_field& var);
606
George Liu872f0f62021-11-25 16:26:16 +0800607/** @brief Split strings according to special identifiers
608 *
609 * We can split the string according to the custom identifier(';', ',', '&' or
610 * others) and store it to vector.
611 *
612 * @param[in] srcStr - The string to be split
613 * @param[in] delim - The custom identifier
614 * @param[in] trimStr - The first and last string to be trimmed
615 *
616 * @return std::vector<std::string> Vectors are used to store strings
617 */
618std::vector<std::string> split(std::string_view srcStr, std::string_view delim,
619 std::string_view trimStr = "");
Manojkiran Edaef773052021-07-29 09:29:28 +0530620/** @brief Get the current system time in readable format
621 *
622 * @return - std::string equivalent of the system time
623 */
624std::string getCurrentSystemTime();
George Liu872f0f62021-11-25 16:26:16 +0800625
Sridevi Ramesheefe49b2022-06-27 11:51:02 -0500626/** @brief checks if the FRU is actually present.
627 * @param[in] objPath - FRU object path.
628 *
629 * @return bool to indicate presence or absence of FRU.
630 */
631bool checkForFruPresence(const std::string& objPath);
632
Sagar Srinivas5db6e872023-12-01 10:03:30 -0600633/** @brief Method to check if the logical bit is set
634 *
635 * @param[containerId] - container id of the entity
636 *
637 * @return true or false based on the logic bit set
638 */
639bool checkIfLogicalBitSet(const uint16_t& containerId);
Pavithra Barithaya5e542be2021-08-13 00:33:31 -0500640
641/** @brief setting the present property
642 *
643 * @param[in] objPath - the object path of the fru
644 * @param[in] present - status to set either true/false
645 */
646void setFruPresence(const std::string& fruObjPath, bool present);
Thu Nguyenb8cf46b2024-06-15 02:44:35 +0000647
648/** @brief Trim `\0` in string and replace ` ` by `_` to use name in D-Bus
649 * object path
650 *
651 * @param[in] name - the input string
652 *
653 * @return the result string
654 */
655std::string_view trimNameForDbus(std::string& name);
656
Thu Nguyena34a64b2022-03-31 08:56:39 +0700657/** @brief Convert the number type D-Bus Value to the double
658 *
659 * @param[in] type - string type should in dbusValueNumericTypeNames list
660 * @param[in] value - DBus PropertyValue variant
661 * @param[out] doubleValue - response value
662 *
663 * @return true if data type is corrected and converting is successful
664 * otherwise return false.
665 */
666bool dbusPropValuesToDouble(const std::string_view& type,
667 const pldm::utils::PropertyValue& value,
668 double* doubleValue);
669
Dung Caob6d39432024-06-05 03:46:47 +0000670/** @brief Convert the Fru String bytes from PLDM Fru to std::string
671 *
672 * @param[in] value - the Fru String bytes
673 * @param[in] length - Number of bytes
674 *
675 * @return Fru string or nullopt.
676 */
Patrick Williams366507c2025-02-03 14:28:01 -0500677std::optional<std::string> fruFieldValuestring(const uint8_t* value,
678 const uint8_t& length);
Dung Caob6d39432024-06-05 03:46:47 +0000679
680/** @brief Convert the Fru Uint32 raw data from PLDM Fru to uint32_t
681 *
682 * @param[in] value - the Fru uint32 raw data
683 * @param[in] length - Number of bytes
684 *
685 * @return Fru uint32_t or nullopt.
686 */
687std::optional<uint32_t> fruFieldParserU32(const uint8_t* value,
688 const uint8_t& length);
689
George Liu83409572019-12-24 18:42:54 +0800690} // namespace utils
Sampa Misra032bd502019-03-06 05:03:22 -0600691} // namespace pldm