[rtems commit] tmonetoone: Add yield test case

Sebastian Huber sebh at rtems.org
Mon Oct 22 06:16:37 UTC 2018


Module:    rtems
Branch:    master
Commit:    8ba76b9e28cd3f1d6020ebcb2ce6a4cbfd2144a1
Changeset: http://git.rtems.org/rtems/commit/?id=8ba76b9e28cd3f1d6020ebcb2ce6a4cbfd2144a1

Author:    Sebastian Huber <sebastian.huber at embedded-brains.de>
Date:      Fri Oct 12 17:20:39 2018 +0200

tmonetoone: Add yield test case

---

 testsuites/tmtests/tmonetoone/init.c | 37 ++++++++++++++++++++++++++++++++++++
 1 file changed, 37 insertions(+)

diff --git a/testsuites/tmtests/tmonetoone/init.c b/testsuites/tmtests/tmonetoone/init.c
index 756a1ea..b721a8c 100644
--- a/testsuites/tmtests/tmonetoone/init.c
+++ b/testsuites/tmtests/tmonetoone/init.c
@@ -16,6 +16,8 @@
 #include "config.h"
 #endif
 
+#include <sched.h>
+
 #include <rtems.h>
 #include <rtems/test.h>
 #include <rtems/thread.h>
@@ -25,6 +27,7 @@
 const char rtems_test_name[] = "TMONETOONE";
 
 typedef enum {
+  TEST_YIELD,
   TEST_EVENTS,
   TEST_BSEM,
   TEST_CLASSIC_FIFO_BSEM,
@@ -51,6 +54,27 @@ typedef struct {
 
 static test_context test_instance;
 
+static void test_yield(task_context *tc)
+{
+  rtems_event_set events;
+  uint32_t counter;
+
+  (void)rtems_event_receive(
+    RTEMS_EVENT_0,
+    RTEMS_WAIT | RTEMS_EVENT_ALL,
+    RTEMS_NO_TIMEOUT,
+    &events
+  );
+
+  counter = 0;
+
+  while (true) {
+    (void)sched_yield();
+    ++counter;
+    tc->counter = counter;
+  }
+}
+
 static void test_events(task_context *tc)
 {
   uint32_t counter;
@@ -133,6 +157,9 @@ static void worker_task(rtems_task_argument arg)
   tc = (task_context *) arg;
 
   switch (tc->variant) {
+    case TEST_YIELD:
+      test_yield(tc);
+      break;
     case TEST_EVENTS:
       test_events(tc);
       break;
@@ -190,6 +217,7 @@ static void create_task(task_context *tc)
 }
 
 static const char * const variant_names[] = {
+  "yield",
   "event",
   "self-contained binary semaphore",
   "Classic binary semaphore (FIFO)",
@@ -248,6 +276,15 @@ static void Init(rtems_task_argument arg)
   ctx->b.other_classic_fifo_bsem = ctx->a.classic_fifo_bsem;
   ctx->b.other_classic_prio_bsem = ctx->a.classic_prio_bsem;
 
+  prepare(ctx, TEST_YIELD);
+
+  sc = rtems_event_send(ctx->a.task, RTEMS_EVENT_0);
+  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
+
+  sc = rtems_event_send(ctx->b.task, RTEMS_EVENT_0);
+  rtems_test_assert(sc == RTEMS_SUCCESSFUL);
+
+  run(ctx);
   prepare(ctx, TEST_EVENTS);
 
   sc = rtems_event_send(ctx->a.task, RTEMS_EVENT_0);



More information about the vc mailing list