diff options
Diffstat (limited to 'host/utils')
| -rw-r--r-- | host/utils/CMakeLists.txt | 21 | ||||
| -rwxr-xr-x | host/utils/FastSendDatagramThreshold.reg | bin | 0 -> 312 bytes | |||
| -rw-r--r-- | host/utils/uhd_images_downloader.py | 95 | ||||
| -rw-r--r-- | host/utils/uhd_usrp_probe.cpp | 12 | ||||
| -rw-r--r-- | host/utils/usrp_cal_utils.hpp | 18 | 
5 files changed, 138 insertions, 8 deletions
| diff --git a/host/utils/CMakeLists.txt b/host/utils/CMakeLists.txt index 0ecd6b4e7..a4ff21eee 100644 --- a/host/utils/CMakeLists.txt +++ b/host/utils/CMakeLists.txt @@ -1,5 +1,5 @@  # -# Copyright 2010-2011 Ettus Research LLC +# Copyright 2010-2012 Ettus Research LLC  #  # This program is free software: you can redistribute it and/or modify  # it under the terms of the GNU General Public License as published by @@ -64,6 +64,17 @@ FOREACH(util_source ${util_share_sources})      INSTALL(TARGETS ${util_name} RUNTIME DESTINATION ${PKG_LIB_DIR}/utils COMPONENT utilities)  ENDFOREACH(util_source) +#UHD images downloader configuration +CONFIGURE_FILE( +    ${CMAKE_CURRENT_SOURCE_DIR}/uhd_images_downloader.py +    ${CMAKE_CURRENT_BINARY_DIR}/uhd_images_downloader.py +@ONLY) +INSTALL(PROGRAMS +    ${CMAKE_CURRENT_BINARY_DIR}/uhd_images_downloader.py +    DESTINATION ${PKG_LIB_DIR}/utils +    COMPONENT utilities +) +  IF(ENABLE_USRP2)      IF(WIN32 AND UHD_RELEASE_MODE) #include dd.exe          FILE(DOWNLOAD @@ -76,8 +87,14 @@ IF(ENABLE_USRP2)              COMPONENT utilities          )      ENDIF(WIN32 AND UHD_RELEASE_MODE) +    IF(LINUX) +        INSTALL(PROGRAMS +            usrp2_recovery.py +            DESTINATION ${PKG_LIB_DIR}/utils +            COMPONENT utilities +        ) +    ENDIF(LINUX)      INSTALL(PROGRAMS -        usrp2_recovery.py          usrp2_card_burner.py          usrp2_card_burner_gui.py          usrp_n2xx_net_burner.py diff --git a/host/utils/FastSendDatagramThreshold.reg b/host/utils/FastSendDatagramThreshold.regBinary files differ new file mode 100755 index 000000000..c0665d09e --- /dev/null +++ b/host/utils/FastSendDatagramThreshold.reg diff --git a/host/utils/uhd_images_downloader.py b/host/utils/uhd_images_downloader.py new file mode 100644 index 000000000..be76f5b2d --- /dev/null +++ b/host/utils/uhd_images_downloader.py @@ -0,0 +1,95 @@ +#!/usr/bin/env python +# +# Copyright 2012 Ettus Research LLC +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program.  If not, see <http://www.gnu.org/licenses/>. +# + +from optparse import OptionParser +import os +import os.path +import shutil +import sys +import urllib2 +import zipfile + +if __name__ == "__main__": + +    #Command line options +    parser = OptionParser() +    parser.add_option("--download-location", type="string", default="@CMAKE_INSTALL_PREFIX@/share/uhd/images", help="Set custom download location for images, [default=%default]") +    parser.add_option("--buffer-size", type="int", default=8192, help="Set download buffer size, [default=%default]",) +    (options, args) = parser.parse_args() +     +    #Configuring image download info +    images_src = "@UHD_IMAGES_DOWNLOAD_SRC@" +    filename = images_src.split("/")[-1] +     +    #Configuring image destination +    cmake_install_prefix = "@CMAKE_INSTALL_PREFIX@" +    if options.download_location != "": +        images_dir = options.download_location +    else: +        images_dir = "@CMAKE_INSTALL_PREFIX@/share/uhd/images" +     +    u = urllib2.urlopen(images_src) +    f = open(filename, "wb") +    meta = u.info() +    #filesize = int(meta.getheaders("Content-Length")[0]) +    filesize = float(int(meta.getheaders("Content-Length")[0])) +     +    print "Downloading images from: %s" % images_src +     +    filesize_dl = 0.0 + +    #Downloading file     +    while True: +        buffer = u.read(options.buffer_size) +        if not buffer: +            break +     +        filesize_dl -= len(buffer) +        f.write(buffer) + +        status = r"%2.2f MB/%2.2f MB (%3.2f" % (-filesize_dl/1e6, filesize/1e6, (-filesize_dl*100.)/filesize) + r"%)" +        status += chr(8)*(len(status)+1) +        print status, +     +    f.close() + +    #Extracting contents of zip file +    if os.path.exists("tempdir"): +        shutil.rmtree("tempdir") +    os.mkdir("tempdir") + +    images_zip = zipfile.ZipFile(filename) +    images_zip.extractall("tempdir") + +    #Removing images currently in images_dir +    if os.path.exists(images_dir): +        try: +            shutil.rmtree(images_dir) +        except: +            sys.stderr.write("\nMake sure you have write permissions in the images directory.\n") +            sys.exit(0) + +    #Copying downloaded images into images_dir +    shutil.copytree("tempdir/%s/share/uhd/images" % filename[:-4],images_dir) + +    #Removing tempdir and zip file +    shutil.rmtree("tempdir") +    images_zip.close() +    os.remove(filename) + +    print "\nImages successfully installed to: %s" % images_dir diff --git a/host/utils/uhd_usrp_probe.cpp b/host/utils/uhd_usrp_probe.cpp index 1bd49a5ff..5b3702fb4 100644 --- a/host/utils/uhd_usrp_probe.cpp +++ b/host/utils/uhd_usrp_probe.cpp @@ -69,9 +69,9 @@ static std::string prop_names_to_pp_string(const std::vector<std::string> &prop_      return ss.str();  } -static std::string get_subdev_pp_string(const std::string &type, property_tree::sptr tree, const fs_path &path){ +static std::string get_frontend_pp_string(const std::string &type, property_tree::sptr tree, const fs_path &path){      std::stringstream ss; -    ss << boost::format("%s Subdev: %s") % type % path.leaf() << std::endl; +    ss << boost::format("%s Frontend: %s") % type % path.leaf() << std::endl;      //ss << std::endl;      ss << boost::format("Name: %s") % (tree->access<std::string>(path / "name").get()) << std::endl; @@ -123,7 +123,7 @@ static std::string get_dboard_pp_string(const std::string &type, property_tree::          if (not gdb_eeprom.serial.empty()) ss << boost::format("Serial: %s") % gdb_eeprom.serial << std::endl;      }      BOOST_FOREACH(const std::string &name, tree->list(path / (prefix + "_frontends"))){ -        ss << make_border(get_subdev_pp_string(type, tree, path / (prefix + "_frontends") / name)); +        ss << make_border(get_frontend_pp_string(type, tree, path / (prefix + "_frontends") / name));      }      ss << make_border(get_codec_pp_string(type, tree, path.branch_path().branch_path() / (prefix + "_codecs") / path.leaf()));      return ss.str(); @@ -137,6 +137,12 @@ static std::string get_mboard_pp_string(property_tree::sptr tree, const fs_path      BOOST_FOREACH(const std::string &key, mb_eeprom.keys()){          if (not mb_eeprom[key].empty()) ss << boost::format("%s: %s") % key % mb_eeprom[key] << std::endl;      } +    if (tree->exists(path / "fw_version")){ +        ss << "FW Version: " << tree->access<std::string>(path / "fw_version").get() << std::endl; +    } +    if (tree->exists(path / "fpga_version")){ +        ss << "FPGA Version: " << tree->access<std::string>(path / "fpga_version").get() << std::endl; +    }      ss << std::endl;      ss << "Time sources: " << prop_names_to_pp_string(tree->access<std::vector<std::string> >(path / "time_source" / "options").get()) << std::endl;      ss << "Clock sources: " << prop_names_to_pp_string(tree->access<std::vector<std::string> >(path / "clock_source" / "options").get()) << std::endl; diff --git a/host/utils/usrp_cal_utils.hpp b/host/utils/usrp_cal_utils.hpp index 825d94d64..364b68bbe 100644 --- a/host/utils/usrp_cal_utils.hpp +++ b/host/utils/usrp_cal_utils.hpp @@ -1,5 +1,5 @@  // -// Copyright 2010 Ettus Research LLC +// Copyright 2011-2012 Ettus Research LLC  //  // This program is free software: you can redistribute it and/or modify  // it under the terms of the GNU General Public License as published by @@ -68,7 +68,13 @@ static inline void set_optimum_defaults(uhd::usrp::multi_usrp::sptr usrp){      const uhd::fs_path tx_fe_path = "/mboards/0/dboards/A/tx_frontends/0";      const std::string tx_name = tree->access<std::string>(tx_fe_path / "name").get(); -    if (tx_name.find("WBX") != std::string::npos or tx_name.find("SBX") != std::string::npos){ +    if (tx_name.find("WBX") != std::string::npos){ +        usrp->set_tx_gain(0); +    } +    else if (tx_name.find("SBX") != std::string::npos){ +        usrp->set_tx_gain(0); +    } +    else if (tx_name.find("RFX") != std::string::npos){          usrp->set_tx_gain(0);      }      else{ @@ -77,7 +83,13 @@ static inline void set_optimum_defaults(uhd::usrp::multi_usrp::sptr usrp){      const uhd::fs_path rx_fe_path = "/mboards/0/dboards/A/tx_frontends/0";      const std::string rx_name = tree->access<std::string>(rx_fe_path / "name").get(); -    if (rx_name.find("WBX") != std::string::npos or rx_name.find("SBX") != std::string::npos){ +    if (rx_name.find("WBX") != std::string::npos){ +        usrp->set_rx_gain(25); +    } +    else if (rx_name.find("SBX") != std::string::npos){ +        usrp->set_rx_gain(25); +    } +    else if (rx_name.find("RFX") != std::string::npos){          usrp->set_rx_gain(25);      }      else{ | 
