summaryrefslogtreecommitdiffstats
path: root/testsuites
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2015-12-14 16:31:44 +0100
committerSebastian Huber <sebastian.huber@embedded-brains.de>2016-02-03 10:00:55 +0100
commit9871f5dc60c622b58710f624f2ddb9328de16eb8 (patch)
tree7634755c127f37744dfeafd62ce2fc7368adaf70 /testsuites
parentOptional POSIX Condition Variable initialization (diff)
downloadrtems-9871f5dc60c622b58710f624f2ddb9328de16eb8.tar.bz2
Optional POSIX Mutex initialization
Update #2408.
Diffstat (limited to 'testsuites')
-rw-r--r--testsuites/sptests/spsysinit01/init.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/testsuites/sptests/spsysinit01/init.c b/testsuites/sptests/spsysinit01/init.c
index 87d0c32dc9..39c4fbec49 100644
--- a/testsuites/sptests/spsysinit01/init.c
+++ b/testsuites/sptests/spsysinit01/init.c
@@ -29,6 +29,7 @@
#include <rtems/extensionimpl.h>
#ifdef RTEMS_POSIX_API
#include <rtems/posix/condimpl.h>
+#include <rtems/posix/muteximpl.h>
#include <rtems/posix/psignalimpl.h>
#include <rtems/posix/pthreadimpl.h>
#endif /* RTEMS_POSIX_API */
@@ -89,6 +90,8 @@ typedef enum {
POSIX_THREADS_POST,
POSIX_CONDITION_VARIABLE_PRE,
POSIX_CONDITION_VARIABLE_POST,
+ POSIX_MUTEX_PRE,
+ POSIX_MUTEX_POST,
POSIX_CLEANUP_PRE,
POSIX_CLEANUP_POST,
#endif /* RTEMS_POSIX_API */
@@ -377,6 +380,18 @@ LAST(RTEMS_SYSINIT_POSIX_CONDITION_VARIABLE)
next_step(POSIX_CONDITION_VARIABLE_POST);
}
+FIRST(RTEMS_SYSINIT_POSIX_MUTEX)
+{
+ assert(_POSIX_Mutex_Information.maximum == 0);
+ next_step(POSIX_MUTEX_PRE);
+}
+
+LAST(RTEMS_SYSINIT_POSIX_MUTEX)
+{
+ assert(_POSIX_Mutex_Information.maximum != 0);
+ next_step(POSIX_MUTEX_POST);
+}
+
static size_t user_extensions_pre_posix_cleanup;
FIRST(RTEMS_SYSINIT_POSIX_CLEANUP)
@@ -506,6 +521,8 @@ static void Init(rtems_task_argument arg)
#ifdef RTEMS_POSIX_API
+#define CONFIGURE_MAXIMUM_POSIX_MUTEXES 1
+
#define CONFIGURE_MAXIMUM_POSIX_CONDITION_VARIABLES 1
#define CONFIGURE_MAXIMUM_POSIX_THREADS 1