aboutsummaryrefslogtreecommitdiffstats
path: root/src/OfdmGenerator.cpp
diff options
context:
space:
mode:
authorMatthias P. Braendli <matthias.braendli@mpb.li>2024-10-29 22:55:41 +0100
committerMatthias P. Braendli <matthias.braendli@mpb.li>2024-10-29 22:55:41 +0100
commit933021ed44e6c1bd2cf1dee91fc033c145c061af (patch)
tree394a40921470502054b678924d060fc5b882fc91 /src/OfdmGenerator.cpp
parent004ff5c13515f61728245ccd3d1f281be987b041 (diff)
downloaddabmod-933021ed44e6c1bd2cf1dee91fc033c145c061af.tar.gz
dabmod-933021ed44e6c1bd2cf1dee91fc033c145c061af.tar.bz2
dabmod-933021ed44e6c1bd2cf1dee91fc033c145c061af.zip
Change to 16-bit fixed point
Diffstat (limited to 'src/OfdmGenerator.cpp')
-rw-r--r--src/OfdmGenerator.cpp30
1 files changed, 17 insertions, 13 deletions
diff --git a/src/OfdmGenerator.cpp b/src/OfdmGenerator.cpp
index 62a0ee5..4f6eeb9 100644
--- a/src/OfdmGenerator.cpp
+++ b/src/OfdmGenerator.cpp
@@ -633,8 +633,8 @@ OfdmGeneratorDEXTER::OfdmGeneratorDEXTER(size_t nbSymbols,
PDEBUG(" myZeroDst: %u\n", myZeroDst);
PDEBUG(" myZeroSize: %u\n", myZeroSize);
- const int N = mySpacing; // The size of the FFT
- const size_t nbytes = N * sizeof(complexfix);
+ const size_t nbytes = mySpacing * sizeof(complexfix);
+ fprintf(stderr, "sizeof(complexfix)=%zu\n", sizeof(complexfix));
#define IIO_ENSURE(expr, err) { \
if (!(expr)) { \
@@ -721,17 +721,6 @@ int OfdmGeneratorDEXTER::process(Buffer* const dataIn, Buffer* dataOut)
throw std::runtime_error("OfdmGenerator::process incorrect iio buffer size!");
}
- ptrdiff_t p_inc = iio_buffer_step(m_buf_out);
- if (p_inc != 1) {
- throw std::runtime_error("OfdmGenerator::process Wrong p_inc");
- }
-
- const uint8_t *fft_out = (const uint8_t*)iio_buffer_first(m_buf_out, m_channel_out);
- const uint8_t *fft_out_end = (const uint8_t*)iio_buffer_end(m_buf_out);
- if (((fft_out_end - fft_out) != (ssize_t)(mySpacing * sizeof(complexfix))) != 0) {
- throw std::runtime_error("OfdmGenerator::process fft_out length invalid!");
- }
-
complexfix *fft_in = reinterpret_cast<complexfix*>(iio_buffer_start(m_buf_in));
fft_in[0] = static_cast<complexfix::value_type>(0);
@@ -758,6 +747,21 @@ int OfdmGeneratorDEXTER::process(Buffer* const dataIn, Buffer* dataOut)
throw std::runtime_error("OfdmGenerator::process error refilling IIO buffer!");
}
+ fprintf(stderr, "IIO refill %zd\n", nbytes_rx);
+
+ ptrdiff_t p_inc = iio_buffer_step(m_buf_out);
+ if (p_inc != 1) {
+ throw std::runtime_error("OfdmGenerator::process Wrong p_inc");
+ }
+
+ const uint8_t *fft_out = (const uint8_t*)iio_buffer_first(m_buf_out, m_channel_out);
+ const uint8_t *fft_out_end = (const uint8_t*)iio_buffer_end(m_buf_out);
+ if ((fft_out_end - fft_out) != (ssize_t)(mySpacing * sizeof(complexfix))) {
+ fprintf(stderr, "FFT_OUT: %p %p %zu %zu\n",
+ fft_out, fft_out_end, (fft_out_end - fft_out), mySpacing * sizeof(complexfix));
+ throw std::runtime_error("OfdmGenerator::process fft_out length invalid!");
+ }
+
memcpy(out, fft_out, mySpacing * sizeof(complexfix));
in += myNbCarriers;