//
// Copyright 2014-2015 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
#include
using namespace uhd::rfnoc;
const double rate_node_ctrl::RATE_UNDEFINED = -1.0;
static double _get_input_samp_rate(rate_node_ctrl::sptr node, size_t port)
{
return node->get_input_samp_rate(port);
}
static double _get_output_samp_rate(rate_node_ctrl::sptr node, size_t port)
{
return node->get_output_samp_rate(port);
}
// FIXME add recursion limiters (i.e. list of explored nodes)
double rate_node_ctrl::get_input_samp_rate(
size_t /* port */
) {
try {
return find_downstream_unique_property(
boost::bind(_get_input_samp_rate, _1, _2),
RATE_UNDEFINED
);
} catch (const uhd::runtime_error &ex) {
throw uhd::runtime_error(str(
boost::format("Multiple sampling rates downstream of %s: %s.")
% unique_id() % ex.what()
));
}
}
double rate_node_ctrl::get_output_samp_rate(
size_t /* port */
) {
try {
return find_upstream_unique_property(
boost::bind(_get_output_samp_rate, _1, _2),
RATE_UNDEFINED
);
} catch (const uhd::runtime_error &ex) {
throw uhd::runtime_error(str(
boost::format("Multiple sampling rates upstream of %s: %s.")
% unique_id() % ex.what()
));
}
}