summaryrefslogtreecommitdiffstats
path: root/cpukit/rtems/src/getapiconfig.c
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2020-02-14 09:48:41 +0100
committerSebastian Huber <sebastian.huber@embedded-brains.de>2020-02-25 07:15:18 +0100
commit9bdb6aa31cc3d0bdafc5fbf870d6fa0ec14902c4 (patch)
treeb0c026973ee6bcdb36db5db845f179d2bd84a754 /cpukit/rtems/src/getapiconfig.c
parentrtems: Simplify _RTEMS_tasks_Initialize_user_task() (diff)
downloadrtems-9bdb6aa31cc3d0bdafc5fbf870d6fa0ec14902c4.tar.bz2
config: Bring back RTEMS 4.11 configuration table
This improves API backward compatibility of RTEMS 5.1 to previous versions.
Diffstat (limited to 'cpukit/rtems/src/getapiconfig.c')
-rw-r--r--cpukit/rtems/src/getapiconfig.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/cpukit/rtems/src/getapiconfig.c b/cpukit/rtems/src/getapiconfig.c
index 77c60cfe1c..088ea5909f 100644
--- a/cpukit/rtems/src/getapiconfig.c
+++ b/cpukit/rtems/src/getapiconfig.c
@@ -37,6 +37,24 @@ static rtems_api_configuration_table config;
const rtems_api_configuration_table *
rtems_configuration_get_rtems_api_configuration( void )
{
+ /*
+ * Always initialize the configuration table and do not bother with
+ * synchronization issues. This function is not performance critical. The
+ * configuration values are all constants.
+ */
+
+ config.notepads_enabled = false;
+ config.maximum_tasks = rtems_configuration_get_maximum_tasks();
+ config.maximum_timers = rtems_configuration_get_maximum_timers();
+ config.maximum_semaphores = rtems_configuration_get_maximum_semaphores();
+ config.maximum_message_queues =
+ rtems_configuration_get_maximum_message_queues();
+ config.maximum_partitions = rtems_configuration_get_maximum_partitions();
+ config.maximum_regions = rtems_configuration_get_maximum_regions();
+ config.maximum_ports = rtems_configuration_get_maximum_ports();
+ config.maximum_periods = rtems_configuration_get_maximum_periods();
+ config.maximum_barriers = rtems_configuration_get_maximum_barriers();
+
if ( _RTEMS_tasks_User_task_table.entry_point != NULL ) {
config.number_of_initialization_tasks = 1;
config.User_initialization_tasks_table = &_RTEMS_tasks_User_task_table;