source: rtems/testsuites/smptests/smpscheduler04/init.c

Last change on this file was bcef89f2, checked in by Sebastian Huber <sebastian.huber@…>, on 05/19/23 at 06:18:25

Update company name

The embedded brains GmbH & Co. KG is the legal successor of embedded
brains GmbH.

  • Property mode set to 100644
File size: 10.3 KB
Line 
1/* SPDX-License-Identifier: BSD-2-Clause */
2
3/*
4 * Copyright (c) 2016 embedded brains GmbH & Co. KG
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 * 1. Redistributions of source code must retain the above copyright
10 *    notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 *    notice, this list of conditions and the following disclaimer in the
13 *    documentation and/or other materials provided with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25 * POSSIBILITY OF SUCH DAMAGE.
26 */
27
28#ifdef HAVE_CONFIG_H
29#include "config.h"
30#endif
31
32#include <inttypes.h>
33#include <string.h>
34#include <stdio.h>
35
36#include <rtems.h>
37#include <rtems/libcsupport.h>
38
39#include "tmacros.h"
40
41const char rtems_test_name[] = "SMPSCHEDULER 4";
42
43#define CPU_COUNT 32
44
45#define PRIO_MIGRATION 2
46
47#define PRIO_SCHEDULER 3
48
49typedef struct {
50  rtems_id migration_task;
51  rtems_id scheduler_task;
52  rtems_id scheduler_ids[CPU_COUNT];
53  uint32_t migration_counter RTEMS_ALIGNED(CPU_CACHE_LINE_BYTES);
54  uint32_t scheduler_counter RTEMS_ALIGNED(CPU_CACHE_LINE_BYTES);
55} test_context;
56
57static test_context test_instance;
58
59static void migration_task(rtems_task_argument arg)
60{
61  test_context *ctx = (test_context *) arg;
62  uint32_t cpu_count = rtems_scheduler_get_processor_maximum();
63  uint32_t cpu_index = rtems_scheduler_get_processor();
64
65  while (true) {
66    rtems_status_code sc;
67
68    cpu_index = (cpu_index + 1) % cpu_count;
69
70    sc = rtems_task_set_scheduler(
71      RTEMS_SELF,
72      ctx->scheduler_ids[cpu_index],
73      PRIO_MIGRATION
74    );
75
76    if (sc == RTEMS_UNSATISFIED) {
77      continue;
78    }
79
80    rtems_test_assert(sc == RTEMS_SUCCESSFUL);
81    rtems_test_assert(cpu_index == rtems_scheduler_get_processor());
82    ++ctx->migration_counter;
83  }
84}
85
86static void scheduler_task(rtems_task_argument arg)
87{
88  test_context *ctx = (test_context *) arg;
89  uint32_t cpu_count = rtems_scheduler_get_processor_maximum();
90  uint32_t cpu_index = rtems_scheduler_get_processor();
91
92  while (true) {
93    rtems_status_code sc;
94
95    cpu_index = (cpu_index - 1) % cpu_count;
96
97    if (cpu_index == 0) {
98      cpu_index = 1;
99    }
100
101    do {
102      sc = rtems_scheduler_remove_processor(
103        ctx->scheduler_ids[cpu_index],
104        cpu_index
105      );
106    } while (sc == RTEMS_RESOURCE_IN_USE);
107
108    sc = rtems_scheduler_add_processor(
109      ctx->scheduler_ids[cpu_index],
110      cpu_index
111    );
112    rtems_test_assert(sc == RTEMS_SUCCESSFUL);
113
114    ++ctx->scheduler_counter;
115  }
116}
117
118static void test(test_context *ctx)
119{
120  rtems_status_code sc;
121  uint32_t i;
122
123  for (i = 0; i < rtems_scheduler_get_processor_maximum(); ++i) {
124    sc = rtems_scheduler_ident(i, &ctx->scheduler_ids[i]);
125    rtems_test_assert(sc == RTEMS_SUCCESSFUL);
126  }
127
128  sc = rtems_task_create(
129    rtems_build_name('M', 'I', 'G', 'R'),
130    PRIO_MIGRATION,
131    RTEMS_MINIMUM_STACK_SIZE,
132    RTEMS_DEFAULT_MODES,
133    RTEMS_DEFAULT_ATTRIBUTES,
134    &ctx->migration_task
135  );
136  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
137
138  sc = rtems_task_start(
139    ctx->migration_task,
140    migration_task,
141    (rtems_task_argument) ctx
142  );
143  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
144
145  sc = rtems_task_create(
146    rtems_build_name('S', 'C', 'H', 'D'),
147    PRIO_SCHEDULER,
148    RTEMS_MINIMUM_STACK_SIZE,
149    RTEMS_DEFAULT_MODES,
150    RTEMS_DEFAULT_ATTRIBUTES,
151    &ctx->scheduler_task
152  );
153  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
154
155  sc = rtems_task_start(
156    ctx->scheduler_task,
157    scheduler_task,
158    (rtems_task_argument) ctx
159  );
160  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
161
162  sc = rtems_task_wake_after(10 * rtems_clock_get_ticks_per_second());
163  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
164
165  sc = rtems_task_delete(ctx->migration_task);
166  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
167
168  sc = rtems_task_delete(ctx->scheduler_task);
169  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
170
171  printf(
172    "migration counter = %" PRIu32 "\n"
173    "scheduler counter = %" PRIu32 "\n",
174    ctx->migration_counter,
175    ctx->scheduler_counter
176  );
177}
178
179static void Init(rtems_task_argument arg)
180{
181  rtems_resource_snapshot snapshot;
182
183  TEST_BEGIN();
184  rtems_resource_snapshot_take(&snapshot);
185  test(&test_instance);
186  rtems_test_assert(rtems_resource_snapshot_check(&snapshot));
187  TEST_END();
188  rtems_test_exit(0);
189}
190
191#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
192#define CONFIGURE_APPLICATION_NEEDS_SIMPLE_CONSOLE_DRIVER
193
194#define CONFIGURE_MAXIMUM_TASKS 3
195
196#define CONFIGURE_MAXIMUM_PROCESSORS CPU_COUNT
197
198#define CONFIGURE_SCHEDULER_SIMPLE_SMP
199
200#include <rtems/scheduler.h>
201
202RTEMS_SCHEDULER_SIMPLE_SMP(0);
203RTEMS_SCHEDULER_SIMPLE_SMP(1);
204RTEMS_SCHEDULER_SIMPLE_SMP(2);
205RTEMS_SCHEDULER_SIMPLE_SMP(3);
206RTEMS_SCHEDULER_SIMPLE_SMP(4);
207RTEMS_SCHEDULER_SIMPLE_SMP(5);
208RTEMS_SCHEDULER_SIMPLE_SMP(6);
209RTEMS_SCHEDULER_SIMPLE_SMP(7);
210RTEMS_SCHEDULER_SIMPLE_SMP(8);
211RTEMS_SCHEDULER_SIMPLE_SMP(9);
212RTEMS_SCHEDULER_SIMPLE_SMP(10);
213RTEMS_SCHEDULER_SIMPLE_SMP(11);
214RTEMS_SCHEDULER_SIMPLE_SMP(12);
215RTEMS_SCHEDULER_SIMPLE_SMP(13);
216RTEMS_SCHEDULER_SIMPLE_SMP(14);
217RTEMS_SCHEDULER_SIMPLE_SMP(15);
218RTEMS_SCHEDULER_SIMPLE_SMP(16);
219RTEMS_SCHEDULER_SIMPLE_SMP(17);
220RTEMS_SCHEDULER_SIMPLE_SMP(18);
221RTEMS_SCHEDULER_SIMPLE_SMP(19);
222RTEMS_SCHEDULER_SIMPLE_SMP(20);
223RTEMS_SCHEDULER_SIMPLE_SMP(21);
224RTEMS_SCHEDULER_SIMPLE_SMP(22);
225RTEMS_SCHEDULER_SIMPLE_SMP(23);
226RTEMS_SCHEDULER_SIMPLE_SMP(24);
227RTEMS_SCHEDULER_SIMPLE_SMP(25);
228RTEMS_SCHEDULER_SIMPLE_SMP(26);
229RTEMS_SCHEDULER_SIMPLE_SMP(27);
230RTEMS_SCHEDULER_SIMPLE_SMP(28);
231RTEMS_SCHEDULER_SIMPLE_SMP(29);
232RTEMS_SCHEDULER_SIMPLE_SMP(30);
233RTEMS_SCHEDULER_SIMPLE_SMP(31);
234
235#define CONFIGURE_SCHEDULER_TABLE_ENTRIES \
236  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(0, 0), \
237  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(1, 1), \
238  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(2, 2), \
239  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(3, 3), \
240  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(4, 4), \
241  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(5, 5), \
242  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(6, 6), \
243  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(7, 7), \
244  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(8, 8), \
245  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(9, 9), \
246  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(10, 10), \
247  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(11, 11), \
248  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(12, 12), \
249  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(13, 13), \
250  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(14, 14), \
251  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(15, 15), \
252  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(16, 16), \
253  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(17, 17), \
254  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(18, 18), \
255  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(19, 19), \
256  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(20, 20), \
257  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(21, 21), \
258  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(22, 22), \
259  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(23, 23), \
260  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(24, 24), \
261  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(25, 25), \
262  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(26, 26), \
263  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(27, 27), \
264  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(28, 28), \
265  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(29, 29), \
266  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(30, 30), \
267  RTEMS_SCHEDULER_TABLE_SIMPLE_SMP(31, 31)
268
269#define CONFIGURE_SCHEDULER_ASSIGNMENTS \
270  RTEMS_SCHEDULER_ASSIGN(0, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_MANDATORY), \
271  RTEMS_SCHEDULER_ASSIGN(1, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
272  RTEMS_SCHEDULER_ASSIGN(2, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
273  RTEMS_SCHEDULER_ASSIGN(3, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
274  RTEMS_SCHEDULER_ASSIGN(4, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
275  RTEMS_SCHEDULER_ASSIGN(5, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
276  RTEMS_SCHEDULER_ASSIGN(6, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
277  RTEMS_SCHEDULER_ASSIGN(7, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
278  RTEMS_SCHEDULER_ASSIGN(8, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
279  RTEMS_SCHEDULER_ASSIGN(9, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
280  RTEMS_SCHEDULER_ASSIGN(10, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
281  RTEMS_SCHEDULER_ASSIGN(11, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
282  RTEMS_SCHEDULER_ASSIGN(12, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
283  RTEMS_SCHEDULER_ASSIGN(13, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
284  RTEMS_SCHEDULER_ASSIGN(14, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
285  RTEMS_SCHEDULER_ASSIGN(15, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
286  RTEMS_SCHEDULER_ASSIGN(16, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
287  RTEMS_SCHEDULER_ASSIGN(17, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
288  RTEMS_SCHEDULER_ASSIGN(18, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
289  RTEMS_SCHEDULER_ASSIGN(19, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
290  RTEMS_SCHEDULER_ASSIGN(20, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
291  RTEMS_SCHEDULER_ASSIGN(21, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
292  RTEMS_SCHEDULER_ASSIGN(22, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
293  RTEMS_SCHEDULER_ASSIGN(23, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
294  RTEMS_SCHEDULER_ASSIGN(24, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
295  RTEMS_SCHEDULER_ASSIGN(25, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
296  RTEMS_SCHEDULER_ASSIGN(26, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
297  RTEMS_SCHEDULER_ASSIGN(27, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
298  RTEMS_SCHEDULER_ASSIGN(28, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
299  RTEMS_SCHEDULER_ASSIGN(29, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
300  RTEMS_SCHEDULER_ASSIGN(30, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL), \
301  RTEMS_SCHEDULER_ASSIGN(31, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_OPTIONAL)
302
303#define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION
304
305#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
306
307#define CONFIGURE_INIT
308
309#include <rtems/confdefs.h>
Note: See TracBrowser for help on using the repository browser.