1
0
mirror of https://github.com/f4exb/sdrangel.git synced 2025-10-26 02:20:26 -04:00

Mew scope: trace memory interim state (2)

This commit is contained in:
f4exb 2017-02-24 08:31:25 +01:00
parent 4dc4ab493b
commit f86d11e2d1
3 changed files with 42 additions and 12 deletions

View File

@ -55,7 +55,8 @@ ScopeVisNG::ScopeVisNG(GLScopeNG* glScope) :
m_freeRun(true), m_freeRun(true),
m_maxTraceDelay(0), m_maxTraceDelay(0),
m_triggerOneShot(false), m_triggerOneShot(false),
m_triggerWaitForReset(false) m_triggerWaitForReset(false),
m_currentTraceMemoryIndex(0)
{ {
setObjectName("ScopeVisNG"); setObjectName("ScopeVisNG");
m_traceDiscreteMemory.resize(m_traceChunkSize); // arbitrary m_traceDiscreteMemory.resize(m_traceChunkSize); // arbitrary
@ -163,14 +164,14 @@ void ScopeVisNG::feed(const SampleVector::const_iterator& cbegin, const SampleVe
else if (m_triggerState == TriggerUntriggered) { else if (m_triggerState == TriggerUntriggered) {
m_triggerPoint = end; m_triggerPoint = end;
} }
else if (m_triggerWaitForReset) { else if ((m_triggerWaitForReset) || (m_currentTraceMemoryIndex > 0)) {
m_triggerPoint = end; m_triggerPoint = end;
} }
else { else {
m_triggerPoint = cbegin; m_triggerPoint = cbegin;
} }
if (m_triggerWaitForReset) { if ((m_triggerWaitForReset) || (m_currentTraceMemoryIndex > 0)) {
return; return;
} }
@ -205,6 +206,19 @@ void ScopeVisNG::feed(const SampleVector::const_iterator& cbegin, const SampleVe
m_mutex.unlock(); m_mutex.unlock();
} }
void ScopeVisNG::processMemoryTrace()
{
if ((m_currentTraceMemoryIndex > 0) && (m_currentTraceMemoryIndex < m_nbTraceMemories))
{
SampleVector::const_iterator mend = m_traceDiscreteMemory.at(m_currentTraceMemoryIndex).m_endPoint;
SampleVector::const_iterator mbegin = mend - m_traceSize;
SampleVector::const_iterator mbegin_tb = mbegin - m_maxTraceDelay;
processTraces(mbegin_tb, mbegin, true); // traceback
processTraces(mbegin, mend, false);
}
}
void ScopeVisNG::processTrace(const SampleVector::const_iterator& cbegin, const SampleVector::const_iterator& end, int& triggerPointToEnd) void ScopeVisNG::processTrace(const SampleVector::const_iterator& cbegin, const SampleVector::const_iterator& end, int& triggerPointToEnd)
{ {
SampleVector::const_iterator begin(cbegin); SampleVector::const_iterator begin(cbegin);
@ -638,6 +652,15 @@ bool ScopeVisNG::handleMessage(const Message& message)
{ {
MsgScopeVisNGMemoryTrace& conf = (MsgScopeVisNGMemoryTrace&) message; MsgScopeVisNGMemoryTrace& conf = (MsgScopeVisNGMemoryTrace&) message;
uint32_t memoryIndex = conf.getMemoryIndex(); uint32_t memoryIndex = conf.getMemoryIndex();
if (memoryIndex != m_currentTraceMemoryIndex)
{
m_currentTraceMemoryIndex = memoryIndex;
if (m_currentTraceMemoryIndex > 0) {
}
}
} }
else else
{ {

View File

@ -684,6 +684,14 @@ private:
return m_traceBackBuffers[m_currentMemIndex]; return m_traceBackBuffers[m_currentMemIndex];
} }
/**
* Return trace at given memory position
*/
TraceBackBuffer& at(int index)
{
return m_traceBackBuffers[index];
}
/** /**
* Return current memory index * Return current memory index
*/ */
@ -926,6 +934,7 @@ private:
Real m_projectorCache[(int) nbProjectionTypes]; Real m_projectorCache[(int) nbProjectionTypes];
bool m_triggerOneShot; //!< True when one shot mode is active bool m_triggerOneShot; //!< True when one shot mode is active
bool m_triggerWaitForReset; //!< In one shot mode suspended until reset by UI bool m_triggerWaitForReset; //!< In one shot mode suspended until reset by UI
uint32_t m_currentTraceMemoryIndex; //!< The current index of trace in memory (0: current)
/** /**
* Moves on to the next trigger if any or increments trigger count if in repeat mode * Moves on to the next trigger if any or increments trigger count if in repeat mode
@ -939,6 +948,11 @@ private:
*/ */
void processTrace(const SampleVector::const_iterator& begin, const SampleVector::const_iterator& end, int& triggerPointToEnd); void processTrace(const SampleVector::const_iterator& begin, const SampleVector::const_iterator& end, int& triggerPointToEnd);
/**
* process a trace in memory at current trace index in memory
*/
void processMemoryTrace();
/** /**
* Process traces from complex trace memory buffer. * Process traces from complex trace memory buffer.
* - if finished it returns the number of unprocessed samples left in the buffer * - if finished it returns the number of unprocessed samples left in the buffer

View File

@ -669,15 +669,8 @@ void GLScopeNGGUI::on_mem_valueChanged(int value)
QString text; QString text;
text.sprintf("%02d", value); text.sprintf("%02d", value);
ui->memText->setText(text); ui->memText->setText(text);
disableLiveMode(value > 0); // block trigger UI line if memory is active
if (value > 0) m_scopeVis->setMemoryIndex(value);
{
disableLiveMode(true); // block trigger UI line
}
else
{
disableLiveMode(false); // unblock trigger UI line
}
} }
void GLScopeNGGUI::on_trigMode_currentIndexChanged(int index) void GLScopeNGGUI::on_trigMode_currentIndexChanged(int index)