[PATCH v2 31/44] config: Add <rtems/confdefs/mcpi.h>

Sebastian Huber sebastian.huber at embedded-brains.de
Fri Feb 21 10:52:43 UTC 2020


Remove all comments and copyrightable content from the moved content.
Use BSD-2-Clause license for new file.

Update #3053.
Update #3875.
---
 cpukit/headers.am                    |   1 +
 cpukit/include/rtems/confdefs.h      | 116 +--------------------------
 cpukit/include/rtems/confdefs/mpci.h | 147 +++++++++++++++++++++++++++++++++++
 3 files changed, 149 insertions(+), 115 deletions(-)
 create mode 100644 cpukit/include/rtems/confdefs/mpci.h

diff --git a/cpukit/headers.am b/cpukit/headers.am
index 84e9523718..20059a7909 100644
--- a/cpukit/headers.am
+++ b/cpukit/headers.am
@@ -188,6 +188,7 @@ include_rtems_confdefs_HEADERS += include/rtems/confdefs/bsp.h
 include_rtems_confdefs_HEADERS += include/rtems/confdefs/libio.h
 include_rtems_confdefs_HEADERS += include/rtems/confdefs/libpci.h
 include_rtems_confdefs_HEADERS += include/rtems/confdefs/malloc.h
+include_rtems_confdefs_HEADERS += include/rtems/confdefs/mpci.h
 include_rtems_confdefs_HEADERS += include/rtems/confdefs/obsolete.h
 include_rtems_confdefs_HEADERS += include/rtems/confdefs/percpu.h
 include_rtems_confdefs_HEADERS += include/rtems/confdefs/scheduler.h
diff --git a/cpukit/include/rtems/confdefs.h b/cpukit/include/rtems/confdefs.h
index 4f1ba45de8..a28e277311 100644
--- a/cpukit/include/rtems/confdefs.h
+++ b/cpukit/include/rtems/confdefs.h
@@ -54,6 +54,7 @@
 #include <rtems/confdefs/libio.h>
 #include <rtems/confdefs/libpci.h>
 #include <rtems/confdefs/malloc.h>
+#include <rtems/confdefs/mpci.h>
 #include <rtems/confdefs/percpu.h>
 #include <rtems/confdefs/scheduler.h>
 
