No retries when adding a purposely removed sensor

When a sensor is removed due to a removal return code being received
during a read, no read retries should be done when attempting to re-add
it. This requires the sensor to be successful in its first read
attempted when being re-added and keeps the re-adding of purposely
removed sensors from consuming up to 1 second during the re-add attempt.

Tested:
    A removed sensor is attempted to be read once on re-add

Change-Id: Ia7eb463deb569c9d10883632e017b4dd05413854
Signed-off-by: Matthew Barth <msbarth@us.ibm.com>
diff --git a/mainloop.cpp b/mainloop.cpp
index 8a804f7..c93beb8 100644
--- a/mainloop.cpp
+++ b/mainloop.cpp
@@ -207,7 +207,7 @@
 }
 
 auto addValue(const SensorSet::key_type& sensor,
-              const std::string& devPath,
+              const RetryIO& retryIO,
               sysfs::hwmonio::HwmonIO& ioAccess,
               ObjectInfo& info,
               bool isOCC = false)
@@ -232,8 +232,8 @@
             sensor.first,
             sensor.second,
             hwmon::entry::cinput,
-            sysfs::hwmonio::retries,
-            sysfs::hwmonio::delay,
+            std::get<size_t>(retryIO),
+            std::get<std::chrono::milliseconds>(retryIO),
             isOCC);
 
     auto gain = getEnv("GAIN", sensor);
@@ -346,11 +346,18 @@
     objectPath.append(label);
 
     ObjectInfo info(&_bus, std::move(objectPath), Object());
+    RetryIO retryIO(sysfs::hwmonio::retries, sysfs::hwmonio::delay);
+    if (rmSensors.find(sensor.first) != rmSensors.end())
+    {
+        // When adding a sensor that was purposely removed,
+        // don't retry on errors when reading its value
+        std::get<size_t>(retryIO) = 0;
+    }
     auto valueInterface = static_cast<
             std::shared_ptr<ValueObject>>(nullptr);
     try
     {
-        valueInterface = addValue(sensor.first, _devPath, ioAccess, info,
+        valueInterface = addValue(sensor.first, retryIO, ioAccess, info,
                 _isOCC);
     }
     catch (const std::system_error& e)
diff --git a/mainloop.hpp b/mainloop.hpp
index d1fe9b0..9a51580 100644
--- a/mainloop.hpp
+++ b/mainloop.hpp
@@ -14,6 +14,7 @@
 
 using Object = std::map<InterfaceType, std::experimental::any>;
 using ObjectInfo = std::tuple<sdbusplus::bus::bus*, std::string, Object>;
+using RetryIO = std::tuple<size_t, std::chrono::milliseconds>;
 
 /** @class MainLoop
  *  @brief hwmon-readd main application loop.