Move GPIO presence object to its own files
This commit moves and renames the PresenceSensor to PresenceGpio
from TachSensors to its own file so that it can be used for more
than just fans.
It is currently only used for GPIO presence monitoring for fans.
This commit maintains the same functionality as the original code.
Once the objects is created for a GPIO, it will be monitoring for
gpiod::line_request::EVENT_BOTH_EDGES changes. The user can call
isPresent() anytime to read the presence status.
Interface:
EventPresenceGpio(const std::string& iDeviceType,
const std::string& iDeviceName,
const std::string& gpioName, bool inverted,
boost::asio::io_context& io);
Sample usage:
presenceGpio = std::make_unique<EventPresenceGpio>(
"Fan", "Fan4b", "FAN4_PRESENCE_R_N", true, io);
if (presenceGpio->isPresent())
{
// Fan is present
}
Testing: Unable to test this update because no hardware supporting
event driven GPIO detection available.
Change-Id: I1f1a4cbab39d3e3ab38b30288f6aa199ee0cfe3c
Signed-off-by: Chris Cain <cjcain@us.ibm.com>
diff --git a/src/FanMain.cpp b/src/FanMain.cpp
index 4087472..736d07d 100644
--- a/src/FanMain.cpp
+++ b/src/FanMain.cpp
@@ -14,6 +14,7 @@
// limitations under the License.
*/
+#include "PresenceGpio.hpp"
#include "PwmSensor.hpp"
#include "TachSensor.hpp"
#include "Thresholds.hpp"
@@ -274,8 +275,8 @@
tachSensors,
boost::container::flat_map<std::string, std::unique_ptr<PwmSensor>>&
pwmSensors,
- boost::container::flat_map<std::string, std::weak_ptr<PresenceSensor>>&
- presenceSensors,
+ boost::container::flat_map<std::string, std::weak_ptr<PresenceGpio>>&
+ presenceGpios,
std::shared_ptr<sdbusplus::asio::connection>& dbusConnection,
const std::shared_ptr<boost::container::flat_set<std::string>>&
sensorsChanged,
@@ -283,7 +284,7 @@
{
auto getter = std::make_shared<GetSensorConfiguration>(
dbusConnection,
- [&io, &objectServer, &tachSensors, &pwmSensors, &presenceSensors,
+ [&io, &objectServer, &tachSensors, &pwmSensors, &presenceGpios,
&dbusConnection,
sensorsChanged](const ManagedObjectType& sensorConfigurations) {
bool firstScan = sensorsChanged == nullptr;
@@ -435,7 +436,7 @@
auto presenceConfig =
sensorData->find(cfgIntf + std::string(".Presence"));
- std::shared_ptr<PresenceSensor> presenceSensor(nullptr);
+ std::shared_ptr<PresenceGpio> presenceGpio(nullptr);
// presence sensors are optional
if (presenceConfig != sensorData->end())
@@ -457,22 +458,23 @@
if (pinName != nullptr)
{
- auto findPresenceSensor =
- presenceSensors.find(*pinName);
- if (findPresenceSensor != presenceSensors.end())
+ auto findPresenceGpio =
+ presenceGpios.find(*pinName);
+ if (findPresenceGpio != presenceGpios.end())
{
- auto p = findPresenceSensor->second.lock();
+ auto p = findPresenceGpio->second.lock();
if (p)
{
- presenceSensor = p;
+ presenceGpio = p;
}
}
- if (!presenceSensor)
+ if (!presenceGpio)
{
- presenceSensor =
- std::make_shared<PresenceSensor>(
- *pinName, inverted, io, sensorName);
- presenceSensors[*pinName] = presenceSensor;
+ presenceGpio =
+ std::make_shared<EventPresenceGpio>(
+ "Fan", sensorName, *pinName, inverted,
+ io);
+ presenceGpios[*pinName] = presenceGpio;
}
}
else
@@ -582,7 +584,7 @@
tachSensor = nullptr;
tachSensor = std::make_shared<TachSensor>(
path.string(), baseType, objectServer, dbusConnection,
- presenceSensor, redundancy, io, sensorName,
+ presenceGpio, redundancy, io, sensorName,
std::move(sensorThresholds), *interfacePath, limits,
powerState, led);
tachSensor->setupRead();
@@ -617,14 +619,14 @@
tachSensors;
boost::container::flat_map<std::string, std::unique_ptr<PwmSensor>>
pwmSensors;
- boost::container::flat_map<std::string, std::weak_ptr<PresenceSensor>>
- presenceSensors;
+ boost::container::flat_map<std::string, std::weak_ptr<PresenceGpio>>
+ presenceGpios;
auto sensorsChanged =
std::make_shared<boost::container::flat_set<std::string>>();
boost::asio::post(io, [&]() {
- createSensors(io, objectServer, tachSensors, pwmSensors,
- presenceSensors, systemBus, nullptr);
+ createSensors(io, objectServer, tachSensors, pwmSensors, presenceGpios,
+ systemBus, nullptr);
});
boost::asio::steady_timer filterTimer(io);
@@ -651,7 +653,7 @@
return;
}
createSensors(io, objectServer, tachSensors, pwmSensors,
- presenceSensors, systemBus, sensorsChanged, 5);
+ presenceGpios, systemBus, sensorsChanged, 5);
});
};