aboutsummaryrefslogtreecommitdiffstats
path: root/host
diff options
context:
space:
mode:
authorsteviez <steve.czabaniuk@ni.com>2020-04-13 23:25:16 -0500
committerAaron Rossetto <aaron.rossetto@ni.com>2020-04-15 07:46:25 -0500
commit62011391d342bd3c5ac9539f8c736d1f909c8485 (patch)
tree06b08d7b39e34b9eac213e1daaee09f8d9138859 /host
parent0597c128475385daf9d0abafc60ec861c951eeaa (diff)
downloaduhd-62011391d342bd3c5ac9539f8c736d1f909c8485.tar.gz
uhd-62011391d342bd3c5ac9539f8c736d1f909c8485.tar.bz2
uhd-62011391d342bd3c5ac9539f8c736d1f909c8485.zip
utils: usrp_burn_mb_eeprom: Avoid EEPROM write in read only case
The usrp_burn_mb_eeprom previously updated the EEPROM at the end of the script, regardless of whether any values were actually specified for write. This skips the EEPROM write for read only usage.
Diffstat (limited to 'host')
-rw-r--r--host/utils/usrp_burn_mb_eeprom.cpp36
1 files changed, 19 insertions, 17 deletions
diff --git a/host/utils/usrp_burn_mb_eeprom.cpp b/host/utils/usrp_burn_mb_eeprom.cpp
index 65b68f379..18e8b367b 100644
--- a/host/utils/usrp_burn_mb_eeprom.cpp
+++ b/host/utils/usrp_burn_mb_eeprom.cpp
@@ -39,11 +39,11 @@ int UHD_SAFE_MAIN(int argc, char* argv[])
// print the help message
if (vm.count("help") or (not vm.count("values") and not vm.count("read-all"))) {
std::cout << boost::format("USRP Burn Motherboard EEPROM %s") % desc << std::endl;
- std::cout << boost::format("Omit the value argument to perform a readback,\n"
+ std::cout << boost::format("In values argument, omit value to perform a readback,\n"
"Or specify a new value to burn into the EEPROM.\n"
"Example (write to ip-addr0 and read out ip-addr1):\n"
" usrp_burn_mb_eeprom --args=<device args> "
- "--values\"ip-addr0=192.168.10.3,ip-addr1\"")
+ "--values \"ip-addr0=192.168.10.3,ip-addr1\"")
<< std::endl;
return EXIT_FAILURE;
}
@@ -56,9 +56,10 @@ int UHD_SAFE_MAIN(int argc, char* argv[])
std::cout << std::endl;
std::vector<std::string> keys_vec, vals_vec;
- if (vm.count("read-all"))
- keys_vec =
- mb_eeprom.keys(); // Leaving vals_vec empty will force utility to only read
+ if (vm.count("read-all")) {
+ keys_vec = mb_eeprom.keys();
+ // Leaving vals_vec empty will force utility to only read
+ }
else if (vm.count("values")) {
// uhd::device_addr_t properly parses input values
uhd::device_addr_t vals(input_str);
@@ -81,20 +82,21 @@ int UHD_SAFE_MAIN(int argc, char* argv[])
std::cout << std::endl;
// 2. Write new values if given
- mb_eeprom = uhd::usrp::mboard_eeprom_t();
- for (size_t i = 0; i < vals_vec.size(); i++) {
- if (vals_vec[i] != "") {
- mb_eeprom[keys_vec[i]] = vals_vec[i];
- std::cout << boost::format("Setting EEPROM [\"%s\"] to \"%s\"...")
- % keys_vec[i] % vals_vec[i]
- << std::endl;
+ if (not vals_vec.empty()) {
+ mb_eeprom = uhd::usrp::mboard_eeprom_t();
+ for (size_t i = 0; i < vals_vec.size(); i++) {
+ if (vals_vec[i] != "") {
+ mb_eeprom[keys_vec[i]] = vals_vec[i];
+ std::cout << boost::format("Setting EEPROM [\"%s\"] to \"%s\"...")
+ % keys_vec[i] % vals_vec[i]
+ << std::endl;
+ }
}
+ tree->access<uhd::usrp::mboard_eeprom_t>("/mboards/0/eeprom").set(mb_eeprom);
+ std::cout << "Power-cycle the USRP device for the changes to take effect."
+ << std::endl;
+ std::cout << std::endl;
}
- tree->access<uhd::usrp::mboard_eeprom_t>("/mboards/0/eeprom").set(mb_eeprom);
- std::cout << "Power-cycle the USRP device for the changes to take effect."
- << std::endl;
- std::cout << std::endl;
-
std::cout << "Done" << std::endl;
return EXIT_SUCCESS;
}