diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2013-06-12 11:29:12 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2013-06-14 16:26:06 +0200 |
commit | ec978d97e028a538598f4b08b2e018d4912f0f7e (patch) | |
tree | c02e8520d2451bd79bdc05b63582fc62f994703b /testsuites | |
parent | rtems: Simplify rtems_task_mode() (diff) | |
download | rtems-ec978d97e028a538598f4b08b2e018d4912f0f7e.tar.bz2 |
score: Add _Chain_Insert_ordered_unprotected()
Diffstat (limited to 'testsuites')
-rw-r--r-- | testsuites/sptests/spchain/init.c | 34 | ||||
-rw-r--r-- | testsuites/sptests/spchain/spchain.doc | 1 | ||||
-rw-r--r-- | testsuites/sptests/spchain/spchain.scn | 1 |
3 files changed, 36 insertions, 0 deletions
diff --git a/testsuites/sptests/spchain/init.c b/testsuites/sptests/spchain/init.c index f8d54b0fa4..72895b6748 100644 --- a/testsuites/sptests/spchain/init.c +++ b/testsuites/sptests/spchain/init.c @@ -218,6 +218,39 @@ static void test_chain_node_count(void) } } +static bool test_order( const Chain_Node *left, const Chain_Node *right ) +{ + return left < right; +} + +static void test_chain_insert_ordered( void ) +{ + Chain_Control chain = CHAIN_INITIALIZER_EMPTY(chain); + Chain_Node nodes[5]; + const Chain_Node *tail; + const Chain_Node *node; + size_t n = RTEMS_ARRAY_SIZE( nodes ); + size_t i = 0; + + puts( "INIT - Verify _Chain_Insert_ordered_unprotected" ); + + _Chain_Insert_ordered_unprotected( &chain, &nodes[4], test_order ); + _Chain_Insert_ordered_unprotected( &chain, &nodes[2], test_order ); + _Chain_Insert_ordered_unprotected( &chain, &nodes[0], test_order ); + _Chain_Insert_ordered_unprotected( &chain, &nodes[3], test_order ); + _Chain_Insert_ordered_unprotected( &chain, &nodes[1], test_order ); + + tail = _Chain_Immutable_tail( &chain ); + node = _Chain_Immutable_first( &chain ); + while ( node != tail && i < n ) { + rtems_test_assert( node == &nodes[ i ] ); + ++i; + node = _Chain_Immutable_next( node ); + } + + rtems_test_assert( i == n ); +} + rtems_task Init( rtems_task_argument ignored ) @@ -260,6 +293,7 @@ rtems_task Init( test_chain_control_layout(); test_chain_control_initializer(); test_chain_node_count(); + test_chain_insert_ordered(); puts( "*** END OF RTEMS CHAIN API TEST ***" ); rtems_test_exit(0); diff --git a/testsuites/sptests/spchain/spchain.doc b/testsuites/sptests/spchain/spchain.doc index 29c9d1045c..8cf80892a5 100644 --- a/testsuites/sptests/spchain/spchain.doc +++ b/testsuites/sptests/spchain/spchain.doc @@ -24,6 +24,7 @@ directives: rtems_chain_get_with_notification rtems_chain_get_with_wait rtems_chain_node_count_unprotected + _Chain_Insert_ordered_unprotected concepts: diff --git a/testsuites/sptests/spchain/spchain.scn b/testsuites/sptests/spchain/spchain.scn index 9cf4d5212f..39f3795e20 100644 --- a/testsuites/sptests/spchain/spchain.scn +++ b/testsuites/sptests/spchain/spchain.scn @@ -13,4 +13,5 @@ INIT - Verify rtems_chain_get_with_wait INIT - Verify rtems_chain_control layout INIT - Verify rtems_chain_control initializer INIT - Verify rtems_chain_node_count_unprotected +INIT - Verify _Chain_Insert_ordered_unprotected *** END OF RTEMS CHAIN API TEST *** |