summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--c/src/exec/posix/src/keycreate.c42
-rw-r--r--c/src/exec/posix/src/keydelete.c3
-rw-r--r--cpukit/posix/src/keycreate.c42
-rw-r--r--cpukit/posix/src/keydelete.c3
4 files changed, 56 insertions, 34 deletions
diff --git a/c/src/exec/posix/src/keycreate.c b/c/src/exec/posix/src/keycreate.c
index da6b4d40af..f5409b31e9 100644
--- a/c/src/exec/posix/src/keycreate.c
+++ b/c/src/exec/posix/src/keycreate.c
@@ -39,28 +39,38 @@ int pthread_key_create(
the_key->destructor = destructor;
+ /*
+ * This is a bit more complex than one might initially expect because
+ * APIs are optional. Thus there may be no ITRON tasks to have keys
+ * for. [NOTE: Currently RTEMS Classic API tasks are not always enabled.]
+ */
+
for ( the_class = OBJECTS_CLASSES_FIRST_THREAD_CLASS;
the_class <= OBJECTS_CLASSES_LAST_THREAD_CLASS;
the_class++ ) {
- bytes_to_allocate =
- (_Objects_Information_table[ the_class ]->maximum + 1) * sizeof( void * );
-
- table = _Workspace_Allocate( bytes_to_allocate );
-
- if ( !table ) {
- for ( --the_class;
- the_class >= OBJECTS_CLASSES_FIRST_THREAD_CLASS;
- the_class-- )
- _Workspace_Free( the_key->Values[ the_class ] );
-
- _POSIX_Keys_Free( the_key );
- _Thread_Enable_dispatch();
- return ENOMEM;
+ if ( _Objects_Information_table[ the_class ] ) {
+ bytes_to_allocate = sizeof( void * ) *
+ (_Objects_Information_table[ the_class ]->maximum + 1);
+ table = _Workspace_Allocate( bytes_to_allocate );
+ if ( !table ) {
+ for ( --the_class;
+ the_class >= OBJECTS_CLASSES_FIRST_THREAD_CLASS;
+ the_class-- )
+ _Workspace_Free( the_key->Values[ the_class ] );
+
+ _POSIX_Keys_Free( the_key );
+ _Thread_Enable_dispatch();
+ return ENOMEM;
+ }
+
+ the_key->Values[ the_class ] = table;
+ memset( table, '\0', bytes_to_allocate );
+ } else {
+ the_key->Values[ the_class ] = NULL;
}
- the_key->Values[ the_class ] = table;
- memset( table, '\0', bytes_to_allocate );
+
}
the_key->is_active = TRUE;
diff --git a/c/src/exec/posix/src/keydelete.c b/c/src/exec/posix/src/keydelete.c
index af012e3638..5d4c93ab1d 100644
--- a/c/src/exec/posix/src/keydelete.c
+++ b/c/src/exec/posix/src/keydelete.c
@@ -38,7 +38,8 @@ int pthread_key_delete(
for ( the_class = OBJECTS_CLASSES_FIRST_THREAD_CLASS;
the_class <= OBJECTS_CLASSES_LAST_THREAD_CLASS;
the_class++ )
- _Workspace_Free( the_key->Values[ the_class ] );
+ if ( the_key->Values[ the_class ] )
+ _Workspace_Free( the_key->Values[ the_class ] );
/*
* NOTE: The destructor is not called and it is the responsibility
diff --git a/cpukit/posix/src/keycreate.c b/cpukit/posix/src/keycreate.c
index da6b4d40af..f5409b31e9 100644
--- a/cpukit/posix/src/keycreate.c
+++ b/cpukit/posix/src/keycreate.c
@@ -39,28 +39,38 @@ int pthread_key_create(
the_key->destructor = destructor;
+ /*
+ * This is a bit more complex than one might initially expect because
+ * APIs are optional. Thus there may be no ITRON tasks to have keys
+ * for. [NOTE: Currently RTEMS Classic API tasks are not always enabled.]
+ */
+
for ( the_class = OBJECTS_CLASSES_FIRST_THREAD_CLASS;
the_class <= OBJECTS_CLASSES_LAST_THREAD_CLASS;
the_class++ ) {
- bytes_to_allocate =
- (_Objects_Information_table[ the_class ]->maximum + 1) * sizeof( void * );
-
- table = _Workspace_Allocate( bytes_to_allocate );
-
- if ( !table ) {
- for ( --the_class;
- the_class >= OBJECTS_CLASSES_FIRST_THREAD_CLASS;
- the_class-- )
- _Workspace_Free( the_key->Values[ the_class ] );
-
- _POSIX_Keys_Free( the_key );
- _Thread_Enable_dispatch();
- return ENOMEM;
+ if ( _Objects_Information_table[ the_class ] ) {
+ bytes_to_allocate = sizeof( void * ) *
+ (_Objects_Information_table[ the_class ]->maximum + 1);
+ table = _Workspace_Allocate( bytes_to_allocate );
+ if ( !table ) {
+ for ( --the_class;
+ the_class >= OBJECTS_CLASSES_FIRST_THREAD_CLASS;
+ the_class-- )
+ _Workspace_Free( the_key->Values[ the_class ] );
+
+ _POSIX_Keys_Free( the_key );
+ _Thread_Enable_dispatch();
+ return ENOMEM;
+ }
+
+ the_key->Values[ the_class ] = table;
+ memset( table, '\0', bytes_to_allocate );
+ } else {
+ the_key->Values[ the_class ] = NULL;
}
- the_key->Values[ the_class ] = table;
- memset( table, '\0', bytes_to_allocate );
+
}
the_key->is_active = TRUE;
diff --git a/cpukit/posix/src/keydelete.c b/cpukit/posix/src/keydelete.c
index af012e3638..5d4c93ab1d 100644
--- a/cpukit/posix/src/keydelete.c
+++ b/cpukit/posix/src/keydelete.c
@@ -38,7 +38,8 @@ int pthread_key_delete(
for ( the_class = OBJECTS_CLASSES_FIRST_THREAD_CLASS;
the_class <= OBJECTS_CLASSES_LAST_THREAD_CLASS;
the_class++ )
- _Workspace_Free( the_key->Values[ the_class ] );
+ if ( the_key->Values[ the_class ] )
+ _Workspace_Free( the_key->Values[ the_class ] );
/*
* NOTE: The destructor is not called and it is the responsibility