aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp/x300
diff options
context:
space:
mode:
authorAshish Chaudhari <ashish@ettus.com>2015-07-18 22:26:25 -0700
committerAshish Chaudhari <ashish@ettus.com>2015-07-18 22:26:25 -0700
commit410b2447769ada7142c164cdfde7eefb8270bef8 (patch)
tree3a55ef1ae0273695398588a0b1c6b5088b82cff6 /host/lib/usrp/x300
parent722f6f6b398e7698089138ed41824b48b569c4ca (diff)
downloaduhd-410b2447769ada7142c164cdfde7eefb8270bef8.tar.gz
uhd-410b2447769ada7142c164cdfde7eefb8270bef8.tar.bz2
uhd-410b2447769ada7142c164cdfde7eefb8270bef8.zip
x300: Added HW rev compat number support
- Added new field "revision_compat" to mb_eeprom - Enforce a revision_compat of 7
Diffstat (limited to 'host/lib/usrp/x300')
-rw-r--r--host/lib/usrp/x300/x300_fw_common.h2
-rw-r--r--host/lib/usrp/x300/x300_impl.cpp37
2 files changed, 27 insertions, 12 deletions
diff --git a/host/lib/usrp/x300/x300_fw_common.h b/host/lib/usrp/x300/x300_fw_common.h
index f7364c774..79b6670b3 100644
--- a/host/lib/usrp/x300/x300_fw_common.h
+++ b/host/lib/usrp/x300/x300_fw_common.h
@@ -29,7 +29,7 @@
extern "C" {
#endif
-#define X300_MAX_HW_REV 8
+#define X300_REVISION_COMPAT 7
#define X300_FW_COMPAT_MAJOR 4
#define X300_FW_COMPAT_MINOR 0
#define X300_FPGA_COMPAT_MAJOR 11
diff --git a/host/lib/usrp/x300/x300_impl.cpp b/host/lib/usrp/x300/x300_impl.cpp
index 34090faa3..3cfb18a38 100644
--- a/host/lib/usrp/x300/x300_impl.cpp
+++ b/host/lib/usrp/x300/x300_impl.cpp
@@ -604,10 +604,8 @@ void x300_impl::setup_mb(const size_t mb_i, const uhd::device_addr_t &dev_addr)
}
////////////////////////////////////////////////////////////////////
- // create clock control objects
+ // read hardware revision and compatibility number
////////////////////////////////////////////////////////////////////
- UHD_MSG(status) << "Setup RF frontend clocking..." << std::endl;
-
mb.hw_rev = 0;
if(mb_eeprom.has_key("revision") and not mb_eeprom["revision"].empty()) {
try {
@@ -624,16 +622,33 @@ void x300_impl::setup_mb(const size_t mb_i, const uhd::device_addr_t &dev_addr)
mb.hw_rev = X300_REV("D");
}
- if (mb.hw_rev > X300_MAX_HW_REV) {
- throw uhd::runtime_error(str(
- boost::format("Unsupported board revision number: %d.\n"
- "The maximum board revision number supported in this version is %d.\n"
- "Please update your UHD version.")
- % mb.hw_rev % X300_MAX_HW_REV
- ));
+ if (mb_eeprom.has_key("revision_compat") and not mb_eeprom["revision_compat"].empty()) {
+ size_t hw_rev_compat = 0;
+ try {
+ hw_rev_compat = boost::lexical_cast<size_t>(mb_eeprom["revision_compat"]);
+ } catch(...) {
+ UHD_MSG(warning) << "Revision compat in EEPROM is invalid! Please reprogram your EEPROM." << std::endl;
+ }
+
+ if (hw_rev_compat > X300_REVISION_COMPAT) {
+ throw uhd::runtime_error(str(boost::format(
+ "Hardware is too new for this software. Please upgrade to a UHD/NI-USRP that supports hardware revision %d.")
+ % mb.hw_rev));
+ } else if (hw_rev_compat < X300_REVISION_COMPAT) {
+ throw uhd::runtime_error(str(boost::format(
+ "Hardware is too new for this software. Please downgrade to a UHD/NI-USRP that supports hardware revision %d.")
+ % mb.hw_rev));
+ }
+ } else if (mb.hw_rev >= 7) { //Revision compat was added with revision 7
+ UHD_MSG(warning) << "No revision compat detected MB EEPROM must be reprogrammed!" << std::endl;
}
- //Create clock control. NOTE: This does not configure the LMK yet.
+ ////////////////////////////////////////////////////////////////////
+ // create clock control objects
+ ////////////////////////////////////////////////////////////////////
+ UHD_MSG(status) << "Setup RF frontend clocking..." << std::endl;
+
+ //Initialize clock control registers. NOTE: This does not configure the LMK yet.
initialize_clock_control(mb);
mb.clock = x300_clock_ctrl::make(mb.zpu_spi,
1 /*slaveno*/,