source: rtems/testsuites/sptests/spsysinit01/init.c @ 190169fe

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

Optional CPU Set Handler initialization

Update #2408.

  • Property mode set to 100644
File size: 13.7 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/barrierimpl.h>
32#include <rtems/posix/condimpl.h>
33#include <rtems/posix/mqueueimpl.h>
34#include <rtems/posix/muteximpl.h>
35#include <rtems/posix/psignalimpl.h>
36#include <rtems/posix/pthreadimpl.h>
37#include <rtems/posix/rwlockimpl.h>
38#include <rtems/posix/semaphoreimpl.h>
39#include <rtems/posix/spinlockimpl.h>
40#include <rtems/posix/timerimpl.h>
41#endif /* RTEMS_POSIX_API */
42#include <rtems/rtems/barrierimpl.h>
43#include <rtems/rtems/dpmemimpl.h>
44#include <rtems/rtems/messageimpl.h>
45#include <rtems/rtems/partimpl.h>
46#include <rtems/rtems/ratemonimpl.h>
47#include <rtems/rtems/regionimpl.h>
48#include <rtems/rtems/semimpl.h>
49#include <rtems/rtems/tasksimpl.h>
50#include <rtems/rtems/timerimpl.h>
51#include <rtems/score/apimutex.h>
52#include <rtems/score/chainimpl.h>
53#include <rtems/score/sysstate.h>
54#include <rtems/score/userextimpl.h>
55#include <rtems/score/wkspace.h>
56
57const char rtems_test_name[] = "SPSYSINIT 1";
58
59typedef enum {
60  BSP_WORK_AREAS_PRE,
61  BSP_WORK_AREAS_POST,
62  BSP_START_PRE,
63  BSP_START_POST,
64  INITIAL_EXTENSIONS_PRE,
65  INITIAL_EXTENSIONS_POST,
66  DATA_STRUCTURES_PRE,
67  DATA_STRUCTURES_POST,
68  CPU_SET_PRE,
69  CPU_SET_POST,
70  USER_EXTENSIONS_PRE,
71  USER_EXTENSIONS_POST,
72  CLASSIC_TASKS_PRE,
73  CLASSIC_TASKS_POST,
74  CLASSIC_TIMER_PRE,
75  CLASSIC_TIMER_POST,
76  CLASSIC_SIGNAL_PRE,
77  CLASSIC_SIGNAL_POST,
78  CLASSIC_EVENT_PRE,
79  CLASSIC_EVENT_POST,
80  CLASSIC_MESSAGE_QUEUE_PRE,
81  CLASSIC_MESSAGE_QUEUE_POST,
82  CLASSIC_SEMAPHORE_PRE,
83  CLASSIC_SEMAPHORE_POST,
84  CLASSIC_PARTITION_PRE,
85  CLASSIC_PARTITION_POST,
86  CLASSIC_REGION_PRE,
87  CLASSIC_REGION_POST,
88  CLASSIC_DUAL_PORTED_MEMORY_PRE,
89  CLASSIC_DUAL_PORTED_MEMORY_POST,
90  CLASSIC_RATE_MONOTONIC_PRE,
91  CLASSIC_RATE_MONOTONIC_POST,
92  CLASSIC_BARRIER_PRE,
93  CLASSIC_BARRIER_POST,
94#ifdef RTEMS_POSIX_API
95  POSIX_SIGNALS_PRE,
96  POSIX_SIGNALS_POST,
97  POSIX_THREADS_PRE,
98  POSIX_THREADS_POST,
99  POSIX_CONDITION_VARIABLE_PRE,
100  POSIX_CONDITION_VARIABLE_POST,
101  POSIX_MUTEX_PRE,
102  POSIX_MUTEX_POST,
103  POSIX_MESSAGE_QUEUE_PRE,
104  POSIX_MESSAGE_QUEUE_POST,
105  POSIX_SEMAPHORE_PRE,
106  POSIX_SEMAPHORE_POST,
107  POSIX_TIMER_PRE,
108  POSIX_TIMER_POST,
109  POSIX_BARRIER_PRE,
110  POSIX_BARRIER_POST,
111  POSIX_RWLOCK_PRE,
112  POSIX_RWLOCK_POST,
113  POSIX_SPINLOCK_PRE,
114  POSIX_SPINLOCK_POST,
115  POSIX_CLEANUP_PRE,
116  POSIX_CLEANUP_POST,
117#endif /* RTEMS_POSIX_API */
118  IDLE_THREADS_PRE,
119  IDLE_THREADS_POST,
120  BSP_LIBC_PRE,
121  BSP_LIBC_POST,
122  BEFORE_DRIVERS_PRE,
123  BEFORE_DRIVERS_POST,
124  BSP_PRE_DRIVERS_PRE,
125  BSP_PRE_DRIVERS_POST,
126  DEVICE_DRIVERS_PRE,
127  DEVICE_DRIVERS_POST,
128  BSP_POST_DRIVERS_PRE,
129  BSP_POST_DRIVERS_POST,
130  INIT_TASK,
131  DONE
132} init_step;
133
134#define FIRST(x) \
135  static void x##_first(void); \
136  RTEMS_SYSINIT_ITEM( \
137    x##_first, \
138    x, \
139    RTEMS_SYSINIT_ORDER_FIRST \
140  ); \
141  static void x##_first(void)
142
143#define LAST(x) \
144  static void x##_last(void); \
145  RTEMS_SYSINIT_ITEM( \
146    x##_last, \
147    x, \
148    RTEMS_SYSINIT_ORDER_LAST \
149  ); \
150  static void x##_last(void)
151
152static init_step step;
153
154static void next_step(init_step expected)
155{
156  assert(step == expected);
157  step = expected + 1;
158}
159
160FIRST(RTEMS_SYSINIT_BSP_WORK_AREAS)
161{
162  rtems_test_begink();
163  assert(_Workspace_Area.area_begin == 0);
164  next_step(BSP_WORK_AREAS_PRE);
165}
166
167LAST(RTEMS_SYSINIT_BSP_WORK_AREAS)
168{
169  assert(_Workspace_Area.area_begin != 0);
170  next_step(BSP_WORK_AREAS_POST);
171}
172
173FIRST(RTEMS_SYSINIT_BSP_START)
174{
175  /*
176   * Since the work performed here is BSP-specific, there is no way to test pre
177   * and post conditions.
178   */
179  next_step(BSP_START_PRE);
180}
181
182LAST(RTEMS_SYSINIT_BSP_START)
183{
184  next_step(BSP_START_POST);
185}
186
187FIRST(RTEMS_SYSINIT_INITIAL_EXTENSIONS)
188{
189  assert(_Chain_Is_empty(&_User_extensions_Switches_list));
190  next_step(INITIAL_EXTENSIONS_PRE);
191}
192
193LAST(RTEMS_SYSINIT_INITIAL_EXTENSIONS)
194{
195  assert(!_Chain_Is_empty(&_User_extensions_Switches_list));
196  next_step(INITIAL_EXTENSIONS_POST);
197}
198
199FIRST(RTEMS_SYSINIT_DATA_STRUCTURES)
200{
201  assert(_RTEMS_Allocator_Mutex == NULL);
202  next_step(DATA_STRUCTURES_PRE);
203}
204
205LAST(RTEMS_SYSINIT_DATA_STRUCTURES)
206{
207  assert(_RTEMS_Allocator_Mutex != NULL);
208  next_step(DATA_STRUCTURES_POST);
209}
210
211FIRST(RTEMS_SYSINIT_CPU_SET)
212{
213  /* There is nothing to do in case RTEMS_SMP is not defined */
214  next_step(CPU_SET_PRE);
215}
216
217LAST(RTEMS_SYSINIT_CPU_SET)
218{
219  next_step(CPU_SET_POST);
220}
221
222FIRST(RTEMS_SYSINIT_USER_EXTENSIONS)
223{
224  assert(_Extension_Information.maximum == 0);
225  next_step(USER_EXTENSIONS_PRE);
226}
227
228LAST(RTEMS_SYSINIT_USER_EXTENSIONS)
229{
230  assert(_Extension_Information.maximum != 0);
231  next_step(USER_EXTENSIONS_POST);
232}
233
234FIRST(RTEMS_SYSINIT_CLASSIC_TASKS)
235{
236  assert(_RTEMS_tasks_Information.Objects.maximum == 0);
237  next_step(CLASSIC_TASKS_PRE);
238}
239
240LAST(RTEMS_SYSINIT_CLASSIC_TASKS)
241{
242  assert(_RTEMS_tasks_Information.Objects.maximum != 0);
243  next_step(CLASSIC_TASKS_POST);
244}
245
246FIRST(RTEMS_SYSINIT_CLASSIC_TIMER)
247{
248  assert(_Timer_Information.maximum == 0);
249  next_step(CLASSIC_TIMER_PRE);
250}
251
252LAST(RTEMS_SYSINIT_CLASSIC_TIMER)
253{
254  assert(_Timer_Information.maximum != 0);
255  next_step(CLASSIC_TIMER_POST);
256}
257
258FIRST(RTEMS_SYSINIT_CLASSIC_SIGNAL)
259{
260  /* There is nothing to do in case RTEMS_MULTIPROCESSING is not defined */
261  next_step(CLASSIC_SIGNAL_PRE);
262}
263
264LAST(RTEMS_SYSINIT_CLASSIC_SIGNAL)
265{
266  next_step(CLASSIC_SIGNAL_POST);
267}
268
269FIRST(RTEMS_SYSINIT_CLASSIC_EVENT)
270{
271  /* There is nothing to do in case RTEMS_MULTIPROCESSING is not defined */
272  next_step(CLASSIC_EVENT_PRE);
273}
274
275LAST(RTEMS_SYSINIT_CLASSIC_EVENT)
276{
277  next_step(CLASSIC_EVENT_POST);
278}
279
280FIRST(RTEMS_SYSINIT_CLASSIC_MESSAGE_QUEUE)
281{
282  assert(_Message_queue_Information.maximum == 0);
283  next_step(CLASSIC_MESSAGE_QUEUE_PRE);
284}
285
286LAST(RTEMS_SYSINIT_CLASSIC_MESSAGE_QUEUE)
287{
288  assert(_Message_queue_Information.maximum != 0);
289  next_step(CLASSIC_MESSAGE_QUEUE_POST);
290}
291
292FIRST(RTEMS_SYSINIT_CLASSIC_SEMAPHORE)
293{
294  assert(_Semaphore_Information.maximum == 0);
295  next_step(CLASSIC_SEMAPHORE_PRE);
296}
297
298LAST(RTEMS_SYSINIT_CLASSIC_SEMAPHORE)
299{
300  assert(_Semaphore_Information.maximum != 0);
301  next_step(CLASSIC_SEMAPHORE_POST);
302}
303
304FIRST(RTEMS_SYSINIT_CLASSIC_PARTITION)
305{
306  assert(_Partition_Information.maximum == 0);
307  next_step(CLASSIC_PARTITION_PRE);
308}
309
310LAST(RTEMS_SYSINIT_CLASSIC_PARTITION)
311{
312  assert(_Partition_Information.maximum != 0);
313  next_step(CLASSIC_PARTITION_POST);
314}
315
316FIRST(RTEMS_SYSINIT_CLASSIC_REGION)
317{
318  assert(_Region_Information.maximum == 0);
319  next_step(CLASSIC_REGION_PRE);
320}
321
322LAST(RTEMS_SYSINIT_CLASSIC_REGION)
323{
324  assert(_Region_Information.maximum != 0);
325  next_step(CLASSIC_REGION_POST);
326}
327
328FIRST(RTEMS_SYSINIT_CLASSIC_DUAL_PORTED_MEMORY)
329{
330  assert(_Dual_ported_memory_Information.maximum == 0);
331  next_step(CLASSIC_DUAL_PORTED_MEMORY_PRE);
332}
333
334LAST(RTEMS_SYSINIT_CLASSIC_DUAL_PORTED_MEMORY)
335{
336  assert(_Dual_ported_memory_Information.maximum != 0);
337  next_step(CLASSIC_DUAL_PORTED_MEMORY_POST);
338}
339
340FIRST(RTEMS_SYSINIT_CLASSIC_RATE_MONOTONIC)
341{
342  assert(_Rate_monotonic_Information.maximum == 0);
343  next_step(CLASSIC_RATE_MONOTONIC_PRE);
344}
345
346LAST(RTEMS_SYSINIT_CLASSIC_RATE_MONOTONIC)
347{
348  assert(_Rate_monotonic_Information.maximum != 0);
349  next_step(CLASSIC_RATE_MONOTONIC_POST);
350}
351
352FIRST(RTEMS_SYSINIT_CLASSIC_BARRIER)
353{
354  assert(_Barrier_Information.maximum == 0);
355  next_step(CLASSIC_BARRIER_PRE);
356}
357
358LAST(RTEMS_SYSINIT_CLASSIC_BARRIER)
359{
360  assert(_Barrier_Information.maximum != 0);
361  next_step(CLASSIC_BARRIER_POST);
362}
363
364#ifdef RTEMS_POSIX_API
365
366FIRST(RTEMS_SYSINIT_POSIX_SIGNALS)
367{
368  assert(
369    memcmp(
370      &_POSIX_signals_Vectors,
371      _POSIX_signals_Default_vectors,
372      sizeof(_POSIX_signals_Vectors)
373    ) != 0
374  );
375  next_step(POSIX_SIGNALS_PRE);
376}
377
378LAST(RTEMS_SYSINIT_POSIX_SIGNALS)
379{
380  assert(
381    memcmp(
382      &_POSIX_signals_Vectors,
383      _POSIX_signals_Default_vectors,
384      sizeof(_POSIX_signals_Vectors)
385    ) == 0
386  );
387  next_step(POSIX_SIGNALS_POST);
388}
389
390FIRST(RTEMS_SYSINIT_POSIX_THREADS)
391{
392  assert(_POSIX_Threads_Information.Objects.maximum == 0);
393  next_step(POSIX_THREADS_PRE);
394}
395
396LAST(RTEMS_SYSINIT_POSIX_THREADS)
397{
398  assert(_POSIX_Threads_Information.Objects.maximum != 0);
399  next_step(POSIX_THREADS_POST);
400}
401
402FIRST(RTEMS_SYSINIT_POSIX_CONDITION_VARIABLE)
403{
404  assert(_POSIX_Condition_variables_Information.maximum == 0);
405  next_step(POSIX_CONDITION_VARIABLE_PRE);
406}
407
408LAST(RTEMS_SYSINIT_POSIX_CONDITION_VARIABLE)
409{
410  assert(_POSIX_Condition_variables_Information.maximum != 0);
411  next_step(POSIX_CONDITION_VARIABLE_POST);
412}
413
414FIRST(RTEMS_SYSINIT_POSIX_MUTEX)
415{
416  assert(_POSIX_Mutex_Information.maximum == 0);
417  next_step(POSIX_MUTEX_PRE);
418}
419
420LAST(RTEMS_SYSINIT_POSIX_MUTEX)
421{
422  assert(_POSIX_Mutex_Information.maximum != 0);
423  next_step(POSIX_MUTEX_POST);
424}
425
426FIRST(RTEMS_SYSINIT_POSIX_MESSAGE_QUEUE)
427{
428  assert(_POSIX_Message_queue_Information.maximum == 0);
429  next_step(POSIX_MESSAGE_QUEUE_PRE);
430}
431
432LAST(RTEMS_SYSINIT_POSIX_MESSAGE_QUEUE)
433{
434  assert(_POSIX_Message_queue_Information.maximum != 0);
435  next_step(POSIX_MESSAGE_QUEUE_POST);
436}
437
438FIRST(RTEMS_SYSINIT_POSIX_SEMAPHORE)
439{
440  assert(_POSIX_Semaphore_Information.maximum == 0);
441  next_step(POSIX_SEMAPHORE_PRE);
442}
443
444LAST(RTEMS_SYSINIT_POSIX_SEMAPHORE)
445{
446  assert(_POSIX_Semaphore_Information.maximum != 0);
447  next_step(POSIX_SEMAPHORE_POST);
448}
449
450FIRST(RTEMS_SYSINIT_POSIX_TIMER)
451{
452  assert(_POSIX_Timer_Information.maximum == 0);
453  next_step(POSIX_TIMER_PRE);
454}
455
456LAST(RTEMS_SYSINIT_POSIX_TIMER)
457{
458  assert(_POSIX_Timer_Information.maximum != 0);
459  next_step(POSIX_TIMER_POST);
460}
461
462FIRST(RTEMS_SYSINIT_POSIX_BARRIER)
463{
464  assert(_POSIX_Barrier_Information.maximum == 0);
465  next_step(POSIX_BARRIER_PRE);
466}
467
468LAST(RTEMS_SYSINIT_POSIX_BARRIER)
469{
470  assert(_POSIX_Barrier_Information.maximum != 0);
471  next_step(POSIX_BARRIER_POST);
472}
473
474FIRST(RTEMS_SYSINIT_POSIX_RWLOCK)
475{
476  assert(_POSIX_RWLock_Information.maximum == 0);
477  next_step(POSIX_RWLOCK_PRE);
478}
479
480LAST(RTEMS_SYSINIT_POSIX_RWLOCK)
481{
482  assert(_POSIX_RWLock_Information.maximum != 0);
483  next_step(POSIX_RWLOCK_POST);
484}
485
486FIRST(RTEMS_SYSINIT_POSIX_SPINLOCK)
487{
488  assert(_POSIX_Spinlock_Information.maximum == 0);
489  next_step(POSIX_SPINLOCK_PRE);
490}
491
492LAST(RTEMS_SYSINIT_POSIX_SPINLOCK)
493{
494  assert(_POSIX_Spinlock_Information.maximum != 0);
495  next_step(POSIX_SPINLOCK_POST);
496}
497
498static size_t user_extensions_pre_posix_cleanup;
499
500FIRST(RTEMS_SYSINIT_POSIX_CLEANUP)
501{
502  user_extensions_pre_posix_cleanup =
503    _Chain_Node_count_unprotected(&_User_extensions_List);
504  next_step(POSIX_CLEANUP_PRE);
505}
506
507LAST(RTEMS_SYSINIT_POSIX_CLEANUP)
508{
509  assert(
510    user_extensions_pre_posix_cleanup + 1 ==
511      _Chain_Node_count_unprotected(&_User_extensions_List)
512  );
513  next_step(POSIX_CLEANUP_POST);
514}
515
516#endif /* RTEMS_POSIX_API */
517
518FIRST(RTEMS_SYSINIT_IDLE_THREADS)
519{
520  assert(_System_state_Is_before_initialization(_System_state_Get()));
521  next_step(IDLE_THREADS_PRE);
522}
523
524LAST(RTEMS_SYSINIT_IDLE_THREADS)
525{
526  assert(_System_state_Is_before_multitasking(_System_state_Get()));
527  next_step(IDLE_THREADS_POST);
528}
529
530FIRST(RTEMS_SYSINIT_BSP_LIBC)
531{
532  assert(rtems_libio_semaphore == 0);
533  next_step(BSP_LIBC_PRE);
534}
535
536LAST(RTEMS_SYSINIT_BSP_LIBC)
537{
538  assert(rtems_libio_semaphore != 0);
539  next_step(BSP_LIBC_POST);
540}
541
542FIRST(RTEMS_SYSINIT_BEFORE_DRIVERS)
543{
544  /* Omit test of build configuration specific pre and post conditions */
545  next_step(BEFORE_DRIVERS_PRE);
546}
547
548LAST(RTEMS_SYSINIT_BEFORE_DRIVERS)
549{
550  next_step(BEFORE_DRIVERS_POST);
551}
552
553FIRST(RTEMS_SYSINIT_BSP_PRE_DRIVERS)
554{
555  /*
556   * Since the work performed here is BSP-specific, there is no way to test pre
557   * and post conditions.
558   */
559  next_step(BSP_PRE_DRIVERS_PRE);
560}
561
562LAST(RTEMS_SYSINIT_BSP_PRE_DRIVERS)
563{
564  next_step(BSP_PRE_DRIVERS_POST);
565}
566
567FIRST(RTEMS_SYSINIT_DEVICE_DRIVERS)
568{
569  assert(!_IO_All_drivers_initialized);
570  next_step(DEVICE_DRIVERS_PRE);
571}
572
573LAST(RTEMS_SYSINIT_DEVICE_DRIVERS)
574{
575  assert(_IO_All_drivers_initialized);
576  next_step(DEVICE_DRIVERS_POST);
577}
578
579FIRST(RTEMS_SYSINIT_BSP_POST_DRIVERS)
580{
581  assert(rtems_libio_iop_freelist != NULL);
582  next_step(BSP_POST_DRIVERS_PRE);
583}
584
585LAST(RTEMS_SYSINIT_BSP_POST_DRIVERS)
586{
587  assert(rtems_libio_iop_freelist == NULL);
588  next_step(BSP_POST_DRIVERS_POST);
589}
590
591static void Init(rtems_task_argument arg)
592{
593#ifdef RTEMS_POSIX_API
594  pthread_cleanup_push(NULL, NULL);
595  pthread_cleanup_pop(0);
596#endif /* RTEMS_POSIX_API */
597  next_step(INIT_TASK);
598  rtems_test_endk();
599  exit(0);
600}
601
602#define CONFIGURE_APPLICATION_DOES_NOT_NEED_CLOCK_DRIVER
603#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
604
605#define CONFIGURE_MAXIMUM_USER_EXTENSIONS 1
606
607#define CONFIGURE_MAXIMUM_BARRIERS 1
608
609#define CONFIGURE_MAXIMUM_MESSAGE_QUEUES 1
610
611#define CONFIGURE_MAXIMUM_PARTITIONS 1
612
613#define CONFIGURE_MAXIMUM_PERIODS 1
614
615#define CONFIGURE_MAXIMUM_PORTS 1
616
617#define CONFIGURE_MAXIMUM_REGIONS 1
618
619#define CONFIGURE_MAXIMUM_SEMAPHORES 1
620
621#define CONFIGURE_MAXIMUM_TASKS 1
622
623#define CONFIGURE_MAXIMUM_TIMERS 1
624
625#ifdef RTEMS_POSIX_API
626
627#define CONFIGURE_MAXIMUM_POSIX_BARRIERS 1
628
629#define CONFIGURE_MAXIMUM_POSIX_MESSAGE_QUEUES 1
630
631#define CONFIGURE_MAXIMUM_POSIX_MUTEXES 1
632
633#define CONFIGURE_MAXIMUM_POSIX_CONDITION_VARIABLES 1
634
635#define CONFIGURE_MAXIMUM_POSIX_RWLOCKS 1
636
637#define CONFIGURE_MAXIMUM_POSIX_SEMAPHORES 1
638
639#define CONFIGURE_MAXIMUM_POSIX_SPINLOCKS 1
640
641#define CONFIGURE_MAXIMUM_POSIX_TIMERS 1
642
643#define CONFIGURE_MAXIMUM_POSIX_THREADS 1
644
645#endif /* RTEMS_POSIX_API */
646
647#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
648
649#define CONFIGURE_STACK_CHECKER_ENABLED
650
651#define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION
652
653#define CONFIGURE_INIT
654
655#include <rtems/confdefs.h>
Note: See TracBrowser for help on using the repository browser.