source: rtems/testsuites/smptests/smpscheduler04/init.c @ 98c6d50

5
Last change on this file since 98c6d50 was 98c6d50, checked in by Chris Johns <chrisj@…>, on 10/19/17 at 05:39:16

testsuite: Use printk for all test output where possible.

  • Remove the printf support leaving the direct printk support configured with TESTS_USE_PRINTK and all other output goes via a buffered vsniprintf call to printk.
  • Control the test's single init for functions and global data with TEST_INIT and not CONFIGURE_INIT. They are now separate.

Updates #3170.

  • Property mode set to 100644
File size: 9.5 KB
Line 
1/*
2 * Copyright (c) 2016 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.org/license/LICENSE.
13 */
14
15#ifdef HAVE_CONFIG_H
16  #include "config.h"
17#endif
18
19#define TEST_INIT
20
21#include <inttypes.h>
22#include <string.h>
23#include <stdio.h>
24
25#include <rtems.h>
26#include <rtems/libcsupport.h>
27
28#include "tmacros.h"
29
30const char rtems_test_name[] = "SMPSCHEDULER 4";
31
32#define CPU_COUNT 32
33
34#define PRIO_MIGRATION 2
35
36#define PRIO_SCHEDULER 3
37
38typedef struct {
39  rtems_id migration_task;
40  rtems_id scheduler_task;
41  rtems_id scheduler_ids[CPU_COUNT];
42  uint32_t migration_counter RTEMS_ALIGNED(CPU_CACHE_LINE_BYTES);
43  uint32_t scheduler_counter RTEMS_ALIGNED(CPU_CACHE_LINE_BYTES);
44} test_context;
45
46static test_context test_instance;
47
48static void migration_task(rtems_task_argument arg)
49{
50  test_context *ctx = (test_context *) arg;
51  uint32_t cpu_count = rtems_get_processor_count();
52  uint32_t cpu_index = rtems_get_current_processor();
53
54  while (true) {
55    rtems_status_code sc;
56
57    cpu_index = (cpu_index + 1) % cpu_count;
58
59    sc = rtems_task_set_scheduler(
60      RTEMS_SELF,
61      ctx->scheduler_ids[cpu_index],
62      PRIO_MIGRATION
63    );
64
65    if (sc == RTEMS_UNSATISFIED) {
66      continue;
67    }
68
69    rtems_test_assert(sc == RTEMS_SUCCESSFUL);
70    rtems_test_assert(cpu_index == rtems_get_current_processor());
71    ++ctx->migration_counter;
72  }
73}
74
75static void scheduler_task(rtems_task_argument arg)
76{
77  test_context *ctx = (test_context *) arg;
78  uint32_t cpu_count = rtems_get_processor_count();
79  uint32_t cpu_index = rtems_get_current_processor();
80
81  while (true) {
82    rtems_status_code sc;
83
84    cpu_index = (cpu_index - 1) % cpu_count;
85
86    if (cpu_index == 0) {
87      cpu_index = 1;
88    }
89
90    do {
91      sc = rtems_scheduler_remove_processor(
92        ctx->scheduler_ids[cpu_index],
93        cpu_index
94      );
95    } while (sc == RTEMS_RESOURCE_IN_USE);
96
97    sc = rtems_scheduler_add_processor(
98      ctx->scheduler_ids[cpu_index],
99      cpu_index
100    );
101    rtems_test_assert(sc == RTEMS_SUCCESSFUL);
102
103    ++ctx->scheduler_counter;
104  }
105}
106
107static void test(test_context *ctx)
108{
109  rtems_status_code sc;
110  uint32_t i;
111
112  for (i = 0; i < rtems_get_processor_count(); ++i) {
113    sc = rtems_scheduler_ident(i, &ctx->scheduler_ids[i]);
114    rtems_test_assert(sc == RTEMS_SUCCESSFUL);
115  }
116
117  sc = rtems_task_create(
118    rtems_build_name('M', 'I', 'G', 'R'),
119    PRIO_MIGRATION,
120    RTEMS_MINIMUM_STACK_SIZE,
121    RTEMS_DEFAULT_MODES,
122    RTEMS_DEFAULT_ATTRIBUTES,
123    &ctx->migration_task
124  );
125  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
126
127  sc = rtems_task_start(
128    ctx->migration_task,
129    migration_task,
130    (rtems_task_argument) ctx
131  );
132  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
133
134  sc = rtems_task_create(
135    rtems_build_name('S', 'C', 'H', 'D'),
136    PRIO_SCHEDULER,
137    RTEMS_MINIMUM_STACK_SIZE,
138    RTEMS_DEFAULT_MODES,
139    RTEMS_DEFAULT_ATTRIBUTES,
140    &ctx->scheduler_task
141  );
142  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
143
144  sc = rtems_task_start(
145    ctx->scheduler_task,
146    scheduler_task,
147    (rtems_task_argument) ctx
148  );
149  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
150
151  sc = rtems_task_wake_after(10 * rtems_clock_get_ticks_per_second());
152  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
153
154  sc = rtems_task_delete(ctx->migration_task);
155  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
156
157  sc = rtems_task_delete(ctx->scheduler_task);
158  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
159
160  printf(
161    "migration counter = %" PRIu32 "\n"
162    "scheduler counter = %" PRIu32 "\n",
163    ctx->migration_counter,
164    ctx->scheduler_counter
165  );
166}
167
168static void Init(rtems_task_argument arg)
169{
170  rtems_resource_snapshot snapshot;
171
172  TEST_BEGIN();
173  rtems_resource_snapshot_take(&snapshot);
174  test(&test_instance);
175  rtems_test_assert(rtems_resource_snapshot_check(&snapshot));
176  TEST_END();
177  rtems_test_exit(0);
178}
179
180#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
181#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
182
183#define CONFIGURE_MAXIMUM_TASKS 3
184
185#define CONFIGURE_MAXIMUM_PROCESSORS CPU_COUNT
186
187#define CONFIGURE_SCHEDULER_SIMPLE_SMP
188
189#include <rtems/scheduler.h>
190
191RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(0);
192RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(1);
193RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(2);
194RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(3);
195RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(4);
196RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(5);
197RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(6);
198RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(7);
199RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(8);
200RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(9);
201RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(10);
202RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(11);
203RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(12);
204RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(13);
205RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(14);
206RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(15);
207RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(16);
208RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(17);
209RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(18);
210RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(19);
211RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(20);
212RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(21);
213RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(22);
214RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(23);
215RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(24);
216RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(25);
217RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(26);
218RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(27);
219RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(28);
220RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(29);
221RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(30);
222RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(31);
223
224#define CONFIGURE_SCHEDULER_CONTROLS \
225  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(0, 0), \
226  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(1, 1), \
227  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(2, 2), \
228  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(3, 3), \
229  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(4, 4), \
230  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(5, 5), \
231  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(6, 6), \
232  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(7, 7), \
233  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(8, 8), \
234  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(9, 9), \
235  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(10, 10), \
236  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(11, 11), \
237  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(12, 12), \
238  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(13, 13), \
239  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(14, 14), \
240  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(15, 15), \
241  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(16, 16), \
242  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(17, 17), \
243  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(18, 18), \
244  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(19, 19), \
245  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(20, 20), \
246  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(21, 21), \
247  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(22, 22), \
248  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(23, 23), \
249  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(24, 24), \
250  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(25, 25), \
251  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(26, 26), \
252  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(27, 27), \
253  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(28, 28), \
254  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(29, 29), \
255  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(30, 30), \
256  RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(31, 31)
257
258#define CONFIGURE_SMP_SCHEDULER_ASSIGNMENTS \
259  RTEMS_SCHEDULER_ASSIGN(0, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_MANDATORY), \
260  RTEMS_SCHEDULER_ASSIGN(1, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
261  RTEMS_SCHEDULER_ASSIGN(2, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
262  RTEMS_SCHEDULER_ASSIGN(3, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
263  RTEMS_SCHEDULER_ASSIGN(4, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
264  RTEMS_SCHEDULER_ASSIGN(5, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
265  RTEMS_SCHEDULER_ASSIGN(6, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
266  RTEMS_SCHEDULER_ASSIGN(7, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
267  RTEMS_SCHEDULER_ASSIGN(8, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
268  RTEMS_SCHEDULER_ASSIGN(9, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
269  RTEMS_SCHEDULER_ASSIGN(10, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
270  RTEMS_SCHEDULER_ASSIGN(11, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
271  RTEMS_SCHEDULER_ASSIGN(12, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
272  RTEMS_SCHEDULER_ASSIGN(13, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
273  RTEMS_SCHEDULER_ASSIGN(14, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
274  RTEMS_SCHEDULER_ASSIGN(15, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
275  RTEMS_SCHEDULER_ASSIGN(16, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
276  RTEMS_SCHEDULER_ASSIGN(17, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
277  RTEMS_SCHEDULER_ASSIGN(18, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
278  RTEMS_SCHEDULER_ASSIGN(19, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
279  RTEMS_SCHEDULER_ASSIGN(20, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
280  RTEMS_SCHEDULER_ASSIGN(21, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
281  RTEMS_SCHEDULER_ASSIGN(22, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
282  RTEMS_SCHEDULER_ASSIGN(23, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
283  RTEMS_SCHEDULER_ASSIGN(24, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
284  RTEMS_SCHEDULER_ASSIGN(25, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
285  RTEMS_SCHEDULER_ASSIGN(26, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
286  RTEMS_SCHEDULER_ASSIGN(27, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
287  RTEMS_SCHEDULER_ASSIGN(28, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
288  RTEMS_SCHEDULER_ASSIGN(29, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
289  RTEMS_SCHEDULER_ASSIGN(30, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
290  RTEMS_SCHEDULER_ASSIGN(31, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL)
291
292#define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION
293
294#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
295
296#define CONFIGURE_INIT
297
298#include <rtems/confdefs.h>
Note: See TracBrowser for help on using the repository browser.