[PATCH 08/11] rtems: Generate <rtems/rtems/attr.h>
Sebastian Huber
sebastian.huber at embedded-brains.de
Mon Nov 9 14:49:36 UTC 2020
Change license to BSD-2-Clause according to file histories and
documentation re-licensing agreement.
Update #3899.
Update #3993.
---
cpukit/include/rtems/rtems/attr.h | 312 +++++++++++++++++++++---------
1 file changed, 223 insertions(+), 89 deletions(-)
diff --git a/cpukit/include/rtems/rtems/attr.h b/cpukit/include/rtems/rtems/attr.h
index 74ed96fdba..c0bc990c45 100644
--- a/cpukit/include/rtems/rtems/attr.h
+++ b/cpukit/include/rtems/rtems/attr.h
@@ -1,188 +1,322 @@
+/* SPDX-License-Identifier: BSD-2-Clause */
+
/**
* @file
*
- * @ingroup ClassicAttributes
+ * @brief This header file provides Classic API directive attributes.
+ */
+
+/*
+ * Copyright (C) 2014, 2020 embedded brains GmbH (http://www.embedded-brains.de)
+ * Copyright (C) 2008 On-Line Applications Research Corporation (OAR)
+ *
+ * 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 include file contains all information about the Object Attributes
- * Handler.
+ * 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.
*/
-/* COPYRIGHT (c) 1989-2008.
- * On-Line Applications Research Corporation (OAR).
+/*
+ * Do not manually edit this file. It is part of the RTEMS quality process
+ * and was automatically generated.
*
- * 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 you find something that needs to be fixed or worded better please
+ * post a report to an RTEMS mailing list or raise a bug report:
+ *
+ * https://docs.rtems.org/branches/master/user/support/bugs.html
+ *
+ * For information on updating and regenerating please refer to:
+ *
+ * https://docs.rtems.org/branches/master/eng/req/howto.html
*/
+/* Generated from spec:/rtems/attr/if/header */
+
#ifndef _RTEMS_RTEMS_ATTR_H
#define _RTEMS_RTEMS_ATTR_H
-#include <rtems/score/basedefs.h>
+#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
+/* Generated from spec:/rtems/attr/if/group */
+
/**
- * @defgroup ClassicAttributes Attributes
+ * @defgroup RTEMSAPIClassicAttr Directive Attributes
*
- * @ingroup RTEMSAPIClassic
+ * @ingroup RTEMSAPIClassic
*
- * This encapsulates functionality which defines and manages the
- * set of Classic API object attributes.
+ * @brief This group contains the Classic API directive attributes.
*/
-/**@{*/
+
+/* Generated from spec:/rtems/attr/if/application-task */
/**
- * This defines the type used to contain Classic API attributes. These
- * are primarily used when creating objects.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API task created
+ * by rtems_task_create() or rtems_task_construct() shall be an application
+ * task.
*/
-typedef uint32_t rtems_attribute;
-
-/** This is the default value for an attribute set. */
+#define RTEMS_APPLICATION_TASK 0x00000000
-#define RTEMS_DEFAULT_ATTRIBUTES 0x00000000
+/* Generated from spec:/rtems/attr/if/attribute */
/**
- * This is the attribute constant to indicate local resource.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This type represents Classic API attributes.
+ *
+ * Attributes are primarily used when creating objects.
*/
-#define RTEMS_LOCAL 0x00000000
+typedef uint32_t rtems_attribute;
+
+/* Generated from spec:/rtems/attr/if/barrier-automatic-release */
/**
- * This is the attribute constant to indicate global resource.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API barrier
+ * created by rtems_barrier_create() shall use the automatic release
+ * protocol.
*/
-#define RTEMS_GLOBAL 0x00000002
+#define RTEMS_BARRIER_AUTOMATIC_RELEASE 0x00000200
+
+/* Generated from spec:/rtems/attr/if/barrier-manual-release */
/**
- * This is the attribute constant which reflects that blocking
- * tasks will be managed using FIFO discipline.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API barrier
+ * created by rtems_barrier_create() shall use the manual release protocol.
*/
-#define RTEMS_FIFO 0x00000000
+#define RTEMS_BARRIER_MANUAL_RELEASE 0x00000000
+
+/* Generated from spec:/rtems/attr/if/binary-semaphore */
/**
- * This is the attribute constant which reflects that blocking
- * tasks will be managed using task priority discipline.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() shall be a proper binary semaphore or
+ * mutex.
*/
-#define RTEMS_PRIORITY 0x00000004
+#define RTEMS_BINARY_SEMAPHORE 0x00000010
-/******************** RTEMS Task Specific Attributes *********************/
+/* Generated from spec:/rtems/attr/if/counting-semaphore */
/**
- * This attribute constant indicates that the task will not use the
- * floating point hardware. If the architecture permits it, then
- * the FPU will be disabled when the task is executing.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() shall be a counting semaphore.
*/
-#define RTEMS_NO_FLOATING_POINT 0x00000000
+#define RTEMS_COUNTING_SEMAPHORE 0x00000000
+
+/* Generated from spec:/rtems/attr/if/default */
/**
- * This attribute constant indicates that the task will use the
- * floating point hardware. There will be a floating point
- * context associated with this task.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant represents the default attribute set.
*/
-#define RTEMS_FLOATING_POINT 0x00000001
+#define RTEMS_DEFAULT_ATTRIBUTES 0x00000000
-/***************** RTEMS Semaphore Specific Attributes ********************/
+/* Generated from spec:/rtems/attr/if/fifo */
/**
- * This is the mask for the attribute bits associated with the
- * Classic API Semaphore Manager.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API object shall
+ * manage blocking tasks using the FIFO discipline.
*/
-#define RTEMS_SEMAPHORE_CLASS 0x00000030
+#define RTEMS_FIFO 0x00000000
+
+/* Generated from spec:/rtems/attr/if/floating-point */
/**
- * This attribute constant indicates that the Classic API Semaphore
- * instance created will be a counting semaphore.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API task created
+ * by rtems_task_create() or rtems_task_construct() shall be able to use the
+ * floating point hardware.
+ *
+ * On some architectures, there will be a floating point context associated
+ * with this task.
*/
-#define RTEMS_COUNTING_SEMAPHORE 0x00000000
+#define RTEMS_FLOATING_POINT 0x00000001
+
+/* Generated from spec:/rtems/attr/if/global */
/**
- * This attribute constant indicates that the Classic API Semaphore
- * instance created will be a proper binary semaphore or mutex.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API object shall
+ * be a global resource in a multiprocessing network.
+ *
+ * This attribute does not refer to SMP systems.
*/
-#define RTEMS_BINARY_SEMAPHORE 0x00000010
+#define RTEMS_GLOBAL 0x00000002
+
+/* Generated from spec:/rtems/attr/if/inherit-priority */
/**
- * This attribute constant indicates that the Classic API Semaphore
- * instance created will be a simple binary semaphore.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() shall use the Priority Inheritance
+ * Protocol.
+ *
+ * The semaphore shall be a binary semaphore (#RTEMS_BINARY_SEMAPHORE).
*/
-#define RTEMS_SIMPLE_BINARY_SEMAPHORE 0x00000020
+#define RTEMS_INHERIT_PRIORITY 0x00000040
+
+/* Generated from spec:/rtems/attr/if/local */
/**
- * This attribute constant indicates that the Classic API Semaphore
- * instance created will NOT use the Priority Inheritance Protocol.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API object shall
+ * be a local resource in a multiprocessing network.
+ *
+ * This attribute does not refer to SMP systems.
*/
-#define RTEMS_NO_INHERIT_PRIORITY 0x00000000
+#define RTEMS_LOCAL 0x00000000
+
+/* Generated from spec:/rtems/attr/if/multiprocessor-resource-sharing */
/**
- * This attribute constant indicates that the Classic API Semaphore
- * instance created will use the Priority Inheritance Protocol.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() shall use the Multiprocessor Resource
+ * Sharing Protocol.
*
- * @note The semaphore instance must be a binary semaphore.
+ * The semaphore shall be a binary semaphore (#RTEMS_BINARY_SEMAPHORE).
*/
-#define RTEMS_INHERIT_PRIORITY 0x00000040
+#define RTEMS_MULTIPROCESSOR_RESOURCE_SHARING 0x00000100
+
+/* Generated from spec:/rtems/attr/if/no-floating-point */
/**
- * This attribute constant indicates that the Classic API Semaphore
- * instance created will NOT use the Priority Ceiling Protocol.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API task created
+ * by rtems_task_create() or rtems_task_construct() will not use the floating
+ * point hardware.
+ *
+ * If the architecture permits it, then the FPU will be disabled when the task
+ * is executing.
*/
-#define RTEMS_NO_PRIORITY_CEILING 0x00000000
+#define RTEMS_NO_FLOATING_POINT 0x00000000
+
+/* Generated from spec:/rtems/attr/if/no-inherit-priority */
/**
- * This attribute constant indicates that the Classic API Semaphore
- * instance created will use the Priority Ceiling Protocol.
+ * @ingroup RTEMSAPIClassicAttr
*
- * @note The semaphore instance must be a binary semaphore.
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() will not use the Priority Inheritance
+ * Protocol.
*/
-#define RTEMS_PRIORITY_CEILING 0x00000080
+#define RTEMS_NO_INHERIT_PRIORITY 0x00000000
+
+/* Generated from spec:/rtems/attr/if/no-multiprocessor-resource-sharing */
/**
- * This attribute constant indicates that the Classic API Semaphore instance
- * created will NOT use the Multiprocessor Resource Sharing Protocol.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() will not use the Multiprocessor
+ * Resource Sharing Protocol.
*/
#define RTEMS_NO_MULTIPROCESSOR_RESOURCE_SHARING 0x00000000
+/* Generated from spec:/rtems/attr/if/no-priority-ceiling */
+
/**
- * This attribute constant indicates that the Classic API Semaphore instance
- * created will use the Multiprocessor Resource Sharing Protocol.
+ * @ingroup RTEMSAPIClassicAttr
*
- * @note The semaphore instance must be a binary semaphore.
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() will not use the Priority Ceiling
+ * Protocol.
*/
-#define RTEMS_MULTIPROCESSOR_RESOURCE_SHARING 0x00000100
+#define RTEMS_NO_PRIORITY_CEILING 0x00000000
-/******************** RTEMS Barrier Specific Attributes ********************/
+/* Generated from spec:/rtems/attr/if/priority */
/**
- * This attribute constant indicates that the Classic API Barrier
- * instance created will use an automatic release protocol.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API object shall
+ * manage blocking tasks using the task priority discipline.
*/
-#define RTEMS_BARRIER_AUTOMATIC_RELEASE 0x00000200
+#define RTEMS_PRIORITY 0x00000004
+
+/* Generated from spec:/rtems/attr/if/priority-ceiling */
/**
- * This attribute constant indicates that the Classic API Barrier
- * instance created will use the manual release protocol.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() shall use the Priority Ceiling
+ * Protocol.
+ *
+ * The semaphore shall be a binary semaphore (#RTEMS_BINARY_SEMAPHORE).
*/
-#define RTEMS_BARRIER_MANUAL_RELEASE 0x00000000
+#define RTEMS_PRIORITY_CEILING 0x00000080
-/**************** RTEMS Internal Task Specific Attributes ****************/
+/* Generated from spec:/rtems/attr/if/semaphore-class */
/**
- * This attribute constant indicates that the task was created
- * by the application using normal Classic API methods.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant represents the mask of bits associated with
+ * the Classic API semaphore classes #RTEMS_BINARY_SEMAPHORE,
+ * #RTEMS_COUNTING_SEMAPHORE, and #RTEMS_SIMPLE_BINARY_SEMAPHORE.
*/
-#define RTEMS_APPLICATION_TASK 0x00000000
+#define RTEMS_SEMAPHORE_CLASS 0x00000030
+
+/* Generated from spec:/rtems/attr/if/simple-binary-semaphore */
/**
- * This attribute constant indicates that the task was created
- * by RTEMS as a support task.
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API semaphore
+ * created by rtems_semaphore_create() shall be a simple binary semaphore.
*/
-#define RTEMS_SYSTEM_TASK 0x00008000
+#define RTEMS_SIMPLE_BINARY_SEMAPHORE 0x00000020
-/**@}*/
+/* Generated from spec:/rtems/attr/if/system-task */
+
+/**
+ * @ingroup RTEMSAPIClassicAttr
+ *
+ * @brief This attribute constant indicates that the Classic API task created
+ * by rtems_task_create() or rtems_task_construct() shall be a system task.
+ */
+#define RTEMS_SYSTEM_TASK 0x00008000
#ifdef __cplusplus
}
#endif
-#endif
-/* end of include file */
+#endif /* _RTEMS_RTEMS_ATTR_H */
--
2.26.2
More information about the devel
mailing list