aboutsummaryrefslogtreecommitdiffstats
path: root/host/apps
diff options
context:
space:
mode:
authorJosh Blum <josh@joshknows.com>2010-03-23 20:44:50 -0700
committerJosh Blum <josh@joshknows.com>2010-03-23 20:44:50 -0700
commit24bd27b90d06820d858c008cff915319873321c5 (patch)
treecadca487d3f804ad73bc0476b3f44a62eb33d306 /host/apps
parent1aef83037f6a9988b06a547710afbbe5ce815459 (diff)
downloaduhd-24bd27b90d06820d858c008cff915319873321c5.tar.gz
uhd-24bd27b90d06820d858c008cff915319873321c5.tar.bz2
uhd-24bd27b90d06820d858c008cff915319873321c5.zip
Reorganized apps dir into utils and examples dir.
The files get installed into the pkg data directory.
Diffstat (limited to 'host/apps')
-rw-r--r--host/apps/CMakeLists.txt26
-rw-r--r--host/apps/discover_usrps.cpp70
-rw-r--r--host/apps/uhd_rx_timed_samples.cpp91
-rw-r--r--host/apps/usrp2_burner.cpp84
-rwxr-xr-xhost/apps/usrp2_recovery.py52
5 files changed, 0 insertions, 323 deletions
diff --git a/host/apps/CMakeLists.txt b/host/apps/CMakeLists.txt
deleted file mode 100644
index f31206e1a..000000000
--- a/host/apps/CMakeLists.txt
+++ /dev/null
@@ -1,26 +0,0 @@
-#
-# Copyright 2010 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/>.
-#
-
-ADD_EXECUTABLE(discover_usrps discover_usrps.cpp)
-TARGET_LINK_LIBRARIES(discover_usrps uhd)
-INSTALL(TARGETS discover_usrps RUNTIME DESTINATION ${RUNTIME_DIR})
-
-ADD_EXECUTABLE(usrp2_burner usrp2_burner.cpp)
-TARGET_LINK_LIBRARIES(usrp2_burner uhd)
-
-ADD_EXECUTABLE(uhd_rx_timed_samples uhd_rx_timed_samples.cpp)
-TARGET_LINK_LIBRARIES(uhd_rx_timed_samples uhd)
diff --git a/host/apps/discover_usrps.cpp b/host/apps/discover_usrps.cpp
deleted file mode 100644
index d670d1651..000000000
--- a/host/apps/discover_usrps.cpp
+++ /dev/null
@@ -1,70 +0,0 @@
-//
-// Copyright 2010 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/device.hpp>
-#include <uhd/props.hpp>
-#include <boost/program_options.hpp>
-#include <boost/format.hpp>
-#include <iostream>
-
-namespace po = boost::program_options;
-
-int main(int argc, char *argv[]){
- po::options_description desc("Allowed options");
- desc.add_options()
- ("help", "help message")
- ("addr", po::value<std::string>(), "resolvable network address")
- ("node", po::value<std::string>(), "path to linux device node")
- ;
-
- 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("Discover USRPs %s") % desc << std::endl;
- return ~0;
- }
-
- //load the options into the address
- uhd::device_addr_t device_addr;
- if (vm.count("addr")){
- device_addr["addr"] = vm["addr"].as<std::string>();
- }
- if (vm.count("node")){
- device_addr["node"] = vm["node"].as<std::string>();
- }
-
- //discover the usrps and print the results
- uhd::device_addrs_t device_addrs = uhd::device::discover(device_addr);
-
- if (device_addrs.size() == 0){
- std::cerr << "No USRP Devices Found" << std::endl;
- return ~0;
- }
-
- for (size_t i = 0; i < device_addrs.size(); i++){
- std::cout << "--------------------------------------------------" << std::endl;
- std::cout << "-- USRP Device " << i << std::endl;
- std::cout << "--------------------------------------------------" << std::endl;
- std::cout << device_addrs[i] << std::endl << std::endl;
- uhd::device::make(device_addrs[i]); //test make
- }
-
- return 0;
-}
diff --git a/host/apps/uhd_rx_timed_samples.cpp b/host/apps/uhd_rx_timed_samples.cpp
deleted file mode 100644
index 97f75647e..000000000
--- a/host/apps/uhd_rx_timed_samples.cpp
+++ /dev/null
@@ -1,91 +0,0 @@
-//
-// Copyright 2010 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/simple_device.hpp>
-#include <uhd/props.hpp>
-#include <boost/program_options.hpp>
-#include <boost/format.hpp>
-#include <iostream>
-#include <complex>
-
-namespace po = boost::program_options;
-
-int main(int argc, char *argv[]){
- //variables to be set by po
- std::string transport_args;
- int seconds_in_future;
- size_t total_num_samps;
-
- //setup the program options
- po::options_description desc("Allowed options");
- desc.add_options()
- ("help", "help message")
- ("args", po::value<std::string>(&transport_args)->default_value(""), "simple uhd transport args")
- ("secs", po::value<int>(&seconds_in_future)->default_value(3), "number of seconds in the future to receive")
- ("nsamps", po::value<size_t>(&total_num_samps)->default_value(1000), "total number of samples to receive")
- ;
- 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 RX Timed Samples %s") % desc << std::endl;
- return ~0;
- }
-
- //create a usrp device
- std::cout << std::endl;
- std::cout << boost::format("Creating the usrp device with: %s...")
- % transport_args << std::endl;
- uhd::simple_device::sptr sdev = uhd::simple_device::make(transport_args);
- uhd::device::sptr dev = sdev->get_device();
- std::cout << boost::format("Using Device: %s") % sdev->get_name() << std::endl;
-
- //set properties on the device
- double rx_rate = sdev->get_rx_rates()[4]; //pick some rate
- std::cout << boost::format("Setting RX Rate: %f Msps...") % (rx_rate/1e6) << std::endl;
- sdev->set_rx_rate(rx_rate);
- std::cout << boost::format("Setting device timestamp to 0...") << std::endl;
- sdev->set_time_now(uhd::time_spec_t(0));
-
- //setup streaming
- std::cout << std::endl;
- std::cout << boost::format("Begin streaming %u seconds in the future...")
- % seconds_in_future << std::endl;
- sdev->set_streaming_at(uhd::time_spec_t(seconds_in_future));
-
- //loop until total number of samples reached
- size_t num_acc_samps = 0; //number of accumulated samples
- while(num_acc_samps < total_num_samps){
- uhd::rx_metadata_t md;
- std::complex<float> buff[1000];
- size_t num_rx_samps = dev->recv(boost::asio::buffer(buff, sizeof(buff)), md, "32fc");
- if (num_rx_samps == 0) continue; //wait for packets with contents
-
- std::cout << boost::format("Got packet: %u samples, %u secs, %u ticks")
- % num_rx_samps % md.time_spec.secs % md.time_spec.ticks << std::endl;
-
- num_acc_samps += num_rx_samps;
- }
-
- //finished, stop streaming
- sdev->set_streaming(false);
- std::cout << std::endl << "Done!" << std::endl << std::endl;
-
- return 0;
-}
diff --git a/host/apps/usrp2_burner.cpp b/host/apps/usrp2_burner.cpp
deleted file mode 100644
index 941e71d0c..000000000
--- a/host/apps/usrp2_burner.cpp
+++ /dev/null
@@ -1,84 +0,0 @@
-//
-// Copyright 2010 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/usrp/usrp2.hpp>
-#include <uhd/props.hpp>
-#include <boost/program_options.hpp>
-#include <boost/format.hpp>
-#include <iostream>
-
-namespace po = boost::program_options;
-
-int main(int argc, char *argv[]){
- po::options_description desc("Allowed options");
- desc.add_options()
- ("help", "help message")
- ("addr", po::value<std::string>(), "resolvable network address")
- ("new-ip", po::value<std::string>(), "new ip address (optional)")
- ("new-mac", po::value<std::string>(), "new mac address (optional)")
- ;
-
- 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("USRP2 Burner %s") % desc << std::endl;
- return ~0;
- }
-
- //load the options into the address
- uhd::device_addr_t device_addr;
- if (vm.count("addr")){
- device_addr["addr"] = vm["addr"].as<std::string>();
- }
- else{
- std::cerr << "Error: missing addr option" << std::endl;
- return ~0;
- }
-
- //create a usrp2 device
- uhd::device::sptr u2_dev = uhd::usrp::usrp2::make(device_addr);
- //FIXME usees the default mboard for now (until the mimo link is supported)
- wax::obj u2_mb = (*u2_dev)[uhd::DEVICE_PROP_MBOARD];
-
- //try to set the new ip (if provided)
- if (vm.count("new-ip")){
- std::cout << "Burning a new ip address into the usrp2 eeprom:" << std::endl;
- std::string old_ip = u2_mb[std::string("ip-addr")].as<std::string>();
- std::cout << boost::format(" Old IP Address: %s") % old_ip << std::endl;
- std::string new_ip = vm["new-ip"].as<std::string>();
- std::cout << boost::format(" New IP Address: %s") % new_ip << std::endl;
- u2_mb[std::string("ip-addr")] = new_ip;
- std::cout << " Done" << std::endl;
- }
-
- //try to set the new mac (if provided)
- if (vm.count("new-mac")){
- std::cout << "Burning a new mac address into the usrp2 eeprom:" << std::endl;
- std::string old_mac = u2_mb[std::string("mac-addr")].as<std::string>();
- std::cout << boost::format(" Old MAC Address: %s") % old_mac << std::endl;
- std::string new_mac = vm["new-mac"].as<std::string>();
- std::cout << boost::format(" New MAC Address: %s") % new_mac << std::endl;
- u2_mb[std::string("mac-addr")] = new_mac;
- std::cout << " Done" << std::endl;
- }
-
- std::cout << "Power-cycle the usrp2 for the changes to take effect." << std::endl;
- return 0;
-}
diff --git a/host/apps/usrp2_recovery.py b/host/apps/usrp2_recovery.py
deleted file mode 100755
index 48c1121cb..000000000
--- a/host/apps/usrp2_recovery.py
+++ /dev/null
@@ -1,52 +0,0 @@
-#!/usr/bin/env python
-
-"""
-The usrp2 recovery app:
-
-When the usrp2 has an unknown or bad ip address in its eeprom,
-it may not be possible to communicate with the usrp2 over ip/udp.
-
-This app will send a raw ethernet packet to bypass the ip layer.
-The packet will contain a known ip address to burn into eeprom.
-Because the recovery packet is sent with a broadcast mac address,
-only one usrp2 should be present on the interface upon execution.
-
-This app requires super-user privileges and only works on linux.
-"""
-
-import socket
-import struct
-import optparse
-
-BCAST_MAC_ADDR = 'ff:ff:ff:ff:ff:ff'
-RECOVERY_ETHERTYPE = 0xbeee
-IP_RECOVERY_CODE = 'addr'
-
-def mac_addr_repr_to_binary_string(mac_addr):
- return ''.join(map(lambda x: chr(int(x, 16)), mac_addr.split(':')))
-
-if __name__ == '__main__':
- parser = optparse.OptionParser(usage='usage: %prog [options]\n'+__doc__)
- parser.add_option('--ifc', type='string', help='ethernet interface name [default=%default]', default='eth0')
- parser.add_option('--new-ip', type='string', help='ip address to set [default=%default]', default='192.168.10.2')
- (options, args) = parser.parse_args()
-
- #create the raw socket
- print "Opening raw socket on interface:", options.ifc
- soc = socket.socket(socket.PF_PACKET, socket.SOCK_RAW)
- soc.bind((options.ifc, RECOVERY_ETHERTYPE))
-
- #create the recovery packet
- print "Loading packet with ip address:", options.new_ip
- packet = struct.pack(
- '!6s6sH4s4s',
- mac_addr_repr_to_binary_string(BCAST_MAC_ADDR),
- mac_addr_repr_to_binary_string(BCAST_MAC_ADDR),
- RECOVERY_ETHERTYPE,
- IP_RECOVERY_CODE,
- socket.inet_aton(options.new_ip),
- )
-
- print "Sending packet (%d bytes)"%len(packet)
- soc.send(packet)
- print "Done"