From e2f8f8e0bd36171246e99d96a5155a5b098f6700 Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Fri, 29 Sep 2017 13:58:43 -0700 Subject: mpm: Added sensor API - Motherboard sensors are automatically populated into the property tree, they can be automatically enumerated and queried - Daughterboard sensors have an API for querying and enumerating sensors, but this commit does not automatically add them to the property tree --- mpm/python/usrp_mpm/periph_manager/base.py | 38 ++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) (limited to 'mpm/python/usrp_mpm/periph_manager') diff --git a/mpm/python/usrp_mpm/periph_manager/base.py b/mpm/python/usrp_mpm/periph_manager/base.py index 0aa1adf59..72066b9ef 100644 --- a/mpm/python/usrp_mpm/periph_manager/base.py +++ b/mpm/python/usrp_mpm/periph_manager/base.py @@ -93,6 +93,9 @@ class PeriphManagerBase(object): # particular version of MPM supports. Leave at None to skip a max rev # check. mboard_max_rev = None + # A list of available sensors on the motherboard. This dictionary is a map + # of the form sensor_name -> method name + mboard_sensor_callback_map = {} # This is a sanity check value to see if the correct number of # daughterboards are detected. If somewhere along the line more than # max_num_dboards dboards are found, an error or warning is raised, @@ -461,3 +464,38 @@ class PeriphManagerBase(object): xbar_file.write(laddr_value) return True + def get_mb_sensors(self): + """ + Return a list of sensor names. + """ + return list(self.mboard_sensor_callback_map.keys()) + + def get_mb_sensor(self, sensor_name): + """ + Return a dictionary that represents the sensor values for a given + sensor. If the requested sensor sensor_name does not exist, throw an + exception. + + The returned dictionary has the following keys (all values are + strings): + - name: This is typically the same as sensor_name + - type: One of the following strings: BOOLEAN, INTEGER, REALNUM, STRING + Note that this matches uhd::sensor_value_t::data_type_t + - value: The value. If type is STRING, it is interpreted as-is. If it's + REALNUM or INTEGER, it needs to be convertable to float or + int, respectively. If it's BOOLEAN, it needs to be either + 'true' or 'false', although any string that is not 'true' will + be interpreted as false. + - unit: This depends on the type. It is generally only relevant for + pretty-printing the sensor value. + """ + if sensor_name not in self.get_mb_sensors(): + error_msg = "Was asked for non-existent sensor `{}'.".format( + sensor_name + ) + self.log.error(error_msg) + raise RuntimeError(error_msg) + return getattr( + self, self.mboard_sensor_callback_map.get(sensor_name) + )() + -- cgit v1.2.3