// // Copyright 2010-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 . // #include "usrp2_impl.hpp" #include "usrp2_regs.hpp" #include "fw_common.h" #include #include #include #include #include #include #include #include //htonl and ntohl #include using namespace uhd; using namespace uhd::usrp; /*********************************************************************** * Helper Methods **********************************************************************/ void usrp2_mboard_impl::dboard_init(void){ //read the dboard eeprom to extract the dboard ids _rx_db_eeprom.load(*_iface, USRP2_I2C_ADDR_RX_DB); _tx_db_eeprom.load(*_iface, USRP2_I2C_ADDR_TX_DB); _gdb_eeprom.load(*_iface, USRP2_I2C_ADDR_TX_DB ^ 5); //create a new dboard interface and manager _dboard_iface = make_usrp2_dboard_iface(_iface, _clock_ctrl); _dboard_manager = dboard_manager::make( _rx_db_eeprom.id, ((_gdb_eeprom.id == dboard_id_t::none())? _tx_db_eeprom : _gdb_eeprom).id, _dboard_iface ); //load dboards _rx_dboard_proxy = wax_obj_proxy::make( boost::bind(&usrp2_mboard_impl::rx_dboard_get, this, _1, _2), boost::bind(&usrp2_mboard_impl::rx_dboard_set, this, _1, _2) ); _tx_dboard_proxy = wax_obj_proxy::make( boost::bind(&usrp2_mboard_impl::tx_dboard_get, this, _1, _2), boost::bind(&usrp2_mboard_impl::tx_dboard_set, this, _1, _2) ); } /*********************************************************************** * RX DBoard Properties **********************************************************************/ void usrp2_mboard_impl::rx_dboard_get(const wax::obj &key_, wax::obj &val){ named_prop_t key = named_prop_t::extract(key_); //handle the get request conditioned on the key switch(key.as()){ case DBOARD_PROP_NAME: val = _iface->get_cname() + " dboard (rx unit)"; return; case DBOARD_PROP_SUBDEV: val = _dboard_manager->get_rx_subdev(key.name); return; case DBOARD_PROP_SUBDEV_NAMES: val = _dboard_manager->get_rx_subdev_names(); return; case DBOARD_PROP_DBOARD_EEPROM: val = _rx_db_eeprom; return; case DBOARD_PROP_DBOARD_IFACE: val = _dboard_iface; return; case DBOARD_PROP_CODEC: val = _rx_codec_proxy->get_link(); return; case DBOARD_PROP_GAIN_GROUP: val = make_gain_group( _rx_db_eeprom.id, _dboard_manager->get_rx_subdev(key.name), _rx_codec_proxy->get_link(), GAIN_GROUP_POLICY_RX ); return; default: UHD_THROW_PROP_GET_ERROR(); } } void usrp2_mboard_impl::rx_dboard_set(const wax::obj &key, const wax::obj &val){ switch(key.as()){ case DBOARD_PROP_DBOARD_EEPROM: _rx_db_eeprom = val.as(); _rx_db_eeprom.store(*_iface, USRP2_I2C_ADDR_RX_DB); return; default: UHD_THROW_PROP_SET_ERROR(); } } /*********************************************************************** * TX DBoard Properties **********************************************************************/ void usrp2_mboard_impl::tx_dboard_get(const wax::obj &key_, wax::obj &val){ named_prop_t key = named_prop_t::extract(key_); //handle the get request conditioned on the key switch(key.as()){ case DBOARD_PROP_NAME: val = _iface->get_cname() + " dboard (tx unit)"; return; case DBOARD_PROP_SUBDEV: val = _dboard_manager->get_tx_subdev(key.name); return; case DBOARD_PROP_SUBDEV_NAMES: val = _dboard_manager->get_tx_subdev_names(); return; case DBOARD_PROP_DBOARD_EEPROM: val = _tx_db_eeprom; return; case DBOARD_PROP_GBOARD_EEPROM: val = _gdb_eeprom; return; case DBOARD_PROP_DBOARD_IFACE: val = _dboard_iface; return; case DBOARD_PROP_CODEC: val = _tx_codec_proxy->get_link(); return; case DBOARD_PROP_GAIN_GROUP: val = make_gain_group( _tx_db_eeprom.id, _dboard_manager->get_tx_subdev(key.name), _tx_codec_proxy->get_link(), GAIN_GROUP_POLICY_TX ); return; default: UHD_THROW_PROP_GET_ERROR(); } } void usrp2_mboard_impl::tx_dboard_set(const wax::obj &key, const wax::obj &val){ switch(key.as()){ case DBOARD_PROP_DBOARD_EEPROM: _tx_db_eeprom = val.as(); _tx_db_eeprom.store(*_iface, USRP2_I2C_ADDR_TX_DB); return; case DBOARD_PROP_GBOARD_EEPROM: _gdb_eeprom = val.as(); _gdb_eeprom.store(*_iface, USRP2_I2C_ADDR_TX_DB ^ 5); return; default: UHD_THROW_PROP_SET_ERROR(); } }