summaryrefslogtreecommitdiffstats
path: root/cpukit/score/src
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2015-02-28 18:06:37 +0100
committerSebastian Huber <sebastian.huber@embedded-brains.de>2015-03-05 11:36:40 +0100
commit43e1573c1f02194a4fa754dfbff51862130742a5 (patch)
treefa7aed77417ebfc87cf9cb00c81c5a1533db7aa8 /cpukit/score/src
parentscore: Thread dispatch dis/enable without Giant (diff)
downloadrtems-43e1573c1f02194a4fa754dfbff51862130742a5.tar.bz2
score: Add ISR lock to Objects_Control
This enables per-object SMP locks on SMP configurations and is the first step to support fine-grained locking. On uni-processor configuration there will be no overhead. The _Objects_Acquire() is intended to replace _Objects_Get_isr_disable(). Update #2273.
Diffstat (limited to 'cpukit/score/src')
-rw-r--r--cpukit/score/src/objectacquire.c80
-rw-r--r--cpukit/score/src/objectclose.c2
2 files changed, 82 insertions, 0 deletions
diff --git a/cpukit/score/src/objectacquire.c b/cpukit/score/src/objectacquire.c
new file mode 100644
index 0000000000..57d38f47bd
--- /dev/null
+++ b/cpukit/score/src/objectacquire.c
@@ -0,0 +1,80 @@
+/**
+ * @file
+ *
+ * @brief Object Acquire
+ *
+ * @ingroup ScoreObject
+ */
+
+/*
+ * Copyright (c) 2015 embedded brains GmbH. All rights reserved.
+ *
+ * embedded brains GmbH
+ * Dornierstr. 4
+ * 82178 Puchheim
+ * Germany
+ * <rtems@embedded-brains.de>
+ *
+ * The license and distribution terms for this file may be
+ * found in the file LICENSE in this distribution or at
+ * http://www.rtems.org/license/LICENSE.
+ */
+
+#if HAVE_CONFIG_H
+ #include "config.h"
+#endif
+
+#include <rtems/score/objectimpl.h>
+
+Objects_Control *_Objects_Acquire(
+ const Objects_Information *information,
+ Objects_Id id,
+ Objects_Locations *location,
+ ISR_lock_Context *lock_context
+)
+{
+ Objects_Control *the_object;
+ uint32_t index;
+
+ index = id - information->minimum_id + 1;
+
+ if ( information->maximum >= index ) {
+ /*
+ * On uni-processor configurations we disable interrupts before we use the
+ * local table. This prevents use of freed memory in case the object
+ * information is extended in between. On SMP configurations bad things
+ * can happen, see https://devel.rtems.org/ticket/2280.
+ */
+#if !defined(RTEMS_SMP)
+ ISR_Level level;
+
+ _ISR_Disable( level );
+#endif
+ if ( ( the_object = information->local_table[ index ] ) != NULL ) {
+ *location = OBJECTS_LOCAL;
+#if defined(RTEMS_SMP)
+ _ISR_lock_ISR_disable_and_acquire( &the_object->Lock, lock_context );
+#else
+ lock_context->isr_level = level;
+#endif
+
+ return the_object;
+ }
+#if !defined(RTEMS_SMP)
+ _ISR_Enable( level );
+#endif
+ *location = OBJECTS_ERROR;
+
+ return NULL;
+ }
+
+ *location = OBJECTS_ERROR;
+
+#if defined(RTEMS_MULTIPROCESSING)
+ _Objects_MP_Is_remote( information, id, location, &the_object );
+
+ return the_object;
+#else
+ return NULL;
+#endif
+}
diff --git a/cpukit/score/src/objectclose.c b/cpukit/score/src/objectclose.c
index 52eb10c60b..25c7aa1a36 100644
--- a/cpukit/score/src/objectclose.c
+++ b/cpukit/score/src/objectclose.c
@@ -28,4 +28,6 @@ void _Objects_Close(
_Objects_Invalidate_Id( information, the_object );
_Objects_Namespace_remove( information, the_object );
+
+ _ISR_lock_Destroy( &the_object->Lock );
}