source: rtems/testsuites/sptests/sp14/task1.c @ e731068

4.104.115
Last change on this file since e731068 was e731068, checked in by Joel Sherrill <joel.sherrill@…>, on 09/25/09 at 13:26:35

2009-09-25 Joel Sherrill <joel.sherrill@…>

  • sp14/asr.c, sp14/sp14.doc, sp14/task1.c, sp14/task2.c: Adjust test to run when IO speed varies.
  • Property mode set to 100644
File size: 3.4 KB
Line 
1/*  Task_1
2 *
3 *  This routine serves as a test task.  It establishes an RTEMS_ASR and
4 *  sends signal to itself to determine if the RTEMS_ASR gets to execute.
5 *
6 *  Input parameters:
7 *    argument - task argument
8 *
9 *  Output parameters:  NONE
10 *
11 *  COPYRIGHT (c) 1989-2009.
12 *  On-Line Applications Research Corporation (OAR).
13 *
14 *  The license and distribution terms for this file may be
15 *  found in the file LICENSE in this distribution or at
16 *  http://www.rtems.com/license/LICENSE.
17 *
18 *  $Id$
19 */
20
21#include "system.h"
22
23rtems_timer_service_routine Signal_3_to_task_1(
24  rtems_id  id,
25  void     *pointer
26)
27{
28  rtems_status_code status;
29
30  status = rtems_signal_send( Task_id[ 1 ], RTEMS_SIGNAL_3 );
31  directive_failed_with_level( status, "rtems_signal_send of 3", 1 );
32
33  Timer_got_this_id  = id;
34  Timer_got_this_pointer = pointer;
35
36  Signals_sent = TRUE;
37}
38
39rtems_task Task_1(
40  rtems_task_argument argument
41)
42{
43  rtems_mode        previous_mode;
44  rtems_status_code status;
45
46  puts( "TA1 - rtems_signal_catch - RTEMS_INTERRUPT_LEVEL( 3 )" );
47  status = rtems_signal_catch( Process_asr, RTEMS_INTERRUPT_LEVEL(3) );
48  directive_failed( status, "rtems_signal_catch" );
49
50  puts( "TA1 - rtems_signal_send - RTEMS_SIGNAL_16 to self" );
51  status = rtems_signal_send( RTEMS_SELF, RTEMS_SIGNAL_16 );
52  directive_failed( status, "rtems_signal_send" );
53
54  puts( "TA1 - rtems_signal_send - RTEMS_SIGNAL_0 to self" );
55  status = rtems_signal_send( RTEMS_SELF, RTEMS_SIGNAL_0 );
56  directive_failed( status, "rtems_signal_send" );
57
58  puts( "TA1 - rtems_signal_catch - RTEMS_NO_ASR" );
59  status = rtems_signal_catch( Process_asr, RTEMS_NO_ASR );
60  directive_failed( status, "rtems_signal_catch" );
61
62  FLUSH_OUTPUT();
63
64rtems_test_pause();
65
66  puts( "TA1 - rtems_signal_send - RTEMS_SIGNAL_1 to self" );
67  status = rtems_signal_send( RTEMS_SELF, RTEMS_SIGNAL_1 );
68  directive_failed( status, "rtems_signal_send" );
69
70  puts( "TA1 - rtems_task_mode - disable ASRs" );
71  status = rtems_task_mode( RTEMS_NO_ASR, RTEMS_ASR_MASK, &previous_mode );
72  directive_failed( status, "rtems_task_mode" );
73
74  Timer_got_this_id = 0;
75  Timer_got_this_pointer = NULL;
76
77  puts( "TA1 - sending signal to RTEMS_SELF from timer" );
78  status = rtems_timer_fire_after(
79    Timer_id[ 1 ],
80    rtems_clock_get_ticks_per_second() / 2,
81    Signal_3_to_task_1,
82    (void *) Task_1
83  );
84  directive_failed( status, "rtems_timer_fire_after" );
85
86  puts( "TA1 - waiting for signal to arrive" );
87
88  Signals_sent = FALSE;
89  Asr_fired    = FALSE;
90
91  while ( Signals_sent == FALSE )
92    ;
93
94  if ( Timer_got_this_id == Timer_id[ 1 ] &&
95       Timer_got_this_pointer == Task_1 )
96    puts( "TA1 - timer routine got the correct arguments" );
97  else
98    printf(
99      "TA1 - timer got (0x%x, %p) instead of (0x%x, %p)!!!!\n",
100      Timer_got_this_id,
101      Timer_got_this_pointer,
102      Timer_id[ 1 ],
103      Task_1
104    );
105
106  puts( "TA1 - rtems_task_mode - enable ASRs" );
107  FLUSH_OUTPUT();
108  status = rtems_task_mode( RTEMS_ASR, RTEMS_ASR_MASK, &previous_mode );
109  directive_failed( status, "rtems_task_mode" );
110
111  status = rtems_task_wake_after(2 * rtems_clock_get_ticks_per_second());
112  directive_failed( status, "rtems_task_wake_after" );
113
114  puts( "TA1 - rtems_signal_catch - asraddr of NULL" );
115  status = rtems_signal_catch( NULL, RTEMS_DEFAULT_MODES );
116  directive_failed( status, "rtems_signal_catch" );
117
118  puts( "TA1 - rtems_task_delete - delete self" );
119  status = rtems_task_delete( RTEMS_SELF );
120  directive_failed( status, "rtems_task_delete of RTEMS_SELF" );
121}
Note: See TracBrowser for help on using the repository browser.