source: rtems/testsuites/sptests/sp04/init.c @ 46c23871

5
Last change on this file since 46c23871 was 46c23871, checked in by Sebastian Huber <sebastian.huber@…>, on 06/16/20 at 05:28:58

rtems: Remove RTEMS_MP_NOT_CONFIGURED error

Some objects can be created with a local or global scope in a
multiprocessing network. In non-multiprocessing configurations setting
the scope to local or global had no effect since such a system can be
viewed as a multiprocessing network with just one node. One and all
nodes is the same in such a network. However, if multiprocessing was
configured, creation of a global object in a single node network
resulted in an RTEMS_MP_NOT_CONFIGURED error. Remove this error
condition for symmetry to the non-multiprocessing setup. This is in line
with the task affinity behaviour in SMP systems.

Update #4005.

  • Property mode set to 100644
File size: 3.1 KB
Line 
1/*  Init
2 *
3 *  This routine is the initialization task for this test program.
4 *  It is a user initialization task and has the responsibility for creating
5 *  and starting the tasks that make up the test.  If the time of day
6 *  clock is required for the test, it should also be set to a known
7 *  value by this function.
8 *
9 *  Input parameters:
10 *    argument - task argument
11 *
12 *  Output parameters:  NONE
13 *
14 *  COPYRIGHT (c) 1989-1999.
15 *  On-Line Applications Research Corporation (OAR).
16 *
17 *  The license and distribution terms for this file may be
18 *  found in the file LICENSE in this distribution or at
19 *  http://www.rtems.org/license/LICENSE.
20 */
21
22#ifdef HAVE_CONFIG_H
23#include "config.h"
24#endif
25
26#define CONFIGURE_INIT
27#include "system.h"
28
29const char rtems_test_name[] = "SP 4";
30
31rtems_extensions_table Extensions = {
32  NULL,                      /* task create user extension */
33  NULL,                      /* task start user extension */
34  NULL,                      /* task restart user extension */
35  NULL,                      /* task delete user extension */
36  Task_switch,               /* task switch user extension */
37  NULL,                      /* task begin user extension */
38  NULL,                      /* task exitted user extension */
39  NULL                       /* fatal error user extension */
40};
41
42rtems_task Init(
43  rtems_task_argument argument
44)
45{
46  rtems_status_code status;
47  rtems_time_of_day time;
48
49  TEST_BEGIN();
50  build_time( &time, 12, 31, 1988, 9, 15, 0, 0 );
51
52  status = rtems_clock_set( &time );
53  directive_failed( status, "rtems_clock_set" );
54
55  Extension_name[ 1 ] =  rtems_build_name( 'E', 'X', 'T', ' ' );
56
57  status = rtems_extension_create(
58    Extension_name[ 1 ],
59    &Extensions,
60    &Extension_id[ 1 ]
61  );
62  directive_failed( status, "rtems_extension_create" );
63
64  Task_name[ 1 ] =  rtems_build_name( 'T', 'A', '1', ' ' );
65  Task_name[ 2 ] =  rtems_build_name( 'T', 'A', '2', ' ' );
66  Task_name[ 3 ] =  rtems_build_name( 'T', 'A', '3', ' ' );
67
68  Run_count[ 1 ] = 0;
69  Run_count[ 2 ] = 0;
70  Run_count[ 3 ] = 0;
71
72  status = rtems_task_create(
73     Task_name[ 1 ],
74     1,
75     RTEMS_MINIMUM_STACK_SIZE * 2,
76     RTEMS_PREEMPT|RTEMS_TIMESLICE,
77     RTEMS_DEFAULT_ATTRIBUTES,
78     &Task_id[ 1 ]
79  );
80  directive_failed( status, "rtems_task_create of TA1" );
81
82  status = rtems_task_create(
83     Task_name[ 2 ],
84     1,
85     RTEMS_MINIMUM_STACK_SIZE * 2,
86     RTEMS_PREEMPT|RTEMS_TIMESLICE,
87     RTEMS_GLOBAL,
88     &Task_id[ 2 ]
89  );
90  directive_failed( status, "rtems_task_create of TA2" );
91
92  status = rtems_task_create(
93     Task_name[ 3 ],
94     1,
95     RTEMS_MINIMUM_STACK_SIZE * 2,
96     RTEMS_PREEMPT|RTEMS_TIMESLICE,
97     RTEMS_DEFAULT_ATTRIBUTES,
98     &Task_id[ 3 ]
99  );
100  directive_failed( status, "rtems_task_create of TA3" );
101
102  status = rtems_task_start( Task_id[ 1 ], Task_1, 0 );
103  directive_failed( status, "rtems_task_start of TA1" );
104
105  status = rtems_task_start( Task_id[ 2 ], Task_2, 0 );
106  directive_failed( status, "rtems_task_start of TA2" );
107
108  status = rtems_task_start( Task_id[ 3 ], Task_3, 0 );
109  directive_failed( status, "rtems_task_start of TA3" );
110
111  rtems_task_exit();
112}
Note: See TracBrowser for help on using the repository browser.