From 1047f37cac02909b33d16462f14dc5f45e98d376 Mon Sep 17 00:00:00 2001 From: Joel Sherrill Date: Tue, 14 Apr 2015 12:11:51 -0500 Subject: semdestroy.c: Add missing _Objects_Allocator_unlock() closes 2319. --- cpukit/posix/src/semdestroy.c | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/cpukit/posix/src/semdestroy.c b/cpukit/posix/src/semdestroy.c index 1c695bb837..9a8a993c81 100644 --- a/cpukit/posix/src/semdestroy.c +++ b/cpukit/posix/src/semdestroy.c @@ -44,19 +44,18 @@ int sem_destroy( case OBJECTS_LOCAL: /* - * Undefined operation on a named semaphore. + * Undefined operation on a named semaphore. Release the object + * and fall to the EINVAL return at the bottom. */ - if ( the_semaphore->named == true ) { _Objects_Put( &the_semaphore->Object ); - rtems_set_errno_and_return_minus_one( EINVAL ); + } else { + _POSIX_Semaphore_Delete( the_semaphore ); + _Objects_Put( &the_semaphore->Object ); + _Objects_Allocator_unlock(); + return 0; } - _POSIX_Semaphore_Delete( the_semaphore ); - _Objects_Put( &the_semaphore->Object ); - _Objects_Allocator_unlock(); - return 0; - #if defined(RTEMS_MULTIPROCESSING) case OBJECTS_REMOTE: #endif -- cgit v1.2.3