1 #include "lfds601_queue_internal.h"
\r
7 /****************************************************************************/
\r
8 void lfds601_queue_delete( struct lfds601_queue_state *qs, void (*user_data_delete_function)(void *user_data, void *user_state), void *user_state )
\r
13 assert( qs != NULL );
\r
14 // TRD : user_data_delete_function can be NULL
\r
15 // TRD : user_state can be NULL
\r
17 while( lfds601_queue_dequeue(qs, &user_data) )
\r
18 if( user_data_delete_function != NULL )
\r
19 user_data_delete_function( user_data, user_state );
\r
21 /* TRD : fully dequeuing will leave us
\r
22 with a single dummy element
\r
23 which both qs->enqueue and qs->dequeue point at
\r
24 we push this back onto the lfds601_freelist
\r
25 before we delete the lfds601_freelist
\r
28 lfds601_freelist_push( qs->fs, qs->enqueue[LFDS601_QUEUE_POINTER]->fe );
\r
30 lfds601_freelist_delete( qs->fs, lfds601_queue_internal_freelist_delete_function, NULL );
\r
32 lfds601_abstraction_aligned_free( qs );
\r
41 /****************************************************************************/
\r
42 #pragma warning( disable : 4100 )
\r
44 void lfds601_queue_internal_freelist_delete_function( void *user_data, void *user_state )
\r
46 assert( user_data != NULL );
\r
47 assert( user_state == NULL );
\r
49 lfds601_abstraction_aligned_free( user_data );
\r
54 #pragma warning( default : 4100 )
\r