forked from Imagelibrary/rtems
Rearranged code to created thread handler routines to initialize, start, restart, and "close/delete" a thread. Made internal threads their own object class. This now uses the thread support routines for starting and initializing a thread. Insured deleted tasks are freed to the Inactive pool associated with the correct Information block. Added an RTEMS API specific data area to the thread control block. Beginnings of removing the word "rtems" from the core.
109 lines
3.0 KiB
C
109 lines
3.0 KiB
C
/* Init
|
|
*
|
|
* This routine is the initialization and test routine for
|
|
* this test program. It attempts to create more global
|
|
* objects than are configured (zero should be configured).
|
|
* This routine is the initialization task for this test program.
|
|
* It is a user initialization task and has the responsibility for creating
|
|
* and starting the tasks that make up the test. If the time of day
|
|
* clock is required for the test, it should also be set to a known
|
|
* value by this function.
|
|
*
|
|
* Input parameters:
|
|
* argument - task argument
|
|
*
|
|
* Output parameters: NONE
|
|
*
|
|
* COPYRIGHT (c) 1989, 1990, 1991, 1992, 1993, 1994.
|
|
* On-Line Applications Research Corporation (OAR).
|
|
* All rights assigned to U.S. Government, 1994.
|
|
*
|
|
* This material may be reproduced by or for the U.S. Government pursuant
|
|
* to the copyright license under the clause at DFARS 252.227-7013. This
|
|
* notice must appear in all copies of this file and its derivatives.
|
|
*
|
|
* $Id$
|
|
*/
|
|
|
|
#include "system.h"
|
|
#undef EXTERN
|
|
#define EXTERN
|
|
#include "conftbl.h"
|
|
#include "gvar.h"
|
|
|
|
rtems_unsigned8 my_partition[0x30000] CPU_STRUCTURE_ALIGNMENT;
|
|
|
|
rtems_task Init(
|
|
rtems_task_argument argument
|
|
)
|
|
{
|
|
rtems_id junk_id;
|
|
rtems_status_code status;
|
|
|
|
printf(
|
|
"\n\n*** TEST 11 -- NODE %d ***\n",
|
|
Multiprocessing_configuration.node
|
|
);
|
|
|
|
Task_name[ 1 ] = rtems_build_name( '1', '1', '1', ' ' );
|
|
Task_name[ 2 ] = rtems_build_name( '2', '2', '2', ' ' );
|
|
|
|
Queue_name[ 1 ] = rtems_build_name( 'M', 'S', 'G', ' ' );
|
|
|
|
Semaphore_name[ 1 ] = rtems_build_name( 'S', 'E', 'M', ' ' );
|
|
|
|
if ( Multiprocessing_configuration.node == 1 ) {
|
|
puts( "Attempting to create Test_task (Global)" );
|
|
status = rtems_task_create(
|
|
Task_name[ 1 ],
|
|
1,
|
|
1024,
|
|
RTEMS_DEFAULT_MODES,
|
|
RTEMS_GLOBAL,
|
|
&junk_id
|
|
);
|
|
fatal_directive_status( status, RTEMS_TOO_MANY, "rtems_task_create" );
|
|
puts( "rtems_task_create correctly returned RTEMS_TOO_MANY" );
|
|
|
|
puts( "Attempting to create Message Queue (Global)" );
|
|
status = rtems_message_queue_create(
|
|
Queue_name[ 1 ],
|
|
3,
|
|
16,
|
|
RTEMS_GLOBAL,
|
|
&junk_id
|
|
);
|
|
fatal_directive_status(
|
|
status,
|
|
RTEMS_TOO_MANY,
|
|
"rtems_message_queue_create"
|
|
);
|
|
puts( "rtems_message_queue_create correctly returned RTEMS_TOO_MANY" );
|
|
|
|
puts( "Attempting to create Semaphore (Global)" );
|
|
status = rtems_semaphore_create(
|
|
Semaphore_name[ 1 ],
|
|
1,
|
|
RTEMS_GLOBAL,
|
|
RTEMS_NO_PRIORITY,
|
|
&junk_id
|
|
);
|
|
fatal_directive_status( status, RTEMS_TOO_MANY, "rtems_semaphore_create" );
|
|
puts( "rtems_semaphore_create correctly returned RTEMS_TOO_MANY" );
|
|
|
|
puts( "Attempting to create Partition (Global)" );
|
|
status = rtems_partition_create(
|
|
1,
|
|
(rtems_unsigned8 *) my_partition,
|
|
128,
|
|
64,
|
|
RTEMS_GLOBAL,
|
|
&junk_id
|
|
);
|
|
fatal_directive_status( status, RTEMS_TOO_MANY, "rtems_partition_create" );
|
|
puts( "rtems_partition_create correctly returned RTEMS_TOO_MANY" );
|
|
}
|
|
puts( "*** END OF TEST 11 ***" );
|
|
exit( 0 );
|
|
}
|