From e05b292b8451eaa3ffb7bb28df231e0e1ed008b8 Mon Sep 17 00:00:00 2001 From: Tom Joseph Date: Thu, 7 Sep 2017 00:43:16 +0530 Subject: sensor: Map dbus info to sensor's reading field Change-Id: I3e35bf78260b1fa29e992b00279f2dd166cd2fe1 Signed-off-by: Tom Joseph --- sensordatahandler.hpp | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) (limited to 'sensordatahandler.hpp') diff --git a/sensordatahandler.hpp b/sensordatahandler.hpp index ba496e7..1b05342 100644 --- a/sensordatahandler.hpp +++ b/sensordatahandler.hpp @@ -115,6 +115,43 @@ GetSensorResponse readingAssertion(const Info& sensorInfo) return response; } +/** @brief Map the Dbus info to the reading field in the Get sensor reading + * command response + * + * @tparam T - type of the dbus property related to sensor. + * @param[in] sensorInfo - Dbus info related to sensor. + * + * @return Response for get sensor reading command. + */ +template +GetSensorResponse readingData(const Info& sensorInfo) +{ + sdbusplus::bus::bus bus{ipmid_get_sd_bus_connection()}; + GetSensorResponse response {}; + auto responseData = reinterpret_cast(response.data()); + + enableScanning(responseData); + + auto service = ipmi::getService(bus, + sensorInfo.sensorInterface, + sensorInfo.sensorPath); + + auto propValue = ipmi::getDbusProperty( + bus, + service, + sensorInfo.sensorPath, + sensorInfo.propertyInterfaces.begin()->first, + sensorInfo.propertyInterfaces.begin()->second.begin()->first); + + auto value = static_cast( + (propValue.get() - sensorInfo.scaledOffset) / + (sensorInfo.coefficientM ? sensorInfo.coefficientM : 1)); + + setReading(value, responseData); + + return response; +} + } //namespace get namespace set -- cgit v1.2.1