aboutsummaryrefslogtreecommitdiffstats
path: root/host/usrp_e_utils/usrp-e-utility.cpp
blob: b926cf49d1034b1c4e01863ec5a243b829a8e169 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
//
// Copyright 2011 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/>.
//

#include <uhd/utils/safe_main.hpp>
#include <boost/program_options.hpp>
#include <boost/format.hpp>
#include <stdexcept>
#include <iostream>

#include "fpga_downloader.cpp"
#include "clkgen_config.hpp"

namespace po = boost::program_options;

int UHD_SAFE_MAIN(int argc, char *argv[]){

    //variables to be set by po
    std::string fpga_path;

    //setup the program options
    po::options_description desc("Allowed options");
    desc.add_options()
        ("help", "help message")
        ("fpga", po::value<std::string>(&fpga_path), "loads the specified FPGA file")
        ("reclk",                                    "runs the clock recovery")
    ;
    po::variables_map vm;
    po::store(po::parse_command_line(argc, argv, desc), vm);
    po::notify(vm);

    //print the help message
    if (vm.count("help")){
        std::cout << boost::format("UHD USRP-E Utility %s") % desc << std::endl;
        return ~0;
    }

    bool loaded_fpga_image = false;
    if (vm.count("fpga") != 0){
        std::cout << "USRP-E Utility loading the FPGA..." << std::endl << std::endl;
        usrp_e100_load_fpga(fpga_path);
        loaded_fpga_image = true;
        sleep(1);
    }

    if (vm.count("reclk") != 0){
        std::cout << "USRP-E Utility running the clock recovery..." << std::flush;
        //if an image was not loaded or specified, we load pass-through
        if (fpga_path.empty()) throw std::runtime_error(
            "Please specify the path to the pass-though FPGA image for your device.\n"
            "  usrp-e-utility --reclk --fpga=/usr/share/uhd/images/usrp_e1xx_pt_fpga.bin"
        );
        clock_genconfig_main();
        if (std::system("rm /tmp/usrp*hash") != 0){ //clear hash so driver must reload
            std::cerr << "No hash to remove! Don't worry, its not a problem." << std::endl;
        }
    }

    std::cout << "Done!" << std::endl;

    return 0;
}