Fixed segmentation fault in Qt trace logger when changing from a large buffer size to a smaller buffer size. Ensure that buffer head and tail pointers are reset as well. Fixed memory leak with old trace log buffer not being freed when allocating the new buffer size.

This commit is contained in:
mjbudd77 2021-04-24 13:57:20 -04:00
parent 2169dd07fb
commit e2716ae2c5
1 changed files with 13 additions and 3 deletions

View File

@ -967,6 +967,11 @@ int initTraceLogBuffer(int maxRecs)
size = maxRecs * sizeof(traceRecord_t);
if ( recBuf != NULL )
{
free(recBuf); recBuf = NULL;
}
recBuf = (traceRecord_t *)malloc(size);
if (recBuf)
@ -978,6 +983,7 @@ int initTraceLogBuffer(int maxRecs)
{
recBufMax = 0;
}
recBufHead = recBufTail = 0;
}
return recBuf == NULL;
}
@ -1001,9 +1007,13 @@ static void pushToLogBuffer(traceRecord_t &rec)
recBuf[recBufHead] = rec;
recBufHead = (recBufHead + 1) % recBufMax;
if (recBufHead == recBufTail)
{
printf("Trace Log Overrun!!!\n");
if ( logging )
{ // Warning that an buffer overrun has occurred,
// This means that some instructions have not been written to the log.
if (recBufHead == recBufTail)
{
printf("Trace Log Overrun!!!\n");
}
}
}
//----------------------------------------------------