source: rtems/c/src/tests/sptests/spfatal/fatal.c @ d2b93bfd

4.104.114.84.95
Last change on this file since d2b93bfd was d2b93bfd, checked in by Joel Sherrill <joel.sherrill@…>, on 09/04/03 at 18:53:48

2003-09-04 Joel Sherrill <joel@…>

  • sp01/init.c, sp01/sp01.doc, sp01/system.h, sp01/task1.c, sp02/init.c, sp02/preempt.c, sp02/sp02.doc, sp02/system.h, sp02/task1.c, sp02/task2.c, sp02/task3.c, sp03/init.c, sp03/sp03.doc, sp03/system.h, sp03/task1.c, sp03/task2.c, sp04/init.c, sp04/sp04.doc, sp04/system.h, sp04/task1.c, sp04/task2.c, sp04/task3.c, sp04/tswitch.c, sp05/init.c, sp05/sp05.doc, sp05/system.h, sp05/task1.c, sp05/task2.c, sp05/task3.c, sp06/init.c, sp06/sp06.doc, sp06/system.h, sp06/task1.c, sp06/task2.c, sp06/task3.c, sp07/init.c, sp07/sp07.doc, sp07/system.h, sp07/task1.c, sp07/task2.c, sp07/task3.c, sp07/task4.c, sp07/taskexit.c, sp07/tcreate.c, sp07/tdelete.c, sp07/trestart.c, sp07/tstart.c, sp08/init.c, sp08/sp08.doc, sp08/system.h, sp08/task1.c, sp09/delay.c, sp09/init.c, sp09/isr.c, sp09/screen01.c, sp09/screen02.c, sp09/screen03.c, sp09/screen04.c, sp09/screen05.c, sp09/screen06.c, sp09/screen07.c, sp09/screen08.c, sp09/screen09.c, sp09/screen10.c, sp09/screen11.c, sp09/screen12.c, sp09/screen13.c, sp09/screen14.c, sp09/sp09.doc, sp09/system.h, sp09/task1.c, sp09/task2.c, sp09/task3.c, sp09/task4.c, sp11/init.c, sp11/sp11.doc, sp11/system.h, sp11/task1.c, sp11/task2.c, sp11/timer.c, sp12/init.c, sp12/pridrv.c, sp12/pritask.c, sp12/sp12.doc, sp12/system.h, sp12/task1.c, sp12/task2.c, sp12/task3.c, sp12/task4.c, sp12/task5.c, sp13/fillbuff.c, sp13/init.c, sp13/putbuff.c, sp13/sp13.doc, sp13/system.h, sp13/task1.c, sp13/task2.c, sp13/task3.c, sp14/asr.c, sp14/init.c, sp14/sp14.doc, sp14/system.h, sp14/task1.c, sp14/task2.c, sp15/init.c, sp15/sp15.doc, sp15/system.h, sp15/task1.c, sp16/init.c, sp16/sp16.doc, sp16/system.h, sp16/task1.c, sp16/task2.c, sp16/task3.c, sp16/task4.c, sp16/task5.c, sp17/asr.c, sp17/init.c, sp17/sp17.doc, sp17/system.h, sp17/task1.c, sp17/task2.c, sp19/first.c, sp19/fptask.c, sp19/fptest.h, sp19/init.c, sp19/inttest.h, sp19/sp19.doc, sp19/system.h, sp19/task1.c, sp20/getall.c, sp20/init.c, sp20/sp20.doc, sp20/system.h, sp20/task1.c, sp21/init.c, sp21/sp21.doc, sp21/system.h, sp21/task1.c, sp22/delay.c, sp22/init.c, sp22/prtime.c, sp22/sp22.doc, sp22/system.h, sp22/task1.c, sp23/init.c, sp23/sp23.doc, sp23/system.h, sp23/task1.c, sp24/init.c, sp24/resume.c, sp24/sp24.doc, sp24/system.h, sp24/task1.c, sp25/init.c, sp25/sp25.doc, sp25/system.h, sp25/task1.c, sp26/init.c, sp26/sp26.doc, sp26/system.h, sp26/task1.c, sp30/init.c, sp30/resume.c, sp30/sp30.doc, sp30/system.h, sp30/task1.c, sp31/delay.c, sp31/init.c, sp31/prtime.c, sp31/sp31.doc, sp31/system.h, sp31/task1.c, sp32/init.c, spfatal/fatal.c, spfatal/init.c, spfatal/puterr.c, spfatal/spfatal.doc, spfatal/system.h, spfatal/task1.c, spsize/getint.c, spsize/init.c, spsize/size.c, spsize/system.h: URL for license changed.
  • Property mode set to 100644
