summaryrefslogtreecommitdiffstats
path: root/testsuites/sptests/sp14/task1.c
diff options
context:
space:
mode:
Diffstat (limited to 'testsuites/sptests/sp14/task1.c')
-rw-r--r--testsuites/sptests/sp14/task1.c116
1 files changed, 116 insertions, 0 deletions
diff --git a/testsuites/sptests/sp14/task1.c b/testsuites/sptests/sp14/task1.c
new file mode 100644
index 0000000000..ac8feed71f
--- /dev/null
+++ b/testsuites/sptests/sp14/task1.c
@@ -0,0 +1,116 @@
+/* Task_1
+ *
+ * This routine serves as a test task. It establishes an RTEMS_ASR and
+ * sends signal to itself to determine if the RTEMS_ASR gets to execute.
+ *
+ * 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"
+
+rtems_timer_service_routine Signal_3_to_task_1(
+ rtems_id id,
+ void *pointer
+)
+{
+ rtems_status_code status;
+
+ status = rtems_signal_send( Task_id[ 1 ], RTEMS_SIGNAL_3 );
+ directive_failed( status, "rtems_signal_send of 3" );
+
+ Timer_got_this_id = id;
+ Timer_got_this_pointer = pointer;
+
+ Signals_sent = TRUE;
+}
+
+rtems_task Task_1(
+ rtems_task_argument argument
+)
+{
+ rtems_mode previous_mode;
+ rtems_status_code status;
+
+ puts( "TA1 - rtems_signal_catch - RTEMS_INTERRUPT_LEVEL( 3 )" );
+ status = rtems_signal_catch( Process_asr, RTEMS_INTERRUPT_LEVEL(3) );
+ directive_failed( status, "rtems_signal_catch" );
+
+ puts( "TA1 - rtems_signal_send - RTEMS_SIGNAL_16 to self" );
+ status = rtems_signal_send( RTEMS_SELF, RTEMS_SIGNAL_16 );
+ directive_failed( status, "rtems_signal_send" );
+
+ puts( "TA1 - rtems_signal_send - RTEMS_SIGNAL_0 to self" );
+ status = rtems_signal_send( RTEMS_SELF, RTEMS_SIGNAL_0 );
+ directive_failed( status, "rtems_signal_send" );
+
+ puts( "TA1 - rtems_signal_catch - RTEMS_NO_ASR" );
+ status = rtems_signal_catch( Process_asr, RTEMS_NO_ASR );
+ directive_failed( status, "rtems_signal_catch" );
+
+pause();
+
+ puts( "TA1 - rtems_signal_send - RTEMS_SIGNAL_1 to self" );
+ status = rtems_signal_send( RTEMS_SELF, RTEMS_SIGNAL_1 );
+ directive_failed( status, "rtems_signal_send" );
+
+ puts( "TA1 - rtems_task_mode - disable ASRs" );
+ status = rtems_task_mode( RTEMS_NO_ASR, RTEMS_ASR_MASK, &previous_mode );
+ directive_failed( status, "rtems_task_mode" );
+
+ Timer_got_this_id = 0;
+ Timer_got_this_pointer = NULL;
+
+ puts( "TA1 - sending signal to RTEMS_SELF from timer" );
+ status = rtems_timer_fire_after(
+ Timer_id[ 1 ],
+ TICKS_PER_SECOND / 2,
+ Signal_3_to_task_1,
+ Task_1
+ );
+ directive_failed( status, "rtems_timer_fire_after" );
+
+ puts( "TA1 - waiting for signal to arrive" );
+
+ Signals_sent = FALSE;
+ Asr_fired = FALSE;
+
+ while ( Signals_sent == FALSE )
+ ;
+
+ if ( Timer_got_this_id == Timer_id[ 1 ] &&
+ Timer_got_this_pointer == Task_1 )
+ puts( "TA1 - timer routine got the correct arguments" );
+ else
+ printf(
+ "TA1 - timer got (0x%x, %p) instead of (0x%x, %p)!!!!\n",
+ Timer_got_this_id,
+ Timer_got_this_pointer,
+ Timer_id[ 1 ],
+ Task_1
+ );
+
+ puts( "TA1 - rtems_task_mode - enable ASRs" );
+ status = rtems_task_mode( RTEMS_ASR, RTEMS_ASR_MASK, &previous_mode );
+ directive_failed( status, "rtems_task_mode" );
+
+ puts( "TA1 - rtems_signal_catch - asraddr of NULL" );
+ status = rtems_signal_catch( NULL, RTEMS_DEFAULT_MODES );
+ directive_failed( status, "rtems_signal_catch" );
+
+ puts( "TA1 - rtems_task_delete - delete self" );
+ status = rtems_task_delete( RTEMS_SELF );
+ directive_failed( status, "rtems_task_delete of RTEMS_SELF" );
+}