@@ -426,108 +427,6 @@ extern "C" {
 #endif
 /**@}*/ /* end of Device Driver Table Configuration */
 
-/**
- * @defgroup ConfigurationMultiprocessing Multiprocessing Configuration
- *
- * @addtogroup Configuration
- *
- * This module contains the parameters related to the Multiprocessing
- * configuration of RTEMS.
- *
- * In a single processor or SMP configuration, only two parameters are
- * needed and they are defaulted. The user should not have to specify
- * any parameters.
- */
-/**@{*/
-
-/**
- * This defines the extra stack space required for the MPCI server thread.
- */
-#ifndef CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK
-  #define CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK 0
-#endif
-
-#if defined(RTEMS_MULTIPROCESSING)
-  /*
-   *  Default Multiprocessing Configuration Table.  The defaults are
-   *  appropriate for most of the RTEMS Multiprocessor Test Suite.  Each
-   *  value may be overridden within each test to customize the environment.
-   */
-
-  #ifdef CONFIGURE_MP_APPLICATION
-    #ifndef CONFIGURE_MP_NODE_NUMBER
-      #define CONFIGURE_MP_NODE_NUMBER                NODE_NUMBER
-    #endif
-
-    #ifndef CONFIGURE_MP_MAXIMUM_NODES
-      #define CONFIGURE_MP_MAXIMUM_NODES              2
-    #endif
-
-    #ifndef CONFIGURE_MP_MAXIMUM_GLOBAL_OBJECTS
-      #define CONFIGURE_MP_MAXIMUM_GLOBAL_OBJECTS     32
-    #endif
-
-    #ifndef CONFIGURE_MP_MAXIMUM_PROXIES
-      #define CONFIGURE_MP_MAXIMUM_PROXIES            32
-    #endif
-
-    #ifndef CONFIGURE_MP_MPCI_TABLE_POINTER
-      #include <mpci.h>
-      #define CONFIGURE_MP_MPCI_TABLE_POINTER         &MPCI_table
-    #endif
-
-    #ifdef CONFIGURE_INIT
-      #if CONFIGURE_MP_NODE_NUMBER < 1
-        #error "CONFIGURE_MP_NODE_NUMBER must be greater than or equal to one"
-      #endif
-
-      #if CONFIGURE_MP_NODE_NUMBER > CONFIGURE_MP_MAXIMUM_NODES
-        #error "CONFIGURE_MP_NODE_NUMBER must be less than or equal to CONFIGURE_MP_MAXIMUM_NODES"
-      #endif
-
-      Objects_MP_Control _Objects_MP_Controls[
-        CONFIGURE_MP_MAXIMUM_GLOBAL_OBJECTS
-      ];
-
-      struct Thread_Configured_proxy_control {
-        Thread_Proxy_control Control;
-        Thread_queue_Configured_heads Heads;
-      };
-
-      static Thread_Configured_proxy_control _Thread_MP_Configured_proxies[
-        CONFIGURE_MP_MAXIMUM_PROXIES
-      ];
-
-      Thread_Configured_proxy_control * const _Thread_MP_Proxies =
-        &_Thread_MP_Configured_proxies[ 0 ];
-
-      const MPCI_Configuration _MPCI_Configuration = {
-        CONFIGURE_MP_NODE_NUMBER,               /* local node number */
-        CONFIGURE_MP_MAXIMUM_NODES,             /* maximum # nodes */
-        CONFIGURE_MP_MAXIMUM_GLOBAL_OBJECTS,    /* maximum # global objects */
-        CONFIGURE_MP_MAXIMUM_PROXIES,           /* maximum # proxies */
-        CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK, /* MPCI stack > minimum */
-        CONFIGURE_MP_MPCI_TABLE_POINTER         /* ptr to MPCI config table */
-      };
-
-      char _MPCI_Receive_server_stack[
-        CONFIGURE_MINIMUM_TASK_STACK_SIZE
-          + CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK
-          + CPU_MPCI_RECEIVE_SERVER_EXTRA_STACK
-          + CPU_ALL_TASKS_ARE_FP * CONTEXT_FP_SIZE
-      ] RTEMS_ALIGNED( CPU_INTERRUPT_STACK_ALIGNMENT )
-      RTEMS_SECTION( ".rtemsstack.mpci" );
-    #endif
-
-    #define _CONFIGURE_MPCI_RECEIVE_SERVER_COUNT 1
-  #else
-    #define _CONFIGURE_MPCI_RECEIVE_SERVER_COUNT 0
-  #endif /* CONFIGURE_MP_APPLICATION */
-#else
-  #define _CONFIGURE_MPCI_RECEIVE_SERVER_COUNT 0
-#endif /* RTEMS_MULTIPROCESSING */
-/**@}*/ /* end of Multiprocessing Configuration */
-
 /**
  * This macro specifies that the user wants to use unlimited objects for any
  * classic or posix objects that have not already been given resource limits.
@@ -1090,10 +989,6 @@ struct _reent *__getreent(void)
 #define _CONFIGURE_TASKS_STACK 0
 #define _CONFIGURE_POSIX_THREADS_STACK 0
 
-#if CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK != 0
-  #error "CONFIGURE_EXECUTIVE_RAM_SIZE defined with request for CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK"
-#endif
-
 #if CONFIGURE_EXTRA_TASK_STACKS != 0
   #error "CONFIGURE_EXECUTIVE_RAM_SIZE defined with request for CONFIGURE_EXTRA_TASK_STACKS"
 #endif
@@ -1524,15 +1419,6 @@ struct _reent *__getreent(void)
 #endif
 #endif
 
-/*
- *  If the user is trying to configure a multiprocessing application and
- *  RTEMS was not configured and built multiprocessing, then error out.
- */
-#if defined(CONFIGURE_MP_APPLICATION) && \
-    !defined(RTEMS_MULTIPROCESSING)
-#error "CONFIGURATION ERROR: RTEMS not configured for multiprocessing!!"
-#endif
-
 #if !defined(RTEMS_SCHEDSIM)
 /*
  *  You must either explicitly include or exclude the clock driver.
diff --git a/cpukit/include/rtems/confdefs/mpci.h b/cpukit/include/rtems/confdefs/mpci.h
new file mode 100644
index 0000000000..053439bb2e
--- /dev/null
+++ b/cpukit/include/rtems/confdefs/mpci.h
@@ -0,0 +1,147 @@
+/*
+ * SPDX-License-Identifier: BSD-2-Clause
+ *
+ * Copyright (C) 2020 embedded brains GmbH (http://www.embedded-brains.de)
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/**
+ * @file
+ *
+ * @ingroup RTEMSApplicationConfiguration
+ *
+ * @brief Evaluate MPCI Configuration Options
+ *
+ * This header file defines _CONFIGURE_MPCI_RECEIVE_SERVER_COUNT for use by
+ * other configuration header files.
+ */
+
+#ifndef _RTEMS_CONFDEFS_MPCI_H
+#define _RTEMS_CONFDEFS_MPCI_H
+
+#ifndef __CONFIGURATION_TEMPLATE_h
+#error "Do not include this file directly, use <rtems/confdefs.h> instead"
+#endif
+
+#ifdef CONFIGURE_INIT
+
+#ifdef RTEMS_MULTIPROCESSING
+
+#include <mpci.h>
+
+#ifdef CONFIGURE_MP_APPLICATION
+
+#ifndef CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK
+  #define CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK 0
+#endif
+
+#ifndef CONFIGURE_MP_NODE_NUMBER
+  #define CONFIGURE_MP_NODE_NUMBER NODE_NUMBER
+#endif
+
+#ifndef CONFIGURE_MP_MAXIMUM_NODES
+  #define CONFIGURE_MP_MAXIMUM_NODES 2
+#endif
+
+#ifndef CONFIGURE_MP_MAXIMUM_GLOBAL_OBJECTS
+  #define CONFIGURE_MP_MAXIMUM_GLOBAL_OBJECTS 32
+#endif
+
+#ifndef CONFIGURE_MP_MAXIMUM_PROXIES
+  #define CONFIGURE_MP_MAXIMUM_PROXIES 32
+#endif
+
+#ifndef CONFIGURE_MP_MPCI_TABLE_POINTER
+  #define CONFIGURE_MP_MPCI_TABLE_POINTER &MPCI_table
+#endif
+
+#if CONFIGURE_MP_NODE_NUMBER < 1
+  #error "CONFIGURE_MP_NODE_NUMBER must be greater than or equal to one"
+#endif
+
+#if CONFIGURE_MP_NODE_NUMBER > CONFIGURE_MP_MAXIMUM_NODES
+  #error "CONFIGURE_MP_NODE_NUMBER must be less than or equal to CONFIGURE_MP_MAXIMUM_NODES"
+#endif
+
+#define _CONFIGURE_MPCI_RECEIVE_SERVER_COUNT 1
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+Objects_MP_Control _Objects_MP_Controls[
+  CONFIGURE_MP_MAXIMUM_GLOBAL_OBJECTS
+];
+
+struct Thread_Configured_proxy_control {
+  Thread_Proxy_control Control;
+  Thread_queue_Configured_heads Heads;
+};
+
+static Thread_Configured_proxy_control _Thread_MP_Configured_proxies[
+  CONFIGURE_MP_MAXIMUM_PROXIES
+];
+
+Thread_Configured_proxy_control * const _Thread_MP_Proxies =
+  &_Thread_MP_Configured_proxies[ 0 ];
+
+const MPCI_Configuration _MPCI_Configuration = {
+  CONFIGURE_MP_NODE_NUMBER,
+  CONFIGURE_MP_MAXIMUM_NODES,
+  CONFIGURE_MP_MAXIMUM_GLOBAL_OBJECTS,
+  CONFIGURE_MP_MAXIMUM_PROXIES,
+  CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK,
+  CONFIGURE_MP_MPCI_TABLE_POINTER
+};
+
+char _MPCI_Receive_server_stack[
+  CONFIGURE_MINIMUM_TASK_STACK_SIZE
+    + CONFIGURE_EXTRA_MPCI_RECEIVE_SERVER_STACK
+    + CPU_MPCI_RECEIVE_SERVER_EXTRA_STACK
+    + CPU_ALL_TASKS_ARE_FP * CONTEXT_FP_SIZE
+] RTEMS_ALIGNED( CPU_INTERRUPT_STACK_ALIGNMENT )
+RTEMS_SECTION( ".rtemsstack.mpci" );
+
+#ifdef __cplusplus
+}
+#endif
+
+#else /* CONFIGURE_MP_APPLICATION */
+
+#define _CONFIGURE_MPCI_RECEIVE_SERVER_COUNT 0
+
+#endif /* CONFIGURE_MP_APPLICATION */
+
+#else /* RTEMS_MULTIPROCESSING */
+
+#ifdef CONFIGURE_MP_APPLICATION
+  #error "CONFIGURE_MP_APPLICATION must not be defined if multiprocessing is disabled"
+#endif
+
+#define _CONFIGURE_MPCI_RECEIVE_SERVER_COUNT 0
+
+#endif /* RTEMS_MULTIPROCESSING */
+
+#endif /* CONFIGURE_INIT */
+
+#endif /* _RTEMS_CONFDEFS_MPCI_H */
-- 
2.16.4



More information about the devel mailing list