aboutsummaryrefslogtreecommitdiffstats
path: root/lib/bladerf/bladerf_sink_c.cc
diff options
context:
space:
mode:
authorSylvain Munaut <tnt@246tNt.com>2016-10-23 16:44:39 +0200
committerDimitri Stolnikov <horiz0n@gmx.net>2017-02-27 23:03:43 +0100
commit71846180f548bac7412ce0fede505672c343b2d5 (patch)
tree0d3320324aef0430e629beff3591a7b3f382ec05 /lib/bladerf/bladerf_sink_c.cc
parent43df1c98c4110a4d3b66ce867da7c21dbf1e6d58 (diff)
bladeRF: Use VOLK for type conversion
Signed-off-by: Sylvain Munaut <tnt@246tNt.com>
Diffstat (limited to 'lib/bladerf/bladerf_sink_c.cc')
-rw-r--r--lib/bladerf/bladerf_sink_c.cc7
1 files changed, 3 insertions, 4 deletions
diff --git a/lib/bladerf/bladerf_sink_c.cc b/lib/bladerf/bladerf_sink_c.cc
index 5c4b45f..7019629 100644
--- a/lib/bladerf/bladerf_sink_c.cc
+++ b/lib/bladerf/bladerf_sink_c.cc
@@ -38,6 +38,8 @@
#include <gnuradio/tags.h>
#include <gnuradio/sync_block.h>
+#include <volk/volk.h>
+
#include "arg_helpers.h"
#include "bladerf_sink_c.h"
@@ -259,10 +261,7 @@ int bladerf_sink_c::work( int noutput_items,
}
/* Convert floating point samples into fixed point */
- for (int i = 0; i < 2 * noutput_items;) {
- _conv_buf[i++] = (int16_t)(scaling * real(*in));
- _conv_buf[i++] = (int16_t)(scaling * imag(*in++));
- }
+ volk_32f_s32f_convert_16i(_conv_buf, (float*)in, scaling, 2 * noutput_items);
if (_use_metadata) {
ret = transmit_with_tags(noutput_items);