blob: bccd929e82058b828acac7fd08d9148e83592340 [file] [log] [blame]
Sampa Misra032bd502019-03-06 05:03:22 -06001#pragma once
2
Eric Yang70262ed2025-07-02 06:35:03 +00003#include "instance_id.hpp"
Sampa Misraaea5dde2020-08-31 08:33:47 -05004#include "types.hpp"
5
George Liuc453e162022-12-21 17:16:23 +08006#include <libpldm/base.h>
7#include <libpldm/bios.h>
George Liudf9a6d32020-12-22 16:27:16 +08008#include <libpldm/entity.h>
9#include <libpldm/pdr.h>
George Liuc453e162022-12-21 17:16:23 +080010#include <libpldm/platform.h>
11#include <libpldm/utils.h>
Sampa Misra032bd502019-03-06 05:03:22 -060012#include <systemd/sd-bus.h>
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050013#include <unistd.h>
Sampa Misra032bd502019-03-06 05:03:22 -060014
George Liu6492f522020-06-16 10:34:05 +080015#include <nlohmann/json.hpp>
16#include <sdbusplus/server.hpp>
Riya Dixit754041d2024-02-20 06:15:49 -060017#include <xyz/openbmc_project/Inventory/Manager/client.hpp>
George Liu6492f522020-06-16 10:34:05 +080018#include <xyz/openbmc_project/Logging/Entry/server.hpp>
Gilbert Chen44524a52022-02-14 12:12:25 +000019#include <xyz/openbmc_project/ObjectMapper/client.hpp>
George Liu6492f522020-06-16 10:34:05 +080020
Pavithra Barithayab3b84b42024-08-23 11:43:57 +053021#include <cstdint>
George Liudf9a6d32020-12-22 16:27:16 +080022#include <deque>
Sampa Misraa2fa0702019-05-31 01:28:55 -050023#include <exception>
Eric Yang70262ed2025-07-02 06:35:03 +000024#include <expected>
Deepak Kodihalli3cd61812020-03-10 06:38:45 -050025#include <filesystem>
Sampa Misraaa8ae722019-12-12 03:20:40 -060026#include <iostream>
George Liudf9a6d32020-12-22 16:27:16 +080027#include <map>
Sampa Misra032bd502019-03-06 05:03:22 -060028#include <string>
Sampa Misraa2fa0702019-05-31 01:28:55 -050029#include <variant>
30#include <vector>
Sampa Misra032bd502019-03-06 05:03:22 -060031
vkaverap@in.ibm.com5b71b862023-08-21 05:19:04 +000032constexpr uint64_t dbusTimeout =
33 std::chrono::duration_cast<std::chrono::microseconds>(
34 std::chrono::seconds(DBUS_TIMEOUT))
35 .count();
36
Sampa Misra032bd502019-03-06 05:03:22 -060037namespace pldm
38{
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050039namespace utils
40{
Thu Nguyena34a64b2022-03-31 08:56:39 +070041
Gilbert Chen77e6fe72024-08-06 09:23:30 +000042enum class Level
43{
44 WARNING,
45 CRITICAL,
46 PERFORMANCELOSS,
47 SOFTSHUTDOWN,
48 HARDSHUTDOWN,
49 ERROR
50};
51enum class Direction
52{
53 HIGH,
54 LOW,
55 ERROR
56};
57
Thu Nguyena34a64b2022-03-31 08:56:39 +070058const std::set<std::string_view> dbusValueTypeNames = {
59 "bool", "uint8_t", "int16_t", "uint16_t",
60 "int32_t", "uint32_t", "int64_t", "uint64_t",
61 "double", "string", "vector<uint8_t>", "vector<string>"};
62const std::set<std::string_view> dbusValueNumericTypeNames = {
63 "uint8_t", "int16_t", "uint16_t", "int32_t",
64 "uint32_t", "int64_t", "uint64_t", "double"};
65
Deepak Kodihalli3cd61812020-03-10 06:38:45 -050066namespace fs = std::filesystem;
Tom Joseph250c4752020-04-15 10:32:45 +053067using Json = nlohmann::json;
Tom Josephe5268cd2021-09-07 13:04:03 +053068constexpr bool Tx = true;
69constexpr bool Rx = false;
Gilbert Chen44524a52022-02-14 12:12:25 +000070using ObjectMapper = sdbusplus::client::xyz::openbmc_project::ObjectMapper<>;
Gilbert Chen44524a52022-02-14 12:12:25 +000071using inventoryManager =
72 sdbusplus::client::xyz::openbmc_project::inventory::Manager<>;
73
74constexpr auto dbusProperties = "org.freedesktop.DBus.Properties";
75constexpr auto mapperService = ObjectMapper::default_service;
76constexpr auto inventoryPath = "/xyz/openbmc_project/inventory";
Unive Tienc40d4a62025-03-12 11:36:07 +080077
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050078/** @struct CustomFD
79 *
80 * RAII wrapper for file descriptor.
81 */
82struct CustomFD
83{
84 CustomFD(const CustomFD&) = delete;
85 CustomFD& operator=(const CustomFD&) = delete;
86 CustomFD(CustomFD&&) = delete;
87 CustomFD& operator=(CustomFD&&) = delete;
88
Patrick Williams6da4f912023-05-10 07:50:53 -050089 CustomFD(int fd) : fd(fd) {}
Jinu Joy Thomasf666db12019-05-29 05:22:31 -050090
91 ~CustomFD()
92 {
93 if (fd >= 0)
94 {
95 close(fd);
96 }
97 }
98
99 int operator()() const
100 {
101 return fd;
102 }
103
104 private:
105 int fd = -1;
106};
107
Sampa Misrab37be312019-07-03 02:26:41 -0500108/** @brief Calculate the pad for PLDM data
109 *
110 * @param[in] data - Length of the data
111 * @return - uint8_t - number of pad bytes
112 */
113uint8_t getNumPadBytes(uint32_t data);
114
George Liu83409572019-12-24 18:42:54 +0800115/** @brief Convert uint64 to date
116 *
117 * @param[in] data - time date of uint64
118 * @param[out] year - year number in dec
119 * @param[out] month - month number in dec
120 * @param[out] day - day of the month in dec
121 * @param[out] hour - number of hours in dec
122 * @param[out] min - number of minutes in dec
123 * @param[out] sec - number of seconds in dec
Manojkiran Eda2576aec2024-06-17 12:05:17 +0530124 * @return true if decode success, false if decode failed
George Liu83409572019-12-24 18:42:54 +0800125 */
126bool uintToDate(uint64_t data, uint16_t* year, uint8_t* month, uint8_t* day,
127 uint8_t* hour, uint8_t* min, uint8_t* sec);
128
129/** @brief Convert effecter data to structure of set_effecter_state_field
130 *
131 * @param[in] effecterData - the date of effecter
George Liuba4c1fb2020-02-05 14:13:30 +0800132 * @param[in] effecterCount - the number of individual sets of effecter
133 * information
134 * @return[out] parse success and get a valid set_effecter_state_field
135 * structure, return nullopt means parse failed
George Liu83409572019-12-24 18:42:54 +0800136 */
Patrick Williams16c2a0a2024-08-16 15:20:59 -0400137std::optional<std::vector<set_effecter_state_field>> parseEffecterData(
138 const std::vector<uint8_t>& effecterData, uint8_t effecterCount);
Sampa Misra032bd502019-03-06 05:03:22 -0600139
140/**
Sampa Misraaa8ae722019-12-12 03:20:40 -0600141 * @brief creates an error log
142 * @param[in] errorMsg - the error message
143 */
Manojkiran Eda92fb0b52024-04-17 10:48:17 +0530144void reportError(const char* errorMsg);
Sampa Misraaa8ae722019-12-12 03:20:40 -0600145
Sampa Misra032bd502019-03-06 05:03:22 -0600146/** @brief Convert any Decimal number to BCD
147 *
148 * @tparam[in] decimal - Decimal number
149 * @return Corresponding BCD number
150 */
151template <typename T>
152T decimalToBcd(T decimal)
153{
154 T bcd = 0;
155 T rem = 0;
156 auto cnt = 0;
157
158 while (decimal)
159 {
160 rem = decimal % 10;
161 bcd = bcd + (rem << cnt);
162 decimal = decimal / 10;
163 cnt += 4;
164 }
165
166 return bcd;
167}
168
Eric Yang70262ed2025-07-02 06:35:03 +0000169/**
170 * @brief Unwraps the result of InstanceId allocation and logs errors.
171 *
172 * Logs errors if present, but always returns the original result so the caller
173 * can choose to handle the error (return, throw, etc).
174 *
175 * @tparam T Instance ID value type.
176 * @param[in] result The result from InstanceIdDb::next().
177 * @return std::expected<T, InstanceIdError>
178 * Returns the original result (value or error).
179 */
180template <typename T>
181std::expected<T, pldm::InstanceIdError> getInstanceId(
182 const std::expected<T, pldm::InstanceIdError>& result)
183{
184 if (!result)
185 {
186 std::cerr << result.error().msg() << std::endl;
187 }
188 return result;
189}
190
George Liu1e44c732020-02-28 20:20:06 +0800191struct DBusMapping
192{
193 std::string objectPath; //!< D-Bus object path
194 std::string interface; //!< D-Bus interface
195 std::string propertyName; //!< D-Bus property name
196 std::string propertyType; //!< D-Bus property type
197};
198
199using PropertyValue =
200 std::variant<bool, uint8_t, int16_t, uint16_t, int32_t, uint32_t, int64_t,
Riya Dixit754041d2024-02-20 06:15:49 -0600201 uint64_t, double, std::string, std::vector<uint8_t>,
Unive Tienc40d4a62025-03-12 11:36:07 +0800202 std::vector<uint64_t>, std::vector<std::string>>;
Deepak Kodihalli6b1d1ca2020-04-27 07:24:51 -0500203using DbusProp = std::string;
204using DbusChangedProps = std::map<DbusProp, PropertyValue>;
Sampa Misraaea5dde2020-08-31 08:33:47 -0500205using DBusInterfaceAdded = std::vector<
206 std::pair<pldm::dbus::Interface,
207 std::vector<std::pair<pldm::dbus::Property,
208 std::variant<pldm::dbus::Property>>>>>;
Kamalkumar Patel7d427f12024-05-16 03:44:00 -0500209
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530210using ObjectPath = std::string;
Kamalkumar Patel7d427f12024-05-16 03:44:00 -0500211using EntityName = std::string;
212using Entities = std::vector<pldm_entity_node*>;
213using EntityAssociations = std::vector<Entities>;
214using ObjectPathMaps = std::map<fs::path, pldm_entity_node*>;
215using EntityMaps = std::map<pldm::pdr::EntityType, EntityName>;
216
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530217using ServiceName = std::string;
218using Interfaces = std::vector<std::string>;
219using MapperServiceMap = std::vector<std::pair<ServiceName, Interfaces>>;
220using GetSubTreeResponse = std::vector<std::pair<ObjectPath, MapperServiceMap>>;
Pavithra Barithaya2ec82692024-04-29 06:31:10 -0500221using GetSubTreePathsResponse = std::vector<std::string>;
Unive Tienc40d4a62025-03-12 11:36:07 +0800222using GetAssociatedSubTreeResponse =
223 std::map<std::string, std::map<std::string, std::vector<std::string>>>;
Delphine CC Chiu549e4bc2024-03-06 11:24:05 +0800224using GetAncestorsResponse =
225 std::vector<std::pair<ObjectPath, MapperServiceMap>>;
Sridevi Ramesheefe49b2022-06-27 11:51:02 -0500226using PropertyMap = std::map<std::string, PropertyValue>;
227using InterfaceMap = std::map<std::string, PropertyMap>;
Riya Dixit754041d2024-02-20 06:15:49 -0600228using ObjectValueTree = std::map<sdbusplus::message::object_path, InterfaceMap>;
George Liu1e44c732020-02-28 20:20:06 +0800229
230/**
231 * @brief The interface for DBusHandler
232 */
233class DBusHandlerInterface
234{
235 public:
236 virtual ~DBusHandlerInterface() = default;
237
George Liu36e81352020-07-01 14:40:30 +0800238 virtual std::string getService(const char* path,
239 const char* interface) const = 0;
Patrick Williams366507c2025-02-03 14:28:01 -0500240 virtual GetSubTreeResponse getSubtree(
241 const std::string& path, int depth,
242 const std::vector<std::string>& ifaceList) const = 0;
George Liu36e81352020-07-01 14:40:30 +0800243
Patrick Williams366507c2025-02-03 14:28:01 -0500244 virtual GetSubTreePathsResponse getSubTreePaths(
245 const std::string& objectPath, int depth,
246 const std::vector<std::string>& ifaceList) const = 0;
Pavithra Barithaya2ec82692024-04-29 06:31:10 -0500247
Delphine CC Chiu549e4bc2024-03-06 11:24:05 +0800248 virtual GetAncestorsResponse getAncestors(
249 const std::string& path,
250 const std::vector<std::string>& ifaceList) const = 0;
251
George Liu1e44c732020-02-28 20:20:06 +0800252 virtual void setDbusProperty(const DBusMapping& dBusMap,
253 const PropertyValue& value) const = 0;
John Wang9e242422020-03-05 08:37:50 +0800254
Patrick Williams366507c2025-02-03 14:28:01 -0500255 virtual PropertyValue getDbusPropertyVariant(
256 const char* objPath, const char* dbusProp,
257 const char* dbusInterface) const = 0;
Gilbert Chen44524a52022-02-14 12:12:25 +0000258
Patrick Williams366507c2025-02-03 14:28:01 -0500259 virtual PropertyMap getDbusPropertiesVariant(
260 const char* serviceName, const char* objPath,
261 const char* dbusInterface) const = 0;
Unive Tienc40d4a62025-03-12 11:36:07 +0800262
263 virtual GetAssociatedSubTreeResponse getAssociatedSubTree(
264 const sdbusplus::message::object_path& objectPath,
265 const sdbusplus::message::object_path& subtree, int depth,
266 const std::vector<std::string>& ifaceList) const = 0;
George Liu1e44c732020-02-28 20:20:06 +0800267};
268
Sampa Misraa2fa0702019-05-31 01:28:55 -0500269/**
270 * @class DBusHandler
271 *
272 * Wrapper class to handle the D-Bus calls
273 *
274 * This class contains the APIs to handle the D-Bus calls
275 * to cater the request from pldm requester.
276 * A class is created to mock the apis in the test cases
277 */
George Liu1e44c732020-02-28 20:20:06 +0800278class DBusHandler : public DBusHandlerInterface
Sampa Misraa2fa0702019-05-31 01:28:55 -0500279{
280 public:
George Liu0e02c322020-01-01 09:41:51 +0800281 /** @brief Get the bus connection. */
282 static auto& getBus()
283 {
284 static auto bus = sdbusplus::bus::new_default();
285 return bus;
286 }
287
288 /**
289 * @brief Get the DBUS Service name for the input dbus path
John Wang9e242422020-03-05 08:37:50 +0800290 *
George Liu0e02c322020-01-01 09:41:51 +0800291 * @param[in] path - DBUS object path
292 * @param[in] interface - DBUS Interface
John Wang9e242422020-03-05 08:37:50 +0800293 *
George Liu0e02c322020-01-01 09:41:51 +0800294 * @return std::string - the dbus service name
John Wang9e242422020-03-05 08:37:50 +0800295 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500296 * @throw sdbusplus::exception_t when it fails
George Liu0e02c322020-01-01 09:41:51 +0800297 */
George Liu36e81352020-07-01 14:40:30 +0800298 std::string getService(const char* path,
299 const char* interface) const override;
George Liu0e02c322020-01-01 09:41:51 +0800300
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530301 /**
302 * @brief Get the Subtree response from the mapper
303 *
304 * @param[in] path - DBUS object path
305 * @param[in] depth - Search depth
306 * @param[in] ifaceList - list of the interface that are being
307 * queried from the mapper
308 *
309 * @return GetSubTreeResponse - the mapper subtree response
310 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500311 * @throw sdbusplus::exception_t when it fails
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530312 */
Patrick Williams366507c2025-02-03 14:28:01 -0500313 GetSubTreeResponse getSubtree(
314 const std::string& path, int depth,
315 const std::vector<std::string>& ifaceList) const override;
Manojkiran Eda1ef62c32021-04-24 07:23:18 +0530316
Pavithra Barithaya2ec82692024-04-29 06:31:10 -0500317 /** @brief Get Subtree path response from the mapper
318 *
319 * @param[in] path - DBUS object path
320 * @param[in] depth - Search depth
321 * @param[in] ifaceList - list of the interface that are being
322 * queried from the mapper
323 *
324 * @return std::vector<std::string> vector of subtree paths
325 */
326 GetSubTreePathsResponse getSubTreePaths(
327 const std::string& objectPath, int depth,
328 const std::vector<std::string>& ifaceList) const override;
329
Delphine CC Chiu549e4bc2024-03-06 11:24:05 +0800330 /**
331 * @brief Get the Ancestors response from the mapper
332 *
333 * @param[in] path - D-Bus object path
334 * @param[in] ifaceList - an optional list of interfaces to constrain the
335 * search to queried from the mapper
336 *
337 * @return GetAncestorsResponse - the mapper GetAncestors response
338 *
339 * @throw sdbusplus::exception_t when it fails
340 */
341 GetAncestorsResponse getAncestors(
342 const std::string& path,
343 const std::vector<std::string>& ifaceList) const override;
344
John Wang9e242422020-03-05 08:37:50 +0800345 /** @brief Get property(type: variant) from the requested dbus
346 *
347 * @param[in] objPath - The Dbus object path
348 * @param[in] dbusProp - The property name to get
349 * @param[in] dbusInterface - The Dbus interface
350 *
351 * @return The value of the property(type: variant)
352 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500353 * @throw sdbusplus::exception_t when it fails
John Wang9e242422020-03-05 08:37:50 +0800354 */
Patrick Williams366507c2025-02-03 14:28:01 -0500355 PropertyValue getDbusPropertyVariant(
356 const char* objPath, const char* dbusProp,
357 const char* dbusInterface) const override;
George Liu0e02c322020-01-01 09:41:51 +0800358
Gilbert Chen44524a52022-02-14 12:12:25 +0000359 /** @brief Get All properties(type: variant) from the requested dbus
360 *
361 * @param[in] serviceName - The Dbus service name
362 * @param[in] objPath - The Dbus object path
363 * @param[in] dbusInterface - The Dbus interface
364 *
365 * @return The values of the properties(type: variant)
366 *
367 * @throw sdbusplus::exception_t when it fails
368 */
Patrick Williams366507c2025-02-03 14:28:01 -0500369 PropertyMap getDbusPropertiesVariant(
370 const char* serviceName, const char* objPath,
371 const char* dbusInterface) const override;
Gilbert Chen44524a52022-02-14 12:12:25 +0000372
John Wang9e242422020-03-05 08:37:50 +0800373 /** @brief The template function to get property from the requested dbus
374 * path
375 *
376 * @tparam Property - Excepted type of the property on dbus
377 *
378 * @param[in] objPath - The Dbus object path
379 * @param[in] dbusProp - The property name to get
380 * @param[in] dbusInterface - The Dbus interface
381 *
382 * @return The value of the property
383 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500384 * @throw sdbusplus::exception_t when dbus request fails
John Wang9e242422020-03-05 08:37:50 +0800385 * std::bad_variant_access when \p Property and property on dbus do
386 * not match
387 */
John Wang92b3c972019-10-17 11:06:41 +0800388 template <typename Property>
389 auto getDbusProperty(const char* objPath, const char* dbusProp,
390 const char* dbusInterface)
391 {
Patrick Williams16c2a0a2024-08-16 15:20:59 -0400392 auto VariantValue =
393 getDbusPropertyVariant(objPath, dbusProp, dbusInterface);
John Wang92b3c972019-10-17 11:06:41 +0800394 return std::get<Property>(VariantValue);
395 }
George Liu1e44c732020-02-28 20:20:06 +0800396
Unive Tienc40d4a62025-03-12 11:36:07 +0800397 /** @brief Get the associated subtree from the mapper
398 *
399 * @param[in] path - The D-Bus object path
400 *
401 * @param[in] interface - The D-Bus interface
402 *
403 * @return GetAssociatedSubtreeResponse - The associated subtree
404 */
405 GetAssociatedSubTreeResponse getAssociatedSubTree(
406 const sdbusplus::message::object_path& objectPath,
407 const sdbusplus::message::object_path& subtree, int depth,
408 const std::vector<std::string>& ifaceList) const override;
409
George Liu1e44c732020-02-28 20:20:06 +0800410 /** @brief Set Dbus property
411 *
412 * @param[in] dBusMap - Object path, property name, interface and property
413 * type for the D-Bus object
414 * @param[in] value - The value to be set
John Wang9e242422020-03-05 08:37:50 +0800415 *
Patrick Williams84b790c2022-07-22 19:26:56 -0500416 * @throw sdbusplus::exception_t when it fails
George Liu1e44c732020-02-28 20:20:06 +0800417 */
418 void setDbusProperty(const DBusMapping& dBusMap,
419 const PropertyValue& value) const override;
Riya Dixit754041d2024-02-20 06:15:49 -0600420
421 /** @brief This function retrieves the properties of an object managed
422 * by the specified D-Bus service located at the given object path.
423 *
424 * @param[in] service - The D-Bus service providing the managed object
425 * @param[in] value - The object path of the managed object
426 *
427 * @return A hierarchical structure representing the properties of the
428 * managed object.
Patrick Williams897b0f82024-04-14 02:31:48 -0500429 * @throw sdbusplus::exception_t when it fails
Riya Dixit754041d2024-02-20 06:15:49 -0600430 */
431 static ObjectValueTree getManagedObj(const char* service, const char* path);
432
433 /** @brief Retrieve the inventory objects managed by a specified class.
434 * The retrieved inventory objects are cached statically
435 * and returned upon subsequent calls to this function.
436 *
437 * @tparam ClassType - The class type that manages the inventory objects.
438 *
439 * @return A reference to the cached inventory objects.
440 */
441 template <typename ClassType>
442 static auto& getInventoryObjects()
443 {
444 static ObjectValueTree object = ClassType::getManagedObj(
445 inventoryManager::interface, inventoryPath);
446 return object;
447 }
Sampa Misraa2fa0702019-05-31 01:28:55 -0500448};
449
Deepak Kodihalli3cd61812020-03-10 06:38:45 -0500450/** @brief Fetch parent D-Bus object based on pathname
451 *
452 * @param[in] dbusObj - child D-Bus object
453 *
454 * @return std::string - the parent D-Bus object path
455 */
456inline std::string findParent(const std::string& dbusObj)
457{
458 fs::path p(dbusObj);
459 return p.parent_path().string();
460}
461
Pavithra Barithaya51efaf82020-04-02 02:42:27 -0500462/** @brief Read (static) MCTP EID of host firmware from a file
463 *
464 * @return uint8_t - MCTP EID
465 */
466uint8_t readHostEID();
Tom Joseph250c4752020-04-15 10:32:45 +0530467
Gilbert Chen6c7fed42022-02-22 15:40:17 +0000468/** @brief Validate the MCTP EID of MCTP endpoint
469 * In `Table 2 - Special endpoint IDs` of DSP0236. EID 0 is NULL_EID.
470 * EID from 1 to 7 is reserved EID. EID 0xFF is broadcast EID.
471 * Those are invalid EID of one MCTP Endpoint.
472 *
473 * @param[in] eid - MCTP EID
474 *
475 * @return true if the MCTP EID is valid otherwise return false.
476 */
477bool isValidEID(eid mctpEid);
478
TOM JOSEPHd4d97a52020-03-23 14:36:34 +0530479/** @brief Convert a value in the JSON to a D-Bus property value
480 *
481 * @param[in] type - type of the D-Bus property
482 * @param[in] value - value in the JSON file
483 *
484 * @return PropertyValue - the D-Bus property value
485 */
486PropertyValue jsonEntryToDbusVal(std::string_view type,
487 const nlohmann::json& value);
Pavithra Barithaya51efaf82020-04-02 02:42:27 -0500488
Pavithra Barithaya0f74c982020-04-27 02:17:10 -0500489/** @brief Find State Effecter PDR
490 * @param[in] tid - PLDM terminus ID.
491 * @param[in] entityID - entity that can be associated with PLDM State set.
492 * @param[in] stateSetId - value that identifies PLDM State set.
493 * @param[in] repo - pointer to BMC's primary PDR repo.
494 * @return array[array[uint8_t]] - StateEffecterPDRs
495 */
Patrick Williams16c2a0a2024-08-16 15:20:59 -0400496std::vector<std::vector<uint8_t>> findStateEffecterPDR(
497 uint8_t tid, uint16_t entityID, uint16_t stateSetId, const pldm_pdr* repo);
Chicago Duan738e4d82020-05-28 16:39:19 +0800498/** @brief Find State Sensor PDR
499 * @param[in] tid - PLDM terminus ID.
500 * @param[in] entityID - entity that can be associated with PLDM State set.
501 * @param[in] stateSetId - value that identifies PLDM State set.
502 * @param[in] repo - pointer to BMC's primary PDR repo.
503 * @return array[array[uint8_t]] - StateSensorPDRs
504 */
Patrick Williams16c2a0a2024-08-16 15:20:59 -0400505std::vector<std::vector<uint8_t>> findStateSensorPDR(
506 uint8_t tid, uint16_t entityID, uint16_t stateSetId, const pldm_pdr* repo);
Pavithra Barithaya0f74c982020-04-27 02:17:10 -0500507
Sampa Misra3a0e3b92020-10-21 05:58:00 -0500508/** @brief Find sensor id from a state sensor PDR
509 *
510 * @param[in] pdrRepo - PDR repository
511 * @param[in] tid - terminus id
512 * @param[in] entityType - entity type
513 * @param[in] entityInstance - entity instance number
514 * @param[in] containerId - container id
515 * @param[in] stateSetId - state set id
516 *
517 * @return uint16_t - the sensor id
518 */
519uint16_t findStateSensorId(const pldm_pdr* pdrRepo, uint8_t tid,
520 uint16_t entityType, uint16_t entityInstance,
521 uint16_t containerId, uint16_t stateSetId);
522
Tom Joseph250c4752020-04-15 10:32:45 +0530523/** @brief Find effecter id from a state effecter pdr
524 * @param[in] pdrRepo - PDR repository
525 * @param[in] entityType - entity type
526 * @param[in] entityInstance - entity instance number
527 * @param[in] containerId - container id
528 * @param[in] stateSetId - state set id
Sampa Misraa4a96162020-07-14 05:33:46 -0500529 * @param[in] localOrRemote - true for checking local repo and false for remote
530 * repo
Tom Joseph250c4752020-04-15 10:32:45 +0530531 *
532 * @return uint16_t - the effecter id
533 */
534uint16_t findStateEffecterId(const pldm_pdr* pdrRepo, uint16_t entityType,
535 uint16_t entityInstance, uint16_t containerId,
Sampa Misraa4a96162020-07-14 05:33:46 -0500536 uint16_t stateSetId, bool localOrRemote);
Tom Joseph250c4752020-04-15 10:32:45 +0530537
Chicago Duanfe4d88b2020-06-12 16:44:13 +0800538/** @brief Emit the sensor event signal
539 *
540 * @param[in] tid - the terminus id
541 * @param[in] sensorId - sensorID value of the sensor
542 * @param[in] sensorOffset - Identifies which state sensor within a
543 * composite state sensor the event is being returned for
544 * @param[in] eventState - The event state value from the state change that
545 * triggered the event message
546 * @param[in] previousEventState - The event state value for the state from
547 * which the present event state was entered.
548 * @return PLDM completion code
549 */
550int emitStateSensorEventSignal(uint8_t tid, uint16_t sensorId,
551 uint8_t sensorOffset, uint8_t eventState,
552 uint8_t previousEventState);
553
Chau Ly8fa40db2024-04-02 09:32:01 +0000554/**
555 * @brief call Recover() method to recover an MCTP Endpoint
556 * @param[in] MCTP Endpoint's object path
557 */
558void recoverMctpEndpoint(const std::string& endpointObjPath);
559
Sridevi Rameshae28bc72020-12-10 07:21:16 -0600560/** @brief Print the buffer
561 *
Tom Josephe5268cd2021-09-07 13:04:03 +0530562 * @param[in] isTx - True if the buffer is an outgoing PLDM message, false if
563 the buffer is an incoming PLDM message
564 * @param[in] buffer - Buffer to print
Sridevi Rameshae28bc72020-12-10 07:21:16 -0600565 *
566 * @return - None
567 */
Tom Josephe5268cd2021-09-07 13:04:03 +0530568void printBuffer(bool isTx, const std::vector<uint8_t>& buffer);
Sridevi Rameshae28bc72020-12-10 07:21:16 -0600569
Tom Joseph54922072021-06-19 02:45:46 -0700570/** @brief Convert the buffer to std::string
571 *
572 * If there are characters that are not printable characters, it is replaced
573 * with space(0x20).
574 *
575 * @param[in] var - pointer to data and length of the data
576 *
577 * @return std::string equivalent of variable field
578 */
579std::string toString(const struct variable_field& var);
580
George Liu872f0f62021-11-25 16:26:16 +0800581/** @brief Split strings according to special identifiers
582 *
583 * We can split the string according to the custom identifier(';', ',', '&' or
584 * others) and store it to vector.
585 *
586 * @param[in] srcStr - The string to be split
587 * @param[in] delim - The custom identifier
588 * @param[in] trimStr - The first and last string to be trimmed
589 *
590 * @return std::vector<std::string> Vectors are used to store strings
591 */
592std::vector<std::string> split(std::string_view srcStr, std::string_view delim,
593 std::string_view trimStr = "");
Manojkiran Edaef773052021-07-29 09:29:28 +0530594/** @brief Get the current system time in readable format
595 *
596 * @return - std::string equivalent of the system time
597 */
598std::string getCurrentSystemTime();
George Liu872f0f62021-11-25 16:26:16 +0800599
Sridevi Ramesheefe49b2022-06-27 11:51:02 -0500600/** @brief checks if the FRU is actually present.
601 * @param[in] objPath - FRU object path.
602 *
603 * @return bool to indicate presence or absence of FRU.
604 */
605bool checkForFruPresence(const std::string& objPath);
606
Sagar Srinivas5db6e872023-12-01 10:03:30 -0600607/** @brief Method to check if the logical bit is set
608 *
609 * @param[containerId] - container id of the entity
610 *
611 * @return true or false based on the logic bit set
612 */
613bool checkIfLogicalBitSet(const uint16_t& containerId);
Pavithra Barithaya5e542be2021-08-13 00:33:31 -0500614
615/** @brief setting the present property
616 *
617 * @param[in] objPath - the object path of the fru
618 * @param[in] present - status to set either true/false
619 */
620void setFruPresence(const std::string& fruObjPath, bool present);
Thu Nguyenb8cf46b2024-06-15 02:44:35 +0000621
622/** @brief Trim `\0` in string and replace ` ` by `_` to use name in D-Bus
623 * object path
624 *
625 * @param[in] name - the input string
626 *
627 * @return the result string
628 */
629std::string_view trimNameForDbus(std::string& name);
630
Thu Nguyena34a64b2022-03-31 08:56:39 +0700631/** @brief Convert the number type D-Bus Value to the double
632 *
633 * @param[in] type - string type should in dbusValueNumericTypeNames list
634 * @param[in] value - DBus PropertyValue variant
635 * @param[out] doubleValue - response value
636 *
637 * @return true if data type is corrected and converting is successful
638 * otherwise return false.
639 */
640bool dbusPropValuesToDouble(const std::string_view& type,
641 const pldm::utils::PropertyValue& value,
642 double* doubleValue);
643
Dung Caob6d39432024-06-05 03:46:47 +0000644/** @brief Convert the Fru String bytes from PLDM Fru to std::string
645 *
646 * @param[in] value - the Fru String bytes
647 * @param[in] length - Number of bytes
648 *
649 * @return Fru string or nullopt.
650 */
Patrick Williams366507c2025-02-03 14:28:01 -0500651std::optional<std::string> fruFieldValuestring(const uint8_t* value,
652 const uint8_t& length);
Dung Caob6d39432024-06-05 03:46:47 +0000653
654/** @brief Convert the Fru Uint32 raw data from PLDM Fru to uint32_t
655 *
656 * @param[in] value - the Fru uint32 raw data
657 * @param[in] length - Number of bytes
658 *
659 * @return Fru uint32_t or nullopt.
660 */
661std::optional<uint32_t> fruFieldParserU32(const uint8_t* value,
662 const uint8_t& length);
663
George Liu83409572019-12-24 18:42:54 +0800664} // namespace utils
Sampa Misra032bd502019-03-06 05:03:22 -0600665} // namespace pldm