aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp/e300/e300_impl.cpp
diff options
context:
space:
mode:
authorTrung N Tran <trung.tran@ettus.com>2018-02-21 13:39:17 -0800
committerMartin Braun <martin.braun@ettus.com>2018-02-21 16:59:46 -0800
commitc208452c81685d8bb865202f3ab4f5461023a22e (patch)
tree159dda4605cf483f930079e3f9b4b50e4c1e4eeb /host/lib/usrp/e300/e300_impl.cpp
parent21cc92016c4d5c3ae99e8fb49c04793feb51c21e (diff)
downloaduhd-c208452c81685d8bb865202f3ab4f5461023a22e.tar.gz
uhd-c208452c81685d8bb865202f3ab4f5461023a22e.tar.bz2
uhd-c208452c81685d8bb865202f3ab4f5461023a22e.zip
x300,n230,e300: changes to adapt to new usrp API
Diffstat (limited to 'host/lib/usrp/e300/e300_impl.cpp')
-rw-r--r--host/lib/usrp/e300/e300_impl.cpp37
1 files changed, 31 insertions, 6 deletions
diff --git a/host/lib/usrp/e300/e300_impl.cpp b/host/lib/usrp/e300/e300_impl.cpp
index 7006994cc..24e9c6f82 100644
--- a/host/lib/usrp/e300/e300_impl.cpp
+++ b/host/lib/usrp/e300/e300_impl.cpp
@@ -521,14 +521,39 @@ e300_impl::e300_impl(const uhd::device_addr_t &device_addr)
// internal gpios
////////////////////////////////////////////////////////////////////
gpio_atr_3000::sptr fp_gpio = gpio_atr_3000::make(_radio_perifs[0].ctrl, radio::sr_addr(radio::FP_GPIO), radio::RB32_FP_GPIO);
- for(const gpio_attr_map_t::value_type attr: gpio_attr_map)
- {
- _tree->create<uint32_t>(mb_path / "gpio" / "INT0" / attr.second)
- .add_coerced_subscriber(boost::bind(&gpio_atr_3000::set_gpio_attr, fp_gpio, attr.first, _1))
- .set(0);
+ for(const auto& attr: gpio_attr_map){
+ switch (attr.first){
+ case usrp::gpio_atr::GPIO_SRC:
+ _tree->create<std::vector<std::string>>(mb_path / "gpio" / "INT0" / attr.second)
+ .set(std::vector<std::string>(32, usrp::gpio_atr::default_attr_value_map.at(attr.first)))
+ .add_coerced_subscriber([this](const std::vector<std::string> str_val){
+ throw uhd::runtime_error("This device does not support set SRC attribute.");
+ });
+ break;
+ case usrp::gpio_atr::GPIO_CTRL:
+ case usrp::gpio_atr::GPIO_DDR:
+ _tree->create<std::vector<std::string>>(mb_path / "gpio" / "INT0" / attr.second)
+ .set(std::vector<std::string>(32, usrp::gpio_atr::default_attr_value_map.at(attr.first)))
+ .add_coerced_subscriber([this, fp_gpio, attr](const std::vector<std::string> str_val){
+ uint32_t val = 0;
+ for(size_t i = 0 ; i < str_val.size() ; i++){
+ val += usrp::gpio_atr::gpio_attr_value_pair.at(attr.second).at(str_val[i])<<i;
+ }
+ fp_gpio->set_gpio_attr(attr.first, val);
+ });
+ break;
+ default:
+ _tree->create<uint32_t>(mb_path / "gpio" / "INT0" / attr.second)
+ .set(0)
+ .add_coerced_subscriber([this, fp_gpio, attr](const uint32_t val){
+ fp_gpio->set_gpio_attr(attr.first, val);
+ });
+ }
}
_tree->create<uint8_t>(mb_path / "gpio" / "INT0" / "READBACK")
- .set_publisher(boost::bind(&gpio_atr_3000::read_gpio, fp_gpio));
+ .set_publisher([this, fp_gpio](){
+ return fp_gpio->read_gpio();
+ });
////////////////////////////////////////////////////////////////////