Commit fbfc2ef6 authored by multrus's avatar multrus
Browse files

Merge branch 'issue_1136_fix_race_condition_in_JBM' into 'main'

[Issue 1136] Fix for race condition in JBM allocate/free data unit

See merge request !1689
parents 69429235 e3e50e3c
Loading
Loading
Loading
Loading
Loading
+4 −0
Original line number Diff line number Diff line
@@ -381,9 +381,11 @@ JB4_DATAUNIT_HANDLE JB4_AllocDataUnit(
        JB4_dropFromBuffer( h );
    }

    /* LOCK JBM MEMORY SLOT BEGIN */
    --h->nFreeMemorySlots;
    dataUnit = h->freeMemorySlots[h->nFreeMemorySlots];
    h->freeMemorySlots[h->nFreeMemorySlots] = NULL;
    /* LOCK JBM MEMORY SLOT END */
    assert( dataUnit != NULL );

    return dataUnit;
@@ -397,8 +399,10 @@ void JB4_FreeDataUnit(
{
    assert( dataUnit != NULL );
    assert( h->nFreeMemorySlots < MAX_JBM_SLOTS );
    /* LOCK JBM MEMORY SLOT BEGIN */
    h->freeMemorySlots[h->nFreeMemorySlots] = dataUnit;
    h->nFreeMemorySlots++;
    /* LOCK JBM MEMORY SLOT END */

    return;
}
+18 −0
Original line number Diff line number Diff line
@@ -150,6 +150,24 @@ executables are "IVAS_cod.exe", "IVAS_dec.exe", "IVAS_rend.exe", and
"ISAR_post_rend.exe". All reside in the c-code main directory. 


                       INTEGRATION AS LIBRARIES
                       ========================

While this package contains the necessary applications to execute the IVAS encoder,
decoder, renderer and ISAR post renderer, it is envisioned that the libraries used
would be integrated into custom applications.

It should be noted that this library is not thread-safe by default. Thus, when using
the IVAS libraries in a multi-threaded environment, proper synchronization of API
calls is required to prevent race conditions by concurrent access to IVAS internal
state memory, FIFO queues buffers or any other data structures. Potential mechanisms
include e.g. mutexes, spinlocks and semaphores. The API calls are at the present not
optimized for fine-granular locking of just critical sections. Some sensitive
sections have thus been marked with a comment in the form /* LOCK XYZ BEGIN */ and
/* LOCK XYZ END */ to provide guidance where code could be modified to prevent
some potential race conditions.


                       RUNNING THE SOFTWARE
                       ====================