![]() |
Helixis 1.0
Task Programming API
|
#include "queue_internal.h"Go to the source code of this file.
Functions | |
| void | queue_query (struct queue_state *qs, enum queue_query_type query_type, void *query_input, void *query_output) |
| void | queue_internal_validate (struct queue_state *qs, struct validation_info *vi, enum data_structure_validity *queue_validity, enum data_structure_validity *freelist_validity) |
| void queue_internal_validate | ( | struct queue_state * | qs, |
| struct validation_info * | vi, | ||
| enum data_structure_validity * | queue_validity, | ||
| enum data_structure_validity * | freelist_validity | ||
| ) |
Definition at line 38 of file queue_query.c.
References and, queue_state::dequeue, freelist_query(), FREELIST_QUERY_ELEMENT_COUNT, FREELIST_QUERY_VALIDATE, queue_state::fs, validation_info::max_elements, validation_info::min_elements, queue_element::next, QUEUE_POINTER, VALIDITY_INVALID_ADDITIONAL_ELEMENTS, VALIDITY_INVALID_LOOP, VALIDITY_INVALID_MISSING_ELEMENTS, and VALIDITY_VALID.
Referenced by queue_query().
{
struct queue_element
*qe,
*qe_slow,
*qe_fast;
atom_t
element_count = 0,
total_elements;
struct validation_info
freelist_vi;
/* TRD : vi can be 0 */
*queue_validity = VALIDITY_VALID;
qe_slow = qe_fast = (struct queue_element *) qs->dequeue[QUEUE_POINTER];
/* TRD : first, check for a loop
we have two pointers
both of which start at the dequeue end of the queue
we enter a loop
and on each iteration
we advance one pointer by one element
and the other by two
we exit the loop when both pointers are 0
(have reached the end of the queue)
or
if we fast pointer 'sees' the slow pointer
which means we have a loop
*/
if( qe_slow != 0 )
do
{
qe_slow = qe_slow->next[QUEUE_POINTER];
if( qe_fast != 0 )
qe_fast = qe_fast->next[QUEUE_POINTER];
if( qe_fast != 0 )
qe_fast = qe_fast->next[QUEUE_POINTER];
}
while( qe_slow != 0 and qe_fast != qe_slow );
if( qe_fast != 0 and qe_slow != 0 and qe_fast == qe_slow )
*queue_validity = VALIDITY_INVALID_LOOP;
/* TRD : now check for expected number of elements
vi can be 0, in which case we do not check
we know we don't have a loop from our earlier check
*/
if( *queue_validity == VALIDITY_VALID and vi != 0 )
{
qe = (struct queue_element *) qs->dequeue[QUEUE_POINTER];
while( qe != 0 )
{
element_count++;
qe = (struct queue_element *) qe->next[QUEUE_POINTER];
}
/* TRD : remember there is a dummy element in the queue */
element_count--;
if( element_count < vi->min_elements )
*queue_validity = VALIDITY_INVALID_MISSING_ELEMENTS;
if( element_count > vi->max_elements )
*queue_validity = VALIDITY_INVALID_ADDITIONAL_ELEMENTS;
}
/* TRD : now we validate the freelist
we may be able to check for the expected number of
elements in the freelist
if the caller has given us an expected min and max
number of elements in the queue, then the total number
of elements in the freelist, minus that min and max,
gives us the expected number of elements in the
freelist
*/
if( vi != 0 )
{
freelist_query( qs->fs, FREELIST_QUERY_ELEMENT_COUNT, 0, (void *) &total_elements );
/* TRD : remember there is a dummy element in the queue */
total_elements--;
freelist_vi.min_elements = total_elements - vi->max_elements;
freelist_vi.max_elements = total_elements - vi->min_elements;
freelist_query( qs->fs, FREELIST_QUERY_VALIDATE, (void *) &freelist_vi, (void *) freelist_validity );
}
if( vi == 0 )
freelist_query( qs->fs, FREELIST_QUERY_VALIDATE, 0, (void *) freelist_validity );
return;
}
| void queue_query | ( | struct queue_state * | qs, |
| enum queue_query_type | query_type, | ||
| void * | query_input, | ||
| void * | query_output | ||
| ) |
Definition at line 10 of file queue_query.c.
References freelist_query(), FREELIST_QUERY_ELEMENT_COUNT, queue_state::fs, queue_internal_validate(), QUEUE_QUERY_ELEMENT_COUNT, and QUEUE_QUERY_VALIDATE.
Referenced by hlx_group_get_size().
{
/* TRD : query_type can be any value in its range */
/* TRD : query_input can be 0 */
switch( query_type )
{
case QUEUE_QUERY_ELEMENT_COUNT:
freelist_query( qs->fs, FREELIST_QUERY_ELEMENT_COUNT, 0, query_output );
break;
case QUEUE_QUERY_VALIDATE:
/* TRD : query_input can be 0 */
queue_internal_validate( qs, (struct validation_info *) query_input, (enum data_structure_validity *) query_output, ((enum data_structure_validity *) query_output)+1 );
break;
}
return;
}
1.7.4