From cee579077f2fbcc671e92d3c56b0e6caf20a52c6 Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Mon, 22 Jan 2018 10:05:39 -0800 Subject: ddc: duc: Factor out usage of boost::bind() Replace with lambdas. --- host/lib/rfnoc/ddc_block_ctrl_impl.cpp | 8 ++-- host/lib/rfnoc/duc_block_ctrl_impl.cpp | 78 ++++++++++++++++++++++------------ 2 files changed, 54 insertions(+), 32 deletions(-) (limited to 'host/lib') diff --git a/host/lib/rfnoc/ddc_block_ctrl_impl.cpp b/host/lib/rfnoc/ddc_block_ctrl_impl.cpp index 8697c84cf..4fb3d567e 100644 --- a/host/lib/rfnoc/ddc_block_ctrl_impl.cpp +++ b/host/lib/rfnoc/ddc_block_ctrl_impl.cpp @@ -1,5 +1,5 @@ // -// Copyright 2016 Ettus Research +// Copyright 2016-2018 Ettus Research, a National Instruments Company // // SPDX-License-Identifier: GPL-3.0 // @@ -20,7 +20,6 @@ using namespace uhd::rfnoc; class ddc_block_ctrl_impl : public ddc_block_ctrl { public: - UHD_RFNOC_BLOCK_CONSTRUCTOR(ddc_block_ctrl) , _fpga_compat(user_reg_read64(RB_REG_COMPAT_NUM)) , _num_halfbands(uhd::narrow_cast( @@ -41,14 +40,15 @@ public: // Argument/prop tree hooks for (size_t chan = 0; chan < get_input_ports().size(); chan++) { - double default_freq = get_arg("freq", chan); + const double default_freq = get_arg("freq", chan); _tree->access(get_arg_path("freq/value", chan)) .set_coercer([this, chan](const double value){ return this->set_freq(value, chan); }) .set(default_freq); ; - double default_output_rate = get_arg("output_rate", chan); + const double default_output_rate = + get_arg("output_rate", chan); _tree->access(get_arg_path("output_rate/value", chan)) .set_coercer([this, chan](const double value){ return this->set_output_rate(value, chan); diff --git a/host/lib/rfnoc/duc_block_ctrl_impl.cpp b/host/lib/rfnoc/duc_block_ctrl_impl.cpp index c8989d65c..fd6354419 100644 --- a/host/lib/rfnoc/duc_block_ctrl_impl.cpp +++ b/host/lib/rfnoc/duc_block_ctrl_impl.cpp @@ -1,5 +1,5 @@ // -// Copyright 2016 Ettus Research +// Copyright 2016-2018 Ettus Research, a National Instruments Company // // SPDX-License-Identifier: GPL-3.0 // @@ -17,21 +17,9 @@ using namespace uhd::rfnoc; -// TODO remove this once we have actual lambdas -static double lambda_forward_prop(uhd::property_tree::sptr tree, uhd::fs_path prop, double value) -{ - return tree->access(prop).set(value).get(); -} - -static double lambda_forward_prop(uhd::property_tree::sptr tree, uhd::fs_path prop) -{ - return tree->access(prop).get(); -} - class duc_block_ctrl_impl : public duc_block_ctrl { public: - UHD_RFNOC_BLOCK_CONSTRUCTOR(duc_block_ctrl) , _fpga_compat(user_reg_read64(RB_REG_COMPAT_NUM)) , _num_halfbands(uhd::narrow_cast( @@ -52,45 +40,78 @@ public: // Argument/prop tree hooks for (size_t chan = 0; chan < get_input_ports().size(); chan++) { - double default_freq = get_arg("freq", chan); + const double default_freq = get_arg("freq", chan); _tree->access(get_arg_path("freq/value", chan)) - .set_coercer(boost::bind(&duc_block_ctrl_impl::set_freq, this, _1, chan)) + .set_coercer([this, chan](const double value){ + return this->set_freq(value, chan); + }) .set(default_freq); ; - double default_input_rate = get_arg("input_rate", chan); + + const double default_input_rate = + get_arg("input_rate", chan); _tree->access(get_arg_path("input_rate/value", chan)) - .set_coercer(boost::bind(&duc_block_ctrl_impl::set_input_rate, this, _1, chan)) + .set_coercer([this, chan](const double value){ + return this->set_input_rate(value, chan); + }) .set(default_input_rate) ; _tree->access(get_arg_path("output_rate/value", chan)) - .add_coerced_subscriber(boost::bind(&duc_block_ctrl_impl::set_output_rate, this, _1, chan)) + .add_coerced_subscriber([this, chan](const double rate){ + this->set_output_rate(rate, chan); + }) ; // Legacy properties (for backward compat w/ multi_usrp) const uhd::fs_path dsp_base_path = _root_path / "legacy_api" / chan; // Legacy properties _tree->create(dsp_base_path / "rate/value") - .set_coercer(boost::bind(&lambda_forward_prop, _tree, get_arg_path("input_rate/value", chan), _1)) - .set_publisher(boost::bind(&lambda_forward_prop, _tree, get_arg_path("input_rate/value", chan))) + .set_coercer([this, chan](const double value){ + return this->_tree->access( + this->get_arg_path("input_rate/value", chan) + ).set(value).get(); + }) + .set_publisher([this, chan](){ + return this->_tree->access( + this->get_arg_path("input_rate/value", chan) + ).get(); + }) ; _tree->create(dsp_base_path / "rate/range") - .set_publisher(boost::bind(&duc_block_ctrl_impl::get_input_rates, this)) + .set_publisher([this](){ + return get_input_rates(); + }) ; _tree->create(dsp_base_path / "freq/value") - .set_coercer(boost::bind(&lambda_forward_prop, _tree, get_arg_path("freq/value", chan), _1)) - .set_publisher(boost::bind(&lambda_forward_prop, _tree, get_arg_path("freq/value", chan))) + .set_coercer([this, chan](const double value){ + return this->_tree->access( + this->get_arg_path("freq/value", chan) + ).set(value).get(); + }) + .set_publisher([this, chan](){ + return this->_tree->access( + this->get_arg_path("freq/value", chan) + ).get(); + }) ; _tree->create(dsp_base_path / "freq/range") - .set_publisher(boost::bind(&duc_block_ctrl_impl::get_freq_range, this)) + .set_publisher([this](){ + return get_freq_range(); + }) ; _tree->access("time/cmd") - .add_coerced_subscriber(boost::bind(&block_ctrl_base::set_command_time, this, _1, chan)) + .add_coerced_subscriber([this, chan](const uhd::time_spec_t time_spec){ + this->set_command_time(time_spec, chan); + }) ; if (_tree->exists("tick_rate")) { - const double tick_rate = _tree->access("tick_rate").get(); + const double tick_rate = + _tree->access("tick_rate").get(); set_command_tick_rate(tick_rate, chan); _tree->access("tick_rate") - .add_coerced_subscriber(boost::bind(&block_ctrl_base::set_command_tick_rate, this, _1, chan)) + .add_coerced_subscriber([this, chan](const double rate){ + this->set_command_tick_rate(rate, chan); + }) ; } @@ -100,7 +121,8 @@ public: sr_write("CONFIG", 1, chan); // Enable clear EOB } } // end ctor - virtual ~duc_block_ctrl_impl() {}; + + virtual ~duc_block_ctrl_impl() {} double get_input_scale_factor(size_t port=ANY_PORT) { -- cgit v1.2.3