summaryrefslogtreecommitdiffstats
path: root/testsuites/sptests/spsysinit01/init.c
diff options
context:
space:
mode:
Diffstat (limited to 'testsuites/sptests/spsysinit01/init.c')
-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