Files
rtems/testsuites/itrontests/itrontask04/init.c
Joel Sherrill 2f564fee64 2003-09-04 Joel Sherrill <joel@OARcorp.com>
* itronhello/init.c, itronhello/itronhello.doc, itronhello/system.h,
	itronmbf01/init.c, itronmbf01/itronmbf01.doc, itronmbf01/system.h,
	itronmbox01/init.c, itronmbox01/system.h, itronsem01/init.c,
	itronsem01/itronsem01.doc, itronsem01/system.h, itrontask01/init.c,
	itrontask01/itrontask01.doc, itrontask01/system.h,
	itrontask01/task1.c, itrontask02/dormant.c, itrontask02/init.c,
	itrontask02/itrontask02.doc, itrontask02/system.h,
	itrontask03/init.c, itrontask03/itrontask03.doc,
	itrontask03/preempt.c, itrontask03/system.h, itrontask03/task1.c,
	itrontask03/task2.c, itrontask03/task3.c, itrontask04/init.c,
	itrontask04/itrontask04.doc, itrontask04/system.h,
	itrontask04/task1.c, itrontask04/task2.c, itrontask04/task3.c,
	itrontime01/init.c, itrontime01/system.h: URL for license changed.
2003-09-04 18:53:25 +00:00

94 lines
2.6 KiB
C

/* Init
*
* This routine is the initialization task for this test program.
* It is called from init_exec 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: NONE
*
* 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.rtems.com/license/LICENSE.
*
* $Id$
*/
#define TEST_INIT
#include "system.h"
#include <stdio.h>
void ITRON_Init( void )
{
ER status;
T_CTSK pk_ctsk;
puts( "\n\n*** ITRON TASK TEST 4 ***" );
status = chg_pri( 0, 20 );
directive_failed( status, "chg_pri to 20" );
pk_ctsk.exinf = NULL;
pk_ctsk.tskatr = TA_HLNG;
pk_ctsk.stksz = RTEMS_MINIMUM_STACK_SIZE;
pk_ctsk.itskpri = 2;
pk_ctsk.task = Task_1;
status = cre_tsk( TA1_ID, &pk_ctsk );
directive_failed( status, "cre_tsk of TA1" );
pk_ctsk.task = Task_2;
status = cre_tsk( TA2_ID, &pk_ctsk );
directive_failed( status, "cre_tsk of TA2" );
pk_ctsk.itskpri = 1;
pk_ctsk.task = Task_3;
status = cre_tsk( TA3_ID, &pk_ctsk );
directive_failed( status, "cre_tsk of TA3" );
puts("INIT - dis_dsp while starting tasks");
status = dis_dsp( );
/* dispatching disabled */
directive_failed_with_level( status, "dis_dsp from ITRON_Init", 1 );
status = sta_tsk( TA1_ID, 0 );
directive_failed_with_level( status, "sta_tsk of TA1", 1 );
status = sta_tsk( TA2_ID, 0 );
directive_failed_with_level( status, "sta_tsk of TA2", 1 );
status = sta_tsk( TA3_ID, 0 );
directive_failed_with_level( status, "sta_tsk of TA3", 1 );
puts( "INIT - suspending TA2 3 times" );
status = sus_tsk( TA2_ID );
directive_failed_with_level( status, "sus_tsk of TA2", 1 );
status = sus_tsk( TA2_ID );
directive_failed_with_level( status, "sus_tsk of TA2", 1 );
status = sus_tsk( TA2_ID );
directive_failed_with_level( status, "sus_tsk of TA2", 1 );
puts("INIT - ena_dsp while starting tasks");
status = ena_dsp( );
/* dispatching enabled again */
puts( "INIT - suspending TA1 3 times" );
status = sus_tsk( TA1_ID );
directive_failed( status, "sus_tsk of TA2" );
status = sus_tsk( TA1_ID );
directive_failed( status, "sus_tsk of TA2" );
status = sus_tsk( TA1_ID );
directive_failed( status, "sus_tsk of TA2" );
puts("INIT - exd_tsk");
exd_tsk();
directive_failed( 0, "exd_tsk" );
}