From 57c676c626268aa8457e1de81921b68418a32ff5 Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Thu, 16 Jun 2016 10:44:00 +0200 Subject: rtems: Fix rtems_semaphore_create() Destroy the thread queue in case of a priority ceiling violation, otherwise the SMP profiling data gets corrupted. --- cpukit/rtems/src/semcreate.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/cpukit/rtems/src/semcreate.c b/cpukit/rtems/src/semcreate.c index 0f8bdcbbe5..bb1c6b4e61 100644 --- a/cpukit/rtems/src/semcreate.c +++ b/cpukit/rtems/src/semcreate.c @@ -173,6 +173,10 @@ rtems_status_code rtems_semaphore_create( executing, &queue_context ); + + if ( status != STATUS_SUCCESSFUL ) { + _Thread_queue_Destroy( &the_semaphore->Core_control.Wait_queue ); + } } else { status = STATUS_SUCCESSFUL; } -- cgit v1.2.3