forked from Imagelibrary/rtems
* Per PR47 add support for buffered test output. This involved adding defines to redirect output to a buffer and dump it when full, at "test pause", and at exit. To avoid problems when redefining exit(), all tests were modified to call rtems_test_exit(). Some tests, notable psxtests, had to be modified to include the standard test macro .h file (pmacros.h or tmacros.h) to enable this support. * include/pmacros.h, psx01/task.c, psx02/init.c, psx02/task.c, psx03/init.c, psx04/init.c, psx05/init.c, psx06/init.c, psx07/init.c, psx08/task3.c, psx09/init.c, psx10/init.c, psx11/init.c, psx12/init.c, psx13/Makefile.am, psx13/main.c, psx13/test.c, psxcancel/init.c, psxchroot01/Makefile.am, psxchroot01/main.c, psxchroot01/test.c, psxfile01/Makefile.am, psxfile01/main.c, psxfile01/test.c, psxfile01/test_cat.c, psxfile01/test_extend.c, psxfile01/test_write.c, psxmount/Makefile.am, psxmount/main.c, psxmount/test.c, psxmsgq01/init.c, psxreaddir/Makefile.am, psxreaddir/main.c, psxreaddir/test.c, psxsem01/init.c, psxstat/Makefile.am, psxstat/main.c, psxstat/test.c, psxtime/main.c, psxtime/test.c, psxtimer/psxtimer.c: Modified.
94 lines
2.2 KiB
C
94 lines
2.2 KiB
C
/* Task_1_through_3
|
|
*
|
|
* This routine serves as a test task. It verifies the basic task
|
|
* switching capabilities of the executive.
|
|
*
|
|
* Input parameters:
|
|
* argument - task argument
|
|
*
|
|
* Output parameters: NONE
|
|
*
|
|
* COPYRIGHT (c) 1989-1999.
|
|
* On-Line Applications Research Corporation (OAR).
|
|
*
|
|
* The license and distribution terms for this file may be
|
|
* found in the file LICENSE in this distribution or at
|
|
* http://www.OARcorp.com/rtems/license.html.
|
|
*
|
|
* $Id$
|
|
*/
|
|
|
|
#include "system.h"
|
|
|
|
void Test_init_routine( void )
|
|
{
|
|
puts( "Test_init_routine: invoked" );
|
|
}
|
|
|
|
|
|
void *Task_1_through_3(
|
|
void *argument
|
|
)
|
|
{
|
|
int status;
|
|
pthread_once_t once = PTHREAD_ONCE_INIT;
|
|
|
|
puts( "Task_1: sched_yield to Init" );
|
|
status = sched_yield();
|
|
assert( !status );
|
|
|
|
/* switch to Task_1 */
|
|
|
|
/* now do some real testing */
|
|
|
|
empty_line();
|
|
|
|
/* get id of this thread */
|
|
|
|
Task_id = pthread_self();
|
|
printf( "Task_1: ID is 0x%08x\n", Task_id );
|
|
|
|
/* exercise pthread_equal */
|
|
|
|
status = pthread_equal( Task_id, Task_id );
|
|
if ( status )
|
|
puts( "Task_1: pthread_equal - match case passed" );
|
|
assert( status );
|
|
|
|
status = pthread_equal( Init_id, Task_id );
|
|
if ( !status )
|
|
puts( "Task_1: pthread_equal - different case passed" );
|
|
assert( !status );
|
|
|
|
puts( "Task_1: pthread_equal - first id bad" );
|
|
status = pthread_equal( -1, Task_id );
|
|
assert( !status );
|
|
|
|
puts( "Task_1: pthread_equal - second id bad" );
|
|
status = pthread_equal( Init_id, -1 );
|
|
assert( !status );
|
|
|
|
/* exercise pthread_once */
|
|
|
|
puts( "Task_1: pthread_once - EINVAL (NULL once_control)" );
|
|
status = pthread_once( NULL, Test_init_routine );
|
|
assert( status == EINVAL );
|
|
|
|
puts( "Task_1: pthread_once - EINVAL (NULL init_routine)" );
|
|
status = pthread_once( &once, NULL );
|
|
assert( status == EINVAL );
|
|
|
|
puts( "Task_1: pthread_once - SUCCESSFUL (init_routine executes)" );
|
|
status = pthread_once( &once, Test_init_routine );
|
|
assert( !status );
|
|
|
|
puts( "Task_1: pthread_once - SUCCESSFUL (init_routine does not execute)" );
|
|
status = pthread_once( &once, Test_init_routine );
|
|
assert( !status );
|
|
|
|
puts( "*** END OF POSIX TEST 1 ***" );
|
|
rtems_test_exit( 0 );
|
|
|
|
return NULL; /* just so the compiler thinks we returned something */
|
|
}
|