summaryrefslogtreecommitdiffstats
path: root/src/output/Lime.cpp
diff options
context:
space:
mode:
authorF5OEO <evaristec@gmail.com>2018-12-13 15:13:23 +0000
committerF5OEO <evaristec@gmail.com>2018-12-13 15:13:23 +0000
commit899664c6d976958ad98cb3e09f90aae4f052466c (patch)
tree416c0a41f2f7737469379d47164f5fb0d1676aae /src/output/Lime.cpp
parenta91bb4387b1254e56de2ff64b2db3cda3d0a08e0 (diff)
downloaddabmod-899664c6d976958ad98cb3e09f90aae4f052466c.tar.gz
dabmod-899664c6d976958ad98cb3e09f90aae4f052466c.tar.bz2
dabmod-899664c6d976958ad98cb3e09f90aae4f052466c.zip
In progress, buffer management
Diffstat (limited to 'src/output/Lime.cpp')
-rw-r--r--src/output/Lime.cpp88
1 files changed, 72 insertions, 16 deletions
diff --git a/src/output/Lime.cpp b/src/output/Lime.cpp
index 78e756d..335adc2 100644
--- a/src/output/Lime.cpp
+++ b/src/output/Lime.cpp
@@ -50,7 +50,7 @@ Lime::Lime(SDRDeviceConfig& config) :
m_conf(config)
{
m_interpolate=m_conf.upsample;
- interpolatebuf=new complexf[200000*m_interpolate];
+
etiLog.level(info) <<
"Lime:Creating the device with: " <<
m_conf.device;
@@ -162,6 +162,23 @@ Lime::Lime(SDRDeviceConfig& config) :
}
break;
}
+ #define FRAME_LENGTH 196608
+ // FRAME DURATION is 96ms
+ unsigned int buffer_size = FRAME_LENGTH*m_interpolate*10; // We take 10 Frame buffer size Fifo
+ interpolatebuf=new complexf[FRAME_LENGTH*m_interpolate];
+ // Fifo seems to be round to multiple of SampleRate
+ m_tx_stream.channel = m_channel;
+ m_tx_stream.fifoSize = buffer_size;
+ m_tx_stream.throughputVsLatency = 1.0;
+ m_tx_stream.isTx = LMS_CH_TX;
+ m_tx_stream.dataFmt = lms_stream_t::LMS_FMT_F32;
+ if ( LMS_SetupStream(m_device, &m_tx_stream) < 0 )
+ {
+ etiLog.level(error) << "Error making LimeSDR device: %s " << LMS_GetLastErrorMessage();
+ throw std::runtime_error("Cannot Channel Activate LimeSDR output device");
+ }
+ LMS_StartStream(&m_tx_stream);
+ LMS_SetGFIR(m_device, LMS_CH_TX, m_channel, LMS_GFIR3, true);
}
Lime::~Lime()
@@ -316,15 +333,16 @@ double Lime::get_temperature(void) const
void Lime::transmit_frame(const struct FrameData& frame)
{
+
if (not m_device) throw runtime_error("Lime device not set up");
- if (not m_tx_stream_active)
+ /*if (not m_tx_stream_active)
{
- unsigned int buffer_size = 200000*m_interpolate;
-
+ unsigned int buffer_size = FRAME_LENGTH*m_interpolate*10; // We take 10 Frame buffer size Fifo
+ // Fifo seems to be round to multiple of SampleRate
m_tx_stream.channel = m_channel;
m_tx_stream.fifoSize = buffer_size;
- m_tx_stream.throughputVsLatency = 0.5;
+ m_tx_stream.throughputVsLatency = 0.8;
m_tx_stream.isTx = LMS_CH_TX;
m_tx_stream.dataFmt = lms_stream_t::LMS_FMT_F32;
@@ -333,10 +351,10 @@ void Lime::transmit_frame(const struct FrameData& frame)
etiLog.level(error) << "Error making LimeSDR device: %s " << LMS_GetLastErrorMessage();
throw std::runtime_error("Cannot Channel Activate LimeSDR output device");
}
- LMS_StartStream(&m_tx_stream);
+ //LMS_StartStream(&m_tx_stream);
LMS_SetGFIR(m_device, LMS_CH_TX, m_channel, LMS_GFIR3, true);
- m_tx_stream_active = true;
- }
+ m_tx_stream_active = false;
+ }*/
// The frame buffer contains bytes representing FC32 samples
const complexf *buf = reinterpret_cast<const complexf*>(frame.buf.data());
@@ -346,6 +364,48 @@ void Lime::transmit_frame(const struct FrameData& frame)
throw std::runtime_error("Lime: invalid buffer size");
}
+
+ lms_stream_status_t LimeStatus;
+ LMS_GetStreamStatus(&m_tx_stream,&LimeStatus);
+ overflows=LimeStatus.overrun;
+ underflows=LimeStatus.underrun;
+ late_packets=LimeStatus.droppedPackets;
+
+
+ etiLog.level(info) << LimeStatus.fifoFilledCount<< "/" << LimeStatus.fifoSize << ":" << numSamples << "Rate" << LimeStatus.linkRate /(2*2.0);
+ etiLog.level(info) << "overrun" << LimeStatus.overrun << "underun" << LimeStatus.underrun << "drop" << LimeStatus.droppedPackets;
+
+ /* if(LimeStatus.fifoFilledCount>LimeStatus.fifoSize-2*FRAME_LENGTH*m_interpolate) // Drop if Fifo is just 2 frames before fullness
+ {
+ etiLog.level(info) << "Fifo overflow : drop";
+ return;
+ }*/
+
+
+ if(LimeStatus.fifoFilledCount<FRAME_LENGTH*2*m_interpolate) // Wait if Fifo is just 2 frames before fullness
+ {
+ etiLog.level(info) << "Fifo underflow : duplicate for filling garbage";
+ for(size_t i=0;i<m_interpolate*10;i++)
+ LMS_SendStream( &m_tx_stream, buf, numSamples, NULL, 1000 );
+
+
+
+ }
+/*
+ if(LimeStatus.fifoFilledCount>=5*FRAME_LENGTH*m_interpolate) // Start if FIFO is half full
+ {
+
+ if(not m_tx_stream_active)
+ {
+ etiLog.level(info) << "Fifo OK : Normal running";
+ LMS_StartStream(&m_tx_stream);
+ m_tx_stream_active = true;
+ }
+
+ }
+*/
+
+
size_t num_sent=0;
if(m_interpolate==1)
num_sent= LMS_SendStream( &m_tx_stream, buf, numSamples, NULL, 1000 );
@@ -363,19 +423,15 @@ void Lime::transmit_frame(const struct FrameData& frame)
if (num_sent <= 0)
{
- etiLog.level(info) << num_sent;
+ etiLog.level(info) << "Underflow" << num_sent;
//throw std::runtime_error("Lime: Too Loonnnngg");
}
else
{
- //etiLog.level(info) << "OK" << num_sent;
+ //etiLog.level(info) << "OK" << num_sent;
}
- lms_stream_status_t LimeStatus;
- LMS_GetStreamStatus(&m_tx_stream,&LimeStatus);
- overflows=LimeStatus.overrun;
- underflows=LimeStatus.underrun;
- late_packets=LimeStatus.droppedPackets;
-
+
+
num_frames_modulated++;
}