source: rtems/testsuites/sptests/spsysinit01/init.c @ cef5675

5
Last change on this file since cef5675 was cef5675, checked in by Sebastian Huber <sebastian.huber@…>, on 12/14/15 at 10:47:47

Optional POSIX Cleanup initialization

Update #2408.

  • Property mode set to 100644
File size: 10.4 KB
Line 
1/*
2 * Copyright (c) 2015 embedded brains GmbH.  All rights reserved.
3 *
4 *  embedded brains GmbH
5 *  Dornierstr. 4
6 *  82178 Puchheim
7 *  Germany
8 *  <rtems@embedded-brains.de>
9 *
10 * The license and distribution terms for this file may be
11 * found in the file LICENSE in this distribution or at
12 * http://www.rtems.com/license/LICENSE.
13 */
14
15#ifdef HAVE_CONFIG_H
16  #include "config.h"
17#endif
18
19#include <assert.h>
20#include <pthread.h>
21#include <string.h>
22#include <stdlib.h>
23
24#include <rtems.h>
25#include <rtems/libio_.h>
26#include <rtems/sysinit.h>
27#include <rtems/test.h>
28
29#include <rtems/extensionimpl.h>
30#ifdef RTEMS_POSIX_API
31#include <rtems/posix/psignalimpl.h>
32#include <rtems/posix/pthreadimpl.h>
33#endif /* RTEMS_POSIX_API */
34#include <rtems/rtems/barrierimpl.h>
35#include <rtems/rtems/dpmemimpl.h>
36#include <rtems/rtems/messageimpl.h>
37#include <rtems/rtems/partimpl.h>
38#include <rtems/rtems/ratemonimpl.h>
39#include <rtems/rtems/regionimpl.h>
40#include <rtems/rtems/semimpl.h>
41#include <rtems/rtems/tasksimpl.h>
42#include <rtems/rtems/timerimpl.h>
43#include <rtems/score/apimutex.h>
44#include <rtems/score/chainimpl.h>
45#include <rtems/score/sysstate.h>
46#include <rtems/score/userextimpl.h>
47#include <rtems/score/wkspace.h>
48
49const char rtems_test_name[] = "SPSYSINIT 1";
50
51typedef enum {
52  BSP_WORK_AREAS_PRE,
53  BSP_WORK_AREAS_POST,
54  BSP_START_PRE,
55  BSP_START_POST,
56  INITIAL_EXTENSIONS_PRE,
57  INITIAL_EXTENSIONS_POST,
58  DATA_STRUCTURES_PRE,
59  DATA_STRUCTURES_POST,
60  USER_EXTENSIONS_PRE,
61  USER_EXTENSIONS_POST,
62  CLASSIC_TASKS_PRE,
63  CLASSIC_TASKS_POST,
64  CLASSIC_TIMER_PRE,
65  CLASSIC_TIMER_POST,
66  CLASSIC_SIGNAL_PRE,
67  CLASSIC_SIGNAL_POST,
68  CLASSIC_EVENT_PRE,
69  CLASSIC_EVENT_POST,
70  CLASSIC_MESSAGE_QUEUE_PRE,
71  CLASSIC_MESSAGE_QUEUE_POST,
72  CLASSIC_SEMAPHORE_PRE,
73  CLASSIC_SEMAPHORE_POST,
74  CLASSIC_PARTITION_PRE,
75  CLASSIC_PARTITION_POST,
76  CLASSIC_REGION_PRE,
77  CLASSIC_REGION_POST,
78  CLASSIC_DUAL_PORTED_MEMORY_PRE,
79  CLASSIC_DUAL_PORTED_MEMORY_POST,
80  CLASSIC_RATE_MONOTONIC_PRE,
81  CLASSIC_RATE_MONOTONIC_POST,
82  CLASSIC_BARRIER_PRE,
83  CLASSIC_BARRIER_POST,
84#ifdef RTEMS_POSIX_API
85  POSIX_SIGNALS_PRE,
86  POSIX_SIGNALS_POST,
87  POSIX_THREADS_PRE,
88  POSIX_THREADS_POST,
89  POSIX_CLEANUP_PRE,
90  POSIX_CLEANUP_POST,
91#endif /* RTEMS_POSIX_API */
92  IDLE_THREADS_PRE,
93  IDLE_THREADS_POST,
94  BSP_LIBC_PRE,
95  BSP_LIBC_POST,
96  BEFORE_DRIVERS_PRE,
97  BEFORE_DRIVERS_POST,
98  BSP_PRE_DRIVERS_PRE,
99  BSP_PRE_DRIVERS_POST,
100  DEVICE_DRIVERS_PRE,
101  DEVICE_DRIVERS_POST,
102  BSP_POST_DRIVERS_PRE,
103  BSP_POST_DRIVERS_POST,
104  INIT_TASK,
105  DONE
106} init_step;
107
108#define FIRST(x) \
109  static void x##_first(void); \
110  RTEMS_SYSINIT_ITEM( \
111    x##_first, \
112    x, \
113    RTEMS_SYSINIT_ORDER_FIRST \
114  ); \
115  static void x##_first(void)
116
117#define LAST(x) \
118  static void x##_last(void); \
119  RTEMS_SYSINIT_ITEM( \
120    x##_last, \
121    x, \
122    RTEMS_SYSINIT_ORDER_LAST \
123  ); \
124  static void x##_last(void)
125
126static init_step step;
127
128static void next_step(init_step expected)
129{
130  assert(step == expected);
131  step = expected + 1;
132}
133
134FIRST(RTEMS_SYSINIT_BSP_WORK_AREAS)
135{
136  rtems_test_begink();
137  assert(_Workspace_Area.area_begin == 0);
138  next_step(BSP_WORK_AREAS_PRE);
139}
140
141LAST(RTEMS_SYSINIT_BSP_WORK_AREAS)
142{
143  assert(_Workspace_Area.area_begin != 0);
144  next_step(BSP_WORK_AREAS_POST);
145}
146
147FIRST(RTEMS_SYSINIT_BSP_START)
148{
149  /*
150   * Since the work performed here is BSP-specific, there is no way to test pre
151   * and post conditions.
152   */
153  next_step(BSP_START_PRE);
154}
155
156LAST(RTEMS_SYSINIT_BSP_START)
157{
158  next_step(BSP_START_POST);
159}
160
161FIRST(RTEMS_SYSINIT_INITIAL_EXTENSIONS)
162{
163  assert(_Chain_Is_empty(&_User_extensions_Switches_list));
164  next_step(INITIAL_EXTENSIONS_PRE);
165}
166
167LAST(RTEMS_SYSINIT_INITIAL_EXTENSIONS)
168{
169  assert(!_Chain_Is_empty(&_User_extensions_Switches_list));
170  next_step(INITIAL_EXTENSIONS_POST);
171}
172
173FIRST(RTEMS_SYSINIT_DATA_STRUCTURES)
174{
175  assert(_RTEMS_Allocator_Mutex == NULL);
176  next_step(DATA_STRUCTURES_PRE);
177}
178
179LAST(RTEMS_SYSINIT_DATA_STRUCTURES)
180{
181  assert(_RTEMS_Allocator_Mutex != NULL);
182  next_step(DATA_STRUCTURES_POST);
183}
184
185FIRST(RTEMS_SYSINIT_USER_EXTENSIONS)
186{
187  assert(_Extension_Information.maximum == 0);
188  next_step(USER_EXTENSIONS_PRE);
189}
190
191LAST(RTEMS_SYSINIT_USER_EXTENSIONS)
192{
193  assert(_Extension_Information.maximum != 0);
194  next_step(USER_EXTENSIONS_POST);
195}
196
197FIRST(RTEMS_SYSINIT_CLASSIC_TASKS)
198{
199  assert(_RTEMS_tasks_Information.Objects.maximum == 0);
200  next_step(CLASSIC_TASKS_PRE);
201}
202
203LAST(RTEMS_SYSINIT_CLASSIC_TASKS)
204{
205  assert(_RTEMS_tasks_Information.Objects.maximum != 0);
206  next_step(CLASSIC_TASKS_POST);
207}
208
209FIRST(RTEMS_SYSINIT_CLASSIC_TIMER)
210{
211  assert(_Timer_Information.maximum == 0);
212  next_step(CLASSIC_TIMER_PRE);
213}
214
215LAST(RTEMS_SYSINIT_CLASSIC_TIMER)
216{
217  assert(_Timer_Information.maximum != 0);
218  next_step(CLASSIC_TIMER_POST);
219}
220
221FIRST(RTEMS_SYSINIT_CLASSIC_SIGNAL)
222{
223  /* There is nothing to do in case RTEMS_MULTIPROCESSING is not defined */
224  next_step(CLASSIC_SIGNAL_PRE);
225}
226
227LAST(RTEMS_SYSINIT_CLASSIC_SIGNAL)
228{
229  next_step(CLASSIC_SIGNAL_POST);
230}
231
232FIRST(RTEMS_SYSINIT_CLASSIC_EVENT)
233{
234  /* There is nothing to do in case RTEMS_MULTIPROCESSING is not defined */
235  next_step(CLASSIC_EVENT_PRE);
236}
237
238LAST(RTEMS_SYSINIT_CLASSIC_EVENT)
239{
240  next_step(CLASSIC_EVENT_POST);
241}
242
243FIRST(RTEMS_SYSINIT_CLASSIC_MESSAGE_QUEUE)
244{
245  assert(_Message_queue_Information.maximum == 0);
246  next_step(CLASSIC_MESSAGE_QUEUE_PRE);
247}
248
249LAST(RTEMS_SYSINIT_CLASSIC_MESSAGE_QUEUE)
250{
251  assert(_Message_queue_Information.maximum != 0);
252  next_step(CLASSIC_MESSAGE_QUEUE_POST);
253}
254
255FIRST(RTEMS_SYSINIT_CLASSIC_SEMAPHORE)
256{
257  assert(_Semaphore_Information.maximum == 0);
258  next_step(CLASSIC_SEMAPHORE_PRE);
259}
260
261LAST(RTEMS_SYSINIT_CLASSIC_SEMAPHORE)
262{
263  assert(_Semaphore_Information.maximum != 0);
264  next_step(CLASSIC_SEMAPHORE_POST);
265}
266
267FIRST(RTEMS_SYSINIT_CLASSIC_PARTITION)
268{
269  assert(_Partition_Information.maximum == 0);
270  next_step(CLASSIC_PARTITION_PRE);
271}
272
273LAST(RTEMS_SYSINIT_CLASSIC_PARTITION)
274{
275  assert(_Partition_Information.maximum != 0);
276  next_step(CLASSIC_PARTITION_POST);
277}
278
279FIRST(RTEMS_SYSINIT_CLASSIC_REGION)
280{
281  assert(_Region_Information.maximum == 0);
282  next_step(CLASSIC_REGION_PRE);
283}
284
285LAST(RTEMS_SYSINIT_CLASSIC_REGION)
286{
287  assert(_Region_Information.maximum != 0);
288  next_step(CLASSIC_REGION_POST);
289}
290
291FIRST(RTEMS_SYSINIT_CLASSIC_DUAL_PORTED_MEMORY)
292{
293  assert(_Dual_ported_memory_Information.maximum == 0);
294  next_step(CLASSIC_DUAL_PORTED_MEMORY_PRE);
295}
296
297LAST(RTEMS_SYSINIT_CLASSIC_DUAL_PORTED_MEMORY)
298{
299  assert(_Dual_ported_memory_Information.maximum != 0);
300  next_step(CLASSIC_DUAL_PORTED_MEMORY_POST);
301}
302
303FIRST(RTEMS_SYSINIT_CLASSIC_RATE_MONOTONIC)
304{
305  assert(_Rate_monotonic_Information.maximum == 0);
306  next_step(CLASSIC_RATE_MONOTONIC_PRE);
307}
308
309LAST(RTEMS_SYSINIT_CLASSIC_RATE_MONOTONIC)
310{
311  assert(_Rate_monotonic_Information.maximum != 0);
312  next_step(CLASSIC_RATE_MONOTONIC_POST);
313}
314
315FIRST(RTEMS_SYSINIT_CLASSIC_BARRIER)
316{
317  assert(_Barrier_Information.maximum == 0);
318  next_step(CLASSIC_BARRIER_PRE);
319}
320
321LAST(RTEMS_SYSINIT_CLASSIC_BARRIER)
322{
323  assert(_Barrier_Information.maximum != 0);
324  next_step(CLASSIC_BARRIER_POST);
325}
326
327#ifdef RTEMS_POSIX_API
328
329FIRST(RTEMS_SYSINIT_POSIX_SIGNALS)
330{
331  assert(
332    memcmp(
333      &_POSIX_signals_Vectors,
334      _POSIX_signals_Default_vectors,
335      sizeof(_POSIX_signals_Vectors)
336    ) != 0
337  );
338  next_step(POSIX_SIGNALS_PRE);
339}
340
341LAST(RTEMS_SYSINIT_POSIX_SIGNALS)
342{
343  assert(
344    memcmp(
345      &_POSIX_signals_Vectors,
346      _POSIX_signals_Default_vectors,
347      sizeof(_POSIX_signals_Vectors)
348    ) == 0
349  );
350  next_step(POSIX_SIGNALS_POST);
351}
352
353FIRST(RTEMS_SYSINIT_POSIX_THREADS)
354{
355  assert(_POSIX_Threads_Information.Objects.maximum == 0);
356  next_step(POSIX_THREADS_PRE);
357}
358
359LAST(RTEMS_SYSINIT_POSIX_THREADS)
360{
361  assert(_POSIX_Threads_Information.Objects.maximum != 0);
362  next_step(POSIX_THREADS_POST);
363}
364
365static size_t user_extensions_pre_posix_cleanup;
366
367FIRST(RTEMS_SYSINIT_POSIX_CLEANUP)
368{
369  user_extensions_pre_posix_cleanup =
370    _Chain_Node_count_unprotected(&_User_extensions_List);
371  next_step(POSIX_CLEANUP_PRE);
372}
373
374LAST(RTEMS_SYSINIT_POSIX_CLEANUP)
375{
376  assert(
377    user_extensions_pre_posix_cleanup + 1 ==
378      _Chain_Node_count_unprotected(&_User_extensions_List)
379  );
380  next_step(POSIX_CLEANUP_POST);
381}
382
383#endif /* RTEMS_POSIX_API */
384
385FIRST(RTEMS_SYSINIT_IDLE_THREADS)
386{
387  assert(_System_state_Is_before_initialization(_System_state_Get()));
388  next_step(IDLE_THREADS_PRE);
389}
390
391LAST(RTEMS_SYSINIT_IDLE_THREADS)
392{
393  assert(_System_state_Is_before_multitasking(_System_state_Get()));
394  next_step(IDLE_THREADS_POST);
395}
396
397FIRST(RTEMS_SYSINIT_BSP_LIBC)
398{
399  assert(rtems_libio_semaphore == 0);
400  next_step(BSP_LIBC_PRE);
401}
402
403LAST(RTEMS_SYSINIT_BSP_LIBC)
404{
405  assert(rtems_libio_semaphore != 0);
406  next_step(BSP_LIBC_POST);
407}
408
409FIRST(RTEMS_SYSINIT_BEFORE_DRIVERS)
410{
411  /* Omit test of build configuration specific pre and post conditions */
412  next_step(BEFORE_DRIVERS_PRE);
413}
414
415LAST(RTEMS_SYSINIT_BEFORE_DRIVERS)
416{
417  next_step(BEFORE_DRIVERS_POST);
418}
419
420FIRST(RTEMS_SYSINIT_BSP_PRE_DRIVERS)
421{
422  /*
423   * Since the work performed here is BSP-specific, there is no way to test pre
424   * and post conditions.
425   */
426  next_step(BSP_PRE_DRIVERS_PRE);
427}
428
429LAST(RTEMS_SYSINIT_BSP_PRE_DRIVERS)
430{
431  next_step(BSP_PRE_DRIVERS_POST);
432}
433
434FIRST(RTEMS_SYSINIT_DEVICE_DRIVERS)
435{
436  assert(!_IO_All_drivers_initialized);
437  next_step(DEVICE_DRIVERS_PRE);
438}
439
440LAST(RTEMS_SYSINIT_DEVICE_DRIVERS)
441{
442  assert(_IO_All_drivers_initialized);
443  next_step(DEVICE_DRIVERS_POST);
444}
445
446FIRST(RTEMS_SYSINIT_BSP_POST_DRIVERS)
447{
448  assert(rtems_libio_iop_freelist != NULL);
449  next_step(BSP_POST_DRIVERS_PRE);
450}
451
452LAST(RTEMS_SYSINIT_BSP_POST_DRIVERS)
453{
454  assert(rtems_libio_iop_freelist == NULL);
455  next_step(BSP_POST_DRIVERS_POST);
456}
457
458static void Init(rtems_task_argument arg)
459{
460#ifdef RTEMS_POSIX_API
461  pthread_cleanup_push(NULL, NULL);
462  pthread_cleanup_pop(0);
463#endif /* RTEMS_POSIX_API */
464  next_step(INIT_TASK);
465  rtems_test_endk();
466  exit(0);
467}
468
469#define CONFIGURE_APPLICATION_DOES_NOT_NEED_CLOCK_DRIVER
470#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
471
472#define CONFIGURE_MAXIMUM_USER_EXTENSIONS 1
473
474#define CONFIGURE_MAXIMUM_BARRIERS 1
475
476#define CONFIGURE_MAXIMUM_MESSAGE_QUEUES 1
477
478#define CONFIGURE_MAXIMUM_PARTITIONS 1
479
480#define CONFIGURE_MAXIMUM_PERIODS 1
481
482#define CONFIGURE_MAXIMUM_PORTS 1
483
484#define CONFIGURE_MAXIMUM_REGIONS 1
485
486#define CONFIGURE_MAXIMUM_SEMAPHORES 1
487
488#define CONFIGURE_MAXIMUM_TASKS 1
489
490#define CONFIGURE_MAXIMUM_TIMERS 1
491
492#ifdef RTEMS_POSIX_API
493
494#define CONFIGURE_MAXIMUM_POSIX_THREADS 1
495
496#endif /* RTEMS_POSIX_API */
497
498#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
499
500#define CONFIGURE_STACK_CHECKER_ENABLED
501
502#define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION
503
504#define CONFIGURE_INIT
505
506#include <rtems/confdefs.h>
Note: See TracBrowser for help on using the repository browser.