File size: 3.2 KB
Line 
1/*  Fatal Error Test
2 *
3 *  NOTE:
4 *
5 *  This test actually modifies the Configuration table and restarts
6 *  the executive.  It is very carefully constructed to do this and
7 *  uses the Configuration very carefully.
8 *
9 *  COPYRIGHT (c) 1989-1999.
10 *  On-Line Applications Research Corporation (OAR).
11 *
12 *  The license and distribution terms for this file may be
13 *  found in the file LICENSE in this distribution or at
14 *  http://www.rtems.com/license/LICENSE.
15 *
16 *  $Id$
17 */
18
19#include "system.h"
20
21#include <setjmp.h>
22
23char Workspace[ 64 * 1024 ] CPU_STRUCTURE_ALIGNMENT;
24
25typedef enum {
26  FATAL_WORKSPACE_OF_ZERO,
27  FATAL_NULL_WORKSPACE,
28  FATAL_WORKSPACE_TOO_SMALL,
29  FATAL_TASK_CREATE,
30  FATAL_TASK_START
31}  Fatal_errors_t;
32
33#define FATAL_LAST FATAL_TASK_START
34
35volatile Fatal_errors_t Case_in_switch;
36
37rtems_status_code Expected_Errors[] = {
38  RTEMS_UNSATISFIED,
39  RTEMS_INVALID_ADDRESS,
40  RTEMS_UNSATISFIED,
41  RTEMS_INVALID_PRIORITY,
42  RTEMS_TASK_EXITTED
43};
44
45rtems_status_code Error_Happened[ FATAL_LAST + 1];
46
47jmp_buf Restart_Context;
48
49/*
50 *  We depend on this being zeroed during initialization.  This
51 *  occurs automatically because this is part of the BSS.
52 */
53
54rtems_unsigned32  First_Time_Through;
55
56void Process_case();
57
58rtems_extension Fatal_extension(
59  rtems_unsigned32 source,
60  boolean          is_internal,
61  rtems_unsigned32 error
62)
63{
64  int index;
65
66  Error_Happened[ Case_in_switch ] = error;
67
68  if ( First_Time_Through == 0 ) {
69    Case_in_switch = FATAL_WORKSPACE_OF_ZERO;
70    First_Time_Through = 1;
71    setjmp( Restart_Context );
72  } else if ( Case_in_switch == FATAL_LAST ) {
73
74    /*
75     *  Depending on the C library we use, we cannot get the
76     *  task exitted error so do not check for it.
77     */
78
79    puts( "*** TEST FATAL ***" );
80    for ( index=0 ; index< FATAL_LAST ; index++ )
81      put_error( Error_Happened[ index ], Expected_Errors[ index ] );
82    puts( "NOT TESTING FATAL ERROR WHEN TASK EXITS -- C LIBRARY CATCHES THIS" );
83    puts( "*** END OF TEST FATAL ***" );
84
85    /*
86     *  returns to the default fatal error handler instead of
87     *  calling rtems_shutdown_executive
88     */
89    return;
90
91  } else {
92
93    longjmp( Restart_Context, 1 );
94  }
95
96  Process_case();
97}
98
99
100
101void Process_case()
102{
103  switch ( Case_in_switch ) {
104    case FATAL_WORKSPACE_OF_ZERO:
105      New_Configuration = rtems_configuration_get_table();
106      New_Configuration.work_space_start = NULL;
107      Case_in_switch = FATAL_NULL_WORKSPACE;
108      break;
109
110    case FATAL_NULL_WORKSPACE:
111      New_Configuration.work_space_start = Workspace;
112      New_Configuration.work_space_size  = 256;
113      Case_in_switch = FATAL_WORKSPACE_TOO_SMALL;
114      break;
115
116    case FATAL_WORKSPACE_TOO_SMALL:
117      Initialization_tasks[ 0 ].initial_priority = RTEMS_CURRENT_PRIORITY;
118      New_Configuration.work_space_size = sizeof( Workspace );
119      Case_in_switch = FATAL_TASK_CREATE;
120      break;
121
122    case FATAL_TASK_CREATE:
123      Initialization_tasks[ 0 ].initial_priority = 1;
124      Initialization_tasks[ 0 ].entry_point      = NULL;
125      Case_in_switch = FATAL_TASK_START;
126      break;
127
128    case FATAL_TASK_START:
129      /* this extension exits the test */
130      Initialization_tasks[ 0 ].entry_point = Init;
131      break;
132  }
133  rtems_initialize_executive(
134    &New_Configuration, rtems_cpu_configuration_get_table() );
135}
136
Note: See TracBrowser for help on using the repository browser.