diff options
author | Josh Blum <josh@joshknows.com> | 2011-09-28 12:04:08 -0700 |
---|---|---|
committer | Josh Blum <josh@joshknows.com> | 2011-09-28 12:04:08 -0700 |
commit | 5098256a258623b2d0bb6aa54b923f22e92a178f (patch) | |
tree | 1bc0019735f0b1b557f5b573b4bbbe8713646ffd /host/lib/usrp/e100/e100_ctrl.cpp | |
parent | 0d9421b7ab57471d0bb223117413d01ac8299240 (diff) | |
download | uhd-5098256a258623b2d0bb6aa54b923f22e92a178f.tar.gz uhd-5098256a258623b2d0bb6aa54b923f22e92a178f.tar.bz2 uhd-5098256a258623b2d0bb6aa54b923f22e92a178f.zip |
e100: added support for internal gpsdo
Diffstat (limited to 'host/lib/usrp/e100/e100_ctrl.cpp')
-rw-r--r-- | host/lib/usrp/e100/e100_ctrl.cpp | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/host/lib/usrp/e100/e100_ctrl.cpp b/host/lib/usrp/e100/e100_ctrl.cpp index 87f7855d3..028e734e3 100644 --- a/host/lib/usrp/e100/e100_ctrl.cpp +++ b/host/lib/usrp/e100/e100_ctrl.cpp @@ -18,12 +18,14 @@ #include "e100_ctrl.hpp" #include "e100_regs.hpp" #include <uhd/exception.hpp> +#include <uhd/utils/log.hpp> #include <uhd/utils/msg.hpp> #include <sys/ioctl.h> //ioctl #include <fcntl.h> //open, close #include <linux/usrp_e.h> //ioctl structures and constants #include <boost/thread/thread.hpp> //sleep #include <boost/thread/mutex.hpp> +#include <boost/foreach.hpp> #include <boost/format.hpp> #include <fstream> @@ -175,6 +177,80 @@ uhd::i2c_iface::sptr e100_ctrl::make_dev_i2c_iface(const std::string &node){ } /*********************************************************************** + * UART control implementation + **********************************************************************/ +#include <termios.h> +#include <cstring> +class uart_dev_iface : public uart_iface{ +public: + uart_dev_iface(const std::string &node){ + if ((_node_fd = ::open(node.c_str(), O_RDWR | O_NONBLOCK)) < 0){ + throw uhd::io_error("Failed to open " + node); + } + + //init the tty settings w/ termios + termios tio; + std::memset(&tio,0,sizeof(tio)); + tio.c_iflag=0; + tio.c_oflag=0; + tio.c_cflag=CS8|CREAD|CLOCAL; // 8n1, see termios.h for more information + tio.c_lflag=0; + tio.c_cc[VMIN]=1; + tio.c_cc[VTIME]=5; + + cfsetospeed(&tio,B115200); // 115200 baud + cfsetispeed(&tio,B115200); // 115200 baud + + tcsetattr(_node_fd,TCSANOW,&tio); + } + + void write_uart(const std::string &buf){ + std::string out_str; + BOOST_FOREACH(const char &ch, buf){ + if (ch == '\n') out_str += "\r\n"; + else out_str += std::string(1, ch); + } + const ssize_t ret = ::write(_node_fd, out_str.c_str(), out_str.size()); + if (size_t(ret) != out_str.size()) UHD_LOG << ret; + } + + std::string read_uart(double timeout){ + const boost::system_time exit_time = boost::get_system_time() + boost::posix_time::milliseconds(long(timeout*1000)); + + std::string line; + while(true){ + char ch; + const ssize_t ret = ::read(_node_fd, &ch, 1); + + //got a character -> process it + if (ret == 1){ + const bool flush = ch == '\n' or ch == '\r'; + if (flush and line.empty()) continue; //avoid flushing on empty lines + line += std::string(1, ch); + if (flush) break; + } + + //didnt get a character, check the timeout + if (boost::get_system_time() > exit_time){ + break; + } + + //otherwise sleep for a bit + else{ + boost::this_thread::sleep(boost::posix_time::milliseconds(10)); + } + } + return line; + } + +private: int _node_fd; +}; + +uhd::uart_iface::sptr e100_ctrl::make_gps_uart_iface(const std::string &node){ + return uhd::uart_iface::sptr(new uart_dev_iface(node)); +} + +/*********************************************************************** * USRP-E100 control implementation **********************************************************************/ class e100_ctrl_impl : public e100_ctrl{ |