mirror of
https://github.com/FreeRTOS/FreeRTOS-Kernel.git
synced 2025-10-23 21:27:45 -04:00
Replace configASSERT( pcQueueName ) in vQueueAddToRegistry with a NULL pointer check. (#313)
* Replace configASSERT( pcQueueName ) in vQueueAddToRegistry with a NULL pointer check. Fixes FreeRTOS/FreeRTOS-Kernel#311 * Make NULL checks consistent.
This commit is contained in:
parent
99295c9ae8
commit
46f7feba81
1 changed files with 20 additions and 18 deletions
38
queue.c
38
queue.c
|
@ -2728,32 +2728,34 @@ BaseType_t xQueueIsQueueFullFromISR( const QueueHandle_t xQueue )
|
|||
UBaseType_t ux;
|
||||
|
||||
configASSERT( xQueue );
|
||||
configASSERT( pcQueueName );
|
||||
|
||||
QueueRegistryItem_t * pxEntryToWrite = NULL;
|
||||
|
||||
/* See if there is an empty space in the registry. A NULL name denotes
|
||||
* a free slot. */
|
||||
for( ux = ( UBaseType_t ) 0U; ux < ( UBaseType_t ) configQUEUE_REGISTRY_SIZE; ux++ )
|
||||
if( pcQueueName != NULL )
|
||||
{
|
||||
/* Replace an existing entry if the queue is already in the registry. */
|
||||
if( xQueueRegistry[ ux ].xHandle == xQueue )
|
||||
/* See if there is an empty space in the registry. A NULL name denotes
|
||||
* a free slot. */
|
||||
for( ux = ( UBaseType_t ) 0U; ux < ( UBaseType_t ) configQUEUE_REGISTRY_SIZE; ux++ )
|
||||
{
|
||||
pxEntryToWrite = &( xQueueRegistry[ ux ] );
|
||||
break;
|
||||
}
|
||||
/* Otherwise, store in the next empty location */
|
||||
else if( ( NULL == pxEntryToWrite ) && ( xQueueRegistry[ ux ].pcQueueName == NULL ) )
|
||||
{
|
||||
pxEntryToWrite = &( xQueueRegistry[ ux ] );
|
||||
}
|
||||
else
|
||||
{
|
||||
mtCOVERAGE_TEST_MARKER();
|
||||
/* Replace an existing entry if the queue is already in the registry. */
|
||||
if( xQueue == xQueueRegistry[ ux ].xHandle )
|
||||
{
|
||||
pxEntryToWrite = &( xQueueRegistry[ ux ] );
|
||||
break;
|
||||
}
|
||||
/* Otherwise, store in the next empty location */
|
||||
else if( ( pxEntryToWrite == NULL ) && ( xQueueRegistry[ ux ].pcQueueName == NULL ) )
|
||||
{
|
||||
pxEntryToWrite = &( xQueueRegistry[ ux ] );
|
||||
}
|
||||
else
|
||||
{
|
||||
mtCOVERAGE_TEST_MARKER();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if( NULL != pxEntryToWrite )
|
||||
if( pxEntryToWrite == NULL )
|
||||
{
|
||||
/* Store the information on this queue. */
|
||||
pxEntryToWrite->pcQueueName = pcQueueName;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue