aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python/usrp_mpm/periph_manager/base.py
diff options
context:
space:
mode:
Diffstat (limited to 'mpm/python/usrp_mpm/periph_manager/base.py')
-rw-r--r--mpm/python/usrp_mpm/periph_manager/base.py45
1 files changed, 30 insertions, 15 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/base.py b/mpm/python/usrp_mpm/periph_manager/base.py
index e297effbd..a3adc56c8 100644
--- a/mpm/python/usrp_mpm/periph_manager/base.py
+++ b/mpm/python/usrp_mpm/periph_manager/base.py
@@ -85,7 +85,7 @@ class PeriphManagerBase(object):
# For checking revision numbers, this is the highest revision that this
# particular version of MPM supports. Leave at None to skip a max rev
# check.
- mboard_max_rev = None
+ mboard_last_rev_compat = 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 = {}
@@ -287,22 +287,37 @@ class PeriphManagerBase(object):
)
)
raise RuntimeError("Invalid PID found in EEPROM.")
- if 'rev' in eeprom_head:
- try:
- rev_numeric = int(eeprom_head.get('rev'))
- except (ValueError, TypeError):
+ # The rev_compat is either directly stored in the EEPROM, or we fall
+ # back first to the dt_compat, then the rev itself (because every rev is
+ # compatible with itself).
+ # The dt_compat solution is a technically a hack, but it works because
+ # all hardware we have released until we made this change happened to
+ # have a dt_compat that also works as a rev_compat.
+ rev_compat = \
+ eeprom_head.get('rev_compat',
+ eeprom_head.get('dt_compat',
+ eeprom_head.get('rev')))
+ try:
+ rev_compat = int(rev_compat)
+ except (ValueError, TypeError):
+ raise RuntimeError(
+ "Invalid revision compat info read from EEPROM!"
+ )
+ # We check if this software is actually compatible with the hardware.
+ # In order for the software to be able to understand the hardware, the
+ # rev_compat value (stored on the EEPROM) must be smaller or equal to
+ # the value stored in the software itself.
+ if self.mboard_last_rev_compat is None:
+ self.log.warning("Skipping HW/SW compatibility check!")
+ else:
+ if rev_compat > self.mboard_last_rev_compat:
raise RuntimeError(
- "Invalid revision info read from EEPROM!"
+ "Software is maximally compatible with revision `{}', but "
+ "the hardware has revision `{}' and is minimally compatible "
+ "with hardware revision `{}'. Please upgrade your version of"
+ "MPM in order to use this device."
+ .format(self.mboard_last_rev_compat, mboard_info['rev'], rev_compat)
)
- if self.mboard_max_rev is not None \
- and rev_numeric > self.mboard_max_rev:
- raise RuntimeError(
- "Device has revision `{}', but max supported " \
- "revision is `{}'".format(
- rev_numeric, self.mboard_max_rev
- ))
- else:
- raise RuntimeError("No revision found in EEPROM.")
return mboard_info
def _get_dboard_eeprom_info(self):