summaryrefslogtreecommitdiffstats
path: root/cpukit/libtest/t-test-rtems-objs.c
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2020-04-16 12:22:06 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2020-07-23 09:27:47 +0200
commit34e4df55901e88454029af8fe57f3c585a43b3ac (patch)
tree669a7039e53e13b09ac8485513910f3c68a9d32e /cpukit/libtest/t-test-rtems-objs.c
parentlibtest: Add T_get_scope() (diff)
downloadrtems-34e4df55901e88454029af8fe57f3c585a43b3ac.tar.bz2
libtest: Split POSIX Keys support
Update #3199.
Diffstat (limited to 'cpukit/libtest/t-test-rtems-objs.c')
-rw-r--r--cpukit/libtest/t-test-rtems-objs.c95
1 files changed, 15 insertions, 80 deletions
diff --git a/cpukit/libtest/t-test-rtems-objs.c b/cpukit/libtest/t-test-rtems-objs.c
index a5d6b4d72f..72447fd22f 100644
--- a/cpukit/libtest/t-test-rtems-objs.c
+++ b/cpukit/libtest/t-test-rtems-objs.c
@@ -1,7 +1,15 @@
-/*
- * SPDX-License-Identifier: BSD-2-Clause
+/* SPDX-License-Identifier: BSD-2-Clause */
+
+/**
+ * @file
*
- * Copyright (C) 2018 embedded brains GmbH
+ * @ingroup RTEMSTestFramework
+ *
+ * @brief RTEMS Objects Support for Test Framework
+ */
+
+/*
+ * Copyright (C) 2018 embedded brains GmbH (http://www.embedded-brains.de)
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
@@ -27,15 +35,15 @@
#undef __STRICT_ANSI__
+#include "t-test-rtems.h"
+
#include <rtems/test.h>
#include <inttypes.h>
-#include <rtems/score/objectimpl.h>
#include <rtems/score/threadimpl.h>
-#include <rtems/posix/keyimpl.h>
-static Objects_Maximum
+Objects_Maximum
T_objects_count(Objects_APIs api, uint16_t cls)
{
const Objects_Information *information;
@@ -56,7 +64,7 @@ T_objects_count(Objects_APIs api, uint16_t cls)
return count;
}
-static void
+void
T_objects_check(Objects_APIs api, uint16_t cls,
Objects_Maximum *expected, const char *name)
{
@@ -372,76 +380,3 @@ T_check_rtems_timers(T_event event, const char *name)
break;
};
}
-
-static Objects_Maximum T_posix_key_count;
-
-static ssize_t T_posix_key_value_count;
-
-static POSIX_Keys_Control *
-T_get_next_posix_key(Objects_Id *id)
-{
- return (POSIX_Keys_Control *)
- _Objects_Get_next(*id, &_POSIX_Keys_Information, id);
-}
-
-static ssize_t
-T_get_active_posix_key_value_pairs(void)
-{
- ssize_t count;
- Objects_Id id;
- POSIX_Keys_Control *the_key;
-
- count = 0;
- id = OBJECTS_ID_INITIAL_INDEX;
-
- while ((the_key = T_get_next_posix_key(&id)) != NULL ) {
- count += (ssize_t)
- _Chain_Node_count_unprotected(&the_key->Key_value_pairs);
- _Objects_Allocator_unlock();
- }
-
- return count;
-}
-
-static void
-T_posix_keys_run_initialize(void)
-{
- T_posix_key_count = T_objects_count(OBJECTS_POSIX_API,
- OBJECTS_POSIX_KEYS);
- T_posix_key_value_count = T_get_active_posix_key_value_pairs();
-}
-
-static void
-T_posix_keys_case_end(void)
-{
- ssize_t count;
- ssize_t delta;
-
- T_objects_check(OBJECTS_POSIX_API, OBJECTS_POSIX_KEYS,
- &T_posix_key_count, "POSIX key");
-
- count = T_get_active_posix_key_value_pairs();
- delta = count - T_posix_key_value_count;
-
- if (delta != 0) {
- T_posix_key_value_count = count;
- T_check_true(false, NULL, "POSIX key value pair leak (%zi)", delta);
- }
-}
-
-void
-T_check_posix_keys(T_event event, const char *name)
-{
- (void)name;
-
- switch (event) {
- case T_EVENT_RUN_INITIALIZE_EARLY:
- T_posix_keys_run_initialize();
- break;
- case T_EVENT_CASE_END:
- T_posix_keys_case_end();
- break;
- default:
- break;
- };
-}