NVMeBasicContext: Account for invalid drive status
Respect the drive status bits in the basic management command response
before parsing the drive temperature value, as it may not yet be valid.
Signed-off-by: Andrew Jeffery <andrew@aj.id.au>
Change-Id: I5311eb3b07f9b52fce7342c9c7f670f777d68c1d
diff --git a/include/NVMeBasicContext.hpp b/include/NVMeBasicContext.hpp
index 6b0a425..6953dd7 100644
--- a/include/NVMeBasicContext.hpp
+++ b/include/NVMeBasicContext.hpp
@@ -22,4 +22,10 @@
boost::asio::io_service& io;
boost::asio::posix::stream_descriptor reqStream;
boost::asio::posix::stream_descriptor respStream;
+
+ enum
+ {
+ NVME_MI_BASIC_SFLGS_DRIVE_NOT_READY = 0x40,
+ NVME_MI_BASIC_SFLGS_DRIVE_FUNCTIONAL = 0x20,
+ };
};
diff --git a/src/NVMeBasicContext.cpp b/src/NVMeBasicContext.cpp
index 29dab7a..08333c5 100644
--- a/src/NVMeBasicContext.cpp
+++ b/src/NVMeBasicContext.cpp
@@ -397,6 +397,15 @@
}
uint8_t* messageData = static_cast<uint8_t*>(msg);
+
+ uint8_t status = messageData[0];
+ if ((status & NVME_MI_BASIC_SFLGS_DRIVE_NOT_READY) ||
+ !(status & NVME_MI_BASIC_SFLGS_DRIVE_FUNCTIONAL))
+ {
+ sensor->markFunctional(false);
+ return;
+ }
+
double value = getTemperatureReading(messageData[2]);
if (!std::isfinite(value))
{