[rtems commit] posix: Allow PTHREAD_PROCESS_SHARED for rwlocks

Sebastian Huber sebh at rtems.org
Fri Sep 22 06:46:50 UTC 2017


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

Author:    Sebastian Huber <sebastian.huber at embedded-brains.de>
Date:      Fri Sep 22 08:22:11 2017 +0200

posix: Allow PTHREAD_PROCESS_SHARED for rwlocks

Close #3153.

---

 cpukit/posix/src/prwlockinit.c         | 30 +++++++--------------------
 testsuites/psxtests/psxrwlock01/test.c | 38 ++++++++++++++++++++++++++++++++++
 2 files changed, 45 insertions(+), 23 deletions(-)

diff --git a/cpukit/posix/src/prwlockinit.c b/cpukit/posix/src/prwlockinit.c
index 34ab1ae..ffce814 100644
--- a/cpukit/posix/src/prwlockinit.c
+++ b/cpukit/posix/src/prwlockinit.c
@@ -58,9 +58,7 @@ int pthread_rwlock_init(
   const pthread_rwlockattr_t *attr
 )
 {
-  POSIX_RWLock_Control        *the_rwlock;
-  pthread_rwlockattr_t         default_attr;
-  const pthread_rwlockattr_t  *the_attr;
+  POSIX_RWLock_Control *the_rwlock;
 
   /*
    *  Error check parameters
@@ -68,28 +66,14 @@ int pthread_rwlock_init(
   if ( !rwlock )
     return EINVAL;
 
-  /*
-   * If the user passed in NULL, use the default attributes
-   */
-  if ( attr ) {
-    the_attr = attr;
-  } else {
-    (void) pthread_rwlockattr_init( &default_attr );
-    the_attr = &default_attr;
-  }
-
-  /*
-   * Now start error checking the attributes that we are going to use
-   */
-  if ( !the_attr->is_initialized )
-    return EINVAL;
+  if ( attr != NULL ) {
+    if ( !attr->is_initialized ) {
+      return EINVAL;
+    }
 
-  switch ( the_attr->process_shared ) {
-    case PTHREAD_PROCESS_PRIVATE:    /* only supported values */
-      break;
-    case PTHREAD_PROCESS_SHARED:
-    default:
+    if ( !_POSIX_Is_valid_pshared( attr->process_shared ) ) {
       return EINVAL;
+    }
   }
 
   the_rwlock = _POSIX_RWLock_Allocate();
diff --git a/testsuites/psxtests/psxrwlock01/test.c b/testsuites/psxtests/psxrwlock01/test.c
index e201293..268f581 100644
--- a/testsuites/psxtests/psxrwlock01/test.c
+++ b/testsuites/psxtests/psxrwlock01/test.c
@@ -90,6 +90,42 @@ void *WriteLockThread(void *arg)
   return NULL;
 }
 
+static void test_pshared_init(void)
+{
+  pthread_rwlock_t rwlock;
+  pthread_rwlockattr_t attr;
+  int eno;
+
+  eno = pthread_rwlockattr_init(&attr);
+  rtems_test_assert(eno == 0);
+
+  eno = pthread_rwlockattr_setpshared(&attr, PTHREAD_PROCESS_PRIVATE);
+  rtems_test_assert(eno == 0);
+
+  eno = pthread_rwlock_init(&rwlock, &attr);
+  rtems_test_assert(eno == 0);
+
+  eno = pthread_rwlock_destroy(&rwlock);
+  rtems_test_assert(eno == 0);
+
+  eno = pthread_rwlockattr_setpshared(&attr, PTHREAD_PROCESS_SHARED);
+  rtems_test_assert(eno == 0);
+
+  eno = pthread_rwlock_init(&rwlock, &attr);
+  rtems_test_assert(eno == 0);
+
+  eno = pthread_rwlock_destroy(&rwlock);
+  rtems_test_assert(eno == 0);
+
+  attr.process_shared = -1;
+
+  eno = pthread_rwlock_init(&rwlock, &attr);
+  rtems_test_assert(eno == EINVAL);
+
+  eno = pthread_rwlockattr_destroy(&attr);
+  rtems_test_assert(eno == 0);
+}
+
 /*
  *  main entry point to the test
  */
@@ -113,6 +149,8 @@ int main(
 
   TEST_BEGIN();
 
+  test_pshared_init();
+
   /*************** NULL POINTER CHECKS *****************/
   puts( "pthread_rwlockattr_init( NULL ) -- EINVAL" );
   status = pthread_rwlockattr_init( NULL );



More information about the vc mailing list