aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/rfnoc/nocscript/block_iface.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/rfnoc/nocscript/block_iface.cpp')
-rw-r--r--host/lib/rfnoc/nocscript/block_iface.cpp176
1 files changed, 78 insertions, 98 deletions
diff --git a/host/lib/rfnoc/nocscript/block_iface.cpp b/host/lib/rfnoc/nocscript/block_iface.cpp
index f0a4e89b5..48adc8ab2 100644
--- a/host/lib/rfnoc/nocscript/block_iface.cpp
+++ b/host/lib/rfnoc/nocscript/block_iface.cpp
@@ -18,108 +18,81 @@
using namespace uhd::rfnoc;
using namespace uhd::rfnoc::nocscript;
-block_iface::block_iface(block_ctrl_base *block_ptr)
- : _block_ptr(block_ptr)
+block_iface::block_iface(block_ctrl_base* block_ptr) : _block_ptr(block_ptr)
{
function_table::sptr ft = function_table::make();
// Add the SR_WRITE() function
- expression_function::argtype_list_type sr_write_args = boost::assign::list_of
- (expression::TYPE_STRING)
- (expression::TYPE_INT)
- ;
- ft->register_function(
- "SR_WRITE",
+ expression_function::argtype_list_type sr_write_args =
+ boost::assign::list_of(expression::TYPE_STRING)(expression::TYPE_INT);
+ ft->register_function("SR_WRITE",
boost::bind(&block_iface::_nocscript__sr_write, this, _1),
expression::TYPE_BOOL,
- sr_write_args
- );
+ sr_write_args);
// Add read access to arguments ($foo)
- expression_function::argtype_list_type arg_set_args_wo_port = boost::assign::list_of
- (expression::TYPE_STRING)
- (expression::TYPE_INT)
- ;
- expression_function::argtype_list_type arg_set_args_w_port = boost::assign::list_of
- (expression::TYPE_STRING)
- (expression::TYPE_INT)
- (expression::TYPE_INT)
- ;
-#define REGISTER_ARG_SETTER(noctype, setter_func) \
- arg_set_args_wo_port[1] = expression::noctype; \
- arg_set_args_w_port[1] = expression::noctype; \
- ft->register_function( \
- "SET_ARG", \
+ expression_function::argtype_list_type arg_set_args_wo_port =
+ boost::assign::list_of(expression::TYPE_STRING)(expression::TYPE_INT);
+ expression_function::argtype_list_type arg_set_args_w_port = boost::assign::list_of(
+ expression::TYPE_STRING)(expression::TYPE_INT)(expression::TYPE_INT);
+#define REGISTER_ARG_SETTER(noctype, setter_func) \
+ arg_set_args_wo_port[1] = expression::noctype; \
+ arg_set_args_w_port[1] = expression::noctype; \
+ ft->register_function("SET_ARG", \
boost::bind(&block_iface::setter_func, this, _1), \
- expression::TYPE_BOOL, \
- arg_set_args_wo_port \
- ); \
- ft->register_function( \
- "SET_ARG", \
+ expression::TYPE_BOOL, \
+ arg_set_args_wo_port); \
+ ft->register_function("SET_ARG", \
boost::bind(&block_iface::setter_func, this, _1), \
- expression::TYPE_BOOL, \
- arg_set_args_w_port \
- );
- REGISTER_ARG_SETTER(TYPE_INT, _nocscript__arg_set_int);
- REGISTER_ARG_SETTER(TYPE_STRING, _nocscript__arg_set_string);
- REGISTER_ARG_SETTER(TYPE_DOUBLE, _nocscript__arg_set_double);
+ expression::TYPE_BOOL, \
+ arg_set_args_w_port);
+ REGISTER_ARG_SETTER(TYPE_INT, _nocscript__arg_set_int);
+ REGISTER_ARG_SETTER(TYPE_STRING, _nocscript__arg_set_string);
+ REGISTER_ARG_SETTER(TYPE_DOUBLE, _nocscript__arg_set_double);
REGISTER_ARG_SETTER(TYPE_INT_VECTOR, _nocscript__arg_set_intvec);
// Add read/write access to local variables
- expression_function::argtype_list_type set_var_args = boost::assign::list_of
- (expression::TYPE_STRING)
- (expression::TYPE_INT)
- ;
- const expression_function::argtype_list_type get_var_args = boost::assign::list_of
- (expression::TYPE_STRING)
- ;
-#define REGISTER_VAR_ACCESS(noctype, typestr) \
- set_var_args[1] = expression::noctype; \
- ft->register_function( \
- "SET_VAR", \
+ expression_function::argtype_list_type set_var_args =
+ boost::assign::list_of(expression::TYPE_STRING)(expression::TYPE_INT);
+ const expression_function::argtype_list_type get_var_args =
+ boost::assign::list_of(expression::TYPE_STRING);
+#define REGISTER_VAR_ACCESS(noctype, typestr) \
+ set_var_args[1] = expression::noctype; \
+ ft->register_function("SET_VAR", \
boost::bind(&block_iface::_nocscript__var_set, this, _1), \
- expression::TYPE_BOOL, \
- set_var_args \
- ); \
- ft->register_function( \
- "GET_"#typestr, \
+ expression::TYPE_BOOL, \
+ set_var_args); \
+ ft->register_function("GET_" #typestr, \
boost::bind(&block_iface::_nocscript__var_get, this, _1), \
- expression::noctype, \
- get_var_args \
- );
+ expression::noctype, \
+ get_var_args);
REGISTER_VAR_ACCESS(TYPE_INT, INT);
REGISTER_VAR_ACCESS(TYPE_STRING, STRING);
REGISTER_VAR_ACCESS(TYPE_DOUBLE, DOUBLE);
REGISTER_VAR_ACCESS(TYPE_INT_VECTOR, INT_VECTOR);
// Create the parser
- _parser = parser::make(
- ft,
+ _parser = parser::make(ft,
boost::bind(&block_iface::_nocscript__arg_get_type, this, _1),
- boost::bind(&block_iface::_nocscript__arg_get_val, this, _1)
- );
+ boost::bind(&block_iface::_nocscript__arg_get_val, this, _1));
}
-void block_iface::run_and_check(const std::string &code, const std::string &error_message)
+void block_iface::run_and_check(const std::string& code, const std::string& error_message)
{
boost::mutex::scoped_lock local_interpreter_lock(_lil_mutex);
- UHD_NOCSCRIPT_LOG() << "[NocScript] Executing and asserting code: " << code ;
- expression::sptr e = _parser->create_expr_tree(code);
+ UHD_NOCSCRIPT_LOG() << "[NocScript] Executing and asserting code: " << code;
+ expression::sptr e = _parser->create_expr_tree(code);
expression_literal result = e->eval();
if (not result.to_bool()) {
if (error_message.empty()) {
- throw uhd::runtime_error(str(
- boost::format("[NocScript] Code returned false: %s")
- % code
- ));
+ throw uhd::runtime_error(
+ str(boost::format("[NocScript] Code returned false: %s") % code));
} else {
- throw uhd::runtime_error(str(
- boost::format("[NocScript] Error: %s")
- % error_message
- ));
+ throw uhd::runtime_error(
+ str(boost::format("[NocScript] Error: %s") % error_message));
}
}
@@ -127,25 +100,26 @@ void block_iface::run_and_check(const std::string &code, const std::string &erro
}
-expression_literal block_iface::_nocscript__sr_write(expression_container::expr_list_type args)
+expression_literal block_iface::_nocscript__sr_write(
+ expression_container::expr_list_type args)
{
const std::string reg_name = args[0]->eval().get_string();
- const uint32_t reg_val = uint32_t(args[1]->eval().get_int());
- bool result = true;
+ const uint32_t reg_val = uint32_t(args[1]->eval().get_int());
+ bool result = true;
try {
- UHD_NOCSCRIPT_LOG() << "[NocScript] Executing SR_WRITE() " ;
+ UHD_NOCSCRIPT_LOG() << "[NocScript] Executing SR_WRITE() ";
_block_ptr->sr_write(reg_name, reg_val);
- } catch (const uhd::exception &e) {
- UHD_LOGGER_ERROR("RFNOC") << boost::format("[NocScript] Error while executing SR_WRITE(%s, 0x%X):\n%s")
- % reg_name % reg_val % e.what()
- ;
+ } catch (const uhd::exception& e) {
+ UHD_LOGGER_ERROR("RFNOC")
+ << boost::format("[NocScript] Error while executing SR_WRITE(%s, 0x%X):\n%s")
+ % reg_name % reg_val % e.what();
result = false;
}
return expression_literal(result);
}
-expression::type_t block_iface::_nocscript__arg_get_type(const std::string &varname)
+expression::type_t block_iface::_nocscript__arg_get_type(const std::string& varname)
{
const std::string var_type = _block_ptr->get_arg_type(varname);
if (var_type == "int") {
@@ -161,7 +135,7 @@ expression::type_t block_iface::_nocscript__arg_get_type(const std::string &varn
}
}
-expression_literal block_iface::_nocscript__arg_get_val(const std::string &varname)
+expression_literal block_iface::_nocscript__arg_get_val(const std::string& varname)
{
const std::string var_type = _block_ptr->get_arg_type(varname);
if (var_type == "int") {
@@ -177,46 +151,50 @@ expression_literal block_iface::_nocscript__arg_get_val(const std::string &varna
}
}
-expression_literal block_iface::_nocscript__arg_set_int(const expression_container::expr_list_type &args)
+expression_literal block_iface::_nocscript__arg_set_int(
+ const expression_container::expr_list_type& args)
{
const std::string var_name = args[0]->eval().get_string();
const int val = args[1]->eval().get_int();
- size_t port = 0;
+ size_t port = 0;
if (args.size() == 3) {
port = size_t(args[2]->eval().get_int());
}
- UHD_NOCSCRIPT_LOG() << "[NocScript] Setting $" << var_name ;
+ UHD_NOCSCRIPT_LOG() << "[NocScript] Setting $" << var_name;
_block_ptr->set_arg<int>(var_name, val, port);
return expression_literal(true);
}
-expression_literal block_iface::_nocscript__arg_set_string(const expression_container::expr_list_type &args)
+expression_literal block_iface::_nocscript__arg_set_string(
+ const expression_container::expr_list_type& args)
{
const std::string var_name = args[0]->eval().get_string();
const std::string val = args[1]->eval().get_string();
- size_t port = 0;
+ size_t port = 0;
if (args.size() == 3) {
port = size_t(args[2]->eval().get_int());
}
- UHD_NOCSCRIPT_LOG() << "[NocScript] Setting $" << var_name ;
+ UHD_NOCSCRIPT_LOG() << "[NocScript] Setting $" << var_name;
_block_ptr->set_arg<std::string>(var_name, val, port);
return expression_literal(true);
}
-expression_literal block_iface::_nocscript__arg_set_double(const expression_container::expr_list_type &args)
+expression_literal block_iface::_nocscript__arg_set_double(
+ const expression_container::expr_list_type& args)
{
const std::string var_name = args[0]->eval().get_string();
- const double val = args[1]->eval().get_double();
- size_t port = 0;
+ const double val = args[1]->eval().get_double();
+ size_t port = 0;
if (args.size() == 3) {
port = size_t(args[2]->eval().get_int());
}
- UHD_NOCSCRIPT_LOG() << "[NocScript] Setting $" << var_name ;
+ UHD_NOCSCRIPT_LOG() << "[NocScript] Setting $" << var_name;
_block_ptr->set_arg<double>(var_name, val, port);
return expression_literal(true);
}
-expression_literal block_iface::_nocscript__arg_set_intvec(const expression_container::expr_list_type &)
+expression_literal block_iface::_nocscript__arg_set_intvec(
+ const expression_container::expr_list_type&)
{
UHD_THROW_INVALID_CODE_PATH();
}
@@ -226,20 +204,22 @@ block_iface::sptr block_iface::make(uhd::rfnoc::block_ctrl_base* block_ptr)
return sptr(new block_iface(block_ptr));
}
-expression_literal block_iface::_nocscript__var_get(const expression_container::expr_list_type &args)
+expression_literal block_iface::_nocscript__var_get(
+ const expression_container::expr_list_type& args)
{
expression_literal expr = _vars[args[0]->eval().get_string()];
- //std::cout << "[NocScript] Getting var " << args[0]->eval().get_string() << " == " << expr ;
- //std::cout << "[NocScript] Type " << expr.infer_type() ;
- //return _vars[args[0]->eval().get_string()];
+ // std::cout << "[NocScript] Getting var " << args[0]->eval().get_string() << " == "
+ // << expr ; std::cout << "[NocScript] Type " << expr.infer_type() ; return
+ // _vars[args[0]->eval().get_string()];
return expr;
}
-expression_literal block_iface::_nocscript__var_set(const expression_container::expr_list_type &args)
+expression_literal block_iface::_nocscript__var_set(
+ const expression_container::expr_list_type& args)
{
_vars[args[0]->eval().get_string()] = args[1]->eval();
- //std::cout << "[NocScript] Set var " << args[0]->eval().get_string() << " to " << _vars[args[0]->eval().get_string()] ;
- //std::cout << "[NocScript] Type " << _vars[args[0]->eval().get_string()].infer_type() ;
+ // std::cout << "[NocScript] Set var " << args[0]->eval().get_string() << " to " <<
+ // _vars[args[0]->eval().get_string()] ; std::cout << "[NocScript] Type " <<
+ // _vars[args[0]->eval().get_string()].infer_type() ;
return expression_literal(true);
}
-