[PATCH] score: Move _Thread_queue_Queue_get_name_and_id()
Joel Sherrill
joel at rtems.org
Mon May 17 15:06:21 UTC 2021
Looks ok.
On Mon, May 17, 2021 at 9:59 AM Sebastian Huber <
sebastian.huber at embedded-brains.de> wrote:
> Move this diagnostic function to a separate file since it does not
> provide a core function of the system.
>
> Change license to BSD-2-Clause according to file history and
> re-licensing agreement.
>
> Update #3053.
> ---
> cpukit/Makefile.am | 1 +
> cpukit/score/src/threadq.c | 36 ------------
> cpukit/score/src/threadqgetnameandid.c | 76 ++++++++++++++++++++++++++
> spec/build/cpukit/librtemscpu.yml | 1 +
> 4 files changed, 78 insertions(+), 36 deletions(-)
> create mode 100644 cpukit/score/src/threadqgetnameandid.c
>
> diff --git a/cpukit/Makefile.am b/cpukit/Makefile.am
> index 0178d5d82a..7e7c267fc1 100644
> --- a/cpukit/Makefile.am
> +++ b/cpukit/Makefile.am
> @@ -984,6 +984,7 @@ librtemscpu_a_SOURCES += score/src/threadqenqueue.c
> librtemscpu_a_SOURCES += score/src/threadqextractwithproxy.c
> librtemscpu_a_SOURCES += score/src/threadqfirst.c
> librtemscpu_a_SOURCES += score/src/threadqflush.c
> +librtemscpu_a_SOURCES += score/src/threadqgetnameandid.c
> librtemscpu_a_SOURCES += score/src/threadqops.c
> librtemscpu_a_SOURCES += score/src/threadqtimeout.c
> librtemscpu_a_SOURCES += score/src/timespecaddto.c
> diff --git a/cpukit/score/src/threadq.c b/cpukit/score/src/threadq.c
> index 55d8760f7c..e322b46b5e 100644
> --- a/cpukit/score/src/threadq.c
> +++ b/cpukit/score/src/threadq.c
> @@ -25,11 +25,7 @@
> #include "config.h"
> #endif
>
> -#include <string.h>
> -
> #include <rtems/score/threadqimpl.h>
> -#include <rtems/score/rbtreeimpl.h>
> -#include <rtems/score/threadimpl.h>
>
> RTEMS_STATIC_ASSERT(
> #if defined(RTEMS_SMP)
> @@ -166,35 +162,3 @@ void _Thread_queue_MP_callout_do_nothing(
> /* Do nothing */
> }
> #endif
> -
> -size_t _Thread_queue_Queue_get_name_and_id(
> - const Thread_queue_Queue *queue,
> - char *buffer,
> - size_t buffer_size,
> - Objects_Id *id
> -)
> -{
> - const char *name;
> -
> - name = queue->name;
> -
> - if ( name == _Thread_queue_Object_name ) {
> - const Thread_queue_Object *queue_object;
> -
> - queue_object = THREAD_QUEUE_QUEUE_TO_OBJECT( queue );
> - *id = queue_object->Object.id;
> - return _Objects_Name_to_string(
> - queue_object->Object.name,
> - false,
> - buffer,
> - buffer_size
> - );
> - } else {
> - if ( name == NULL ) {
> - name = _Thread_queue_Object_name;
> - }
> -
> - *id = 0;
> - return strlcpy( buffer, name, buffer_size );
> - }
> -}
> diff --git a/cpukit/score/src/threadqgetnameandid.c
> b/cpukit/score/src/threadqgetnameandid.c
> new file mode 100644
> index 0000000000..ea4e2203e6
> --- /dev/null
> +++ b/cpukit/score/src/threadqgetnameandid.c
> @@ -0,0 +1,76 @@
> +/* SPDX-License-Identifier: BSD-2-Clause */
> +
> +/**
> + * @file
> + *
> + * @ingroup RTEMSScoreThreadQueue
> + *
> + * @brief This source file contains the implementation of
> + * _Thread_queue_Queue_get_name_and_id().
> + */
> +
> +/*
> + * Copyright (C) 2017 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.
> + */
> +
> +#ifdef HAVE_CONFIG_H
> +#include "config.h"
> +#endif
> +
> +#include <rtems/score/threadqimpl.h>
> +#include <rtems/score/objectimpl.h>
> +
> +#include <string.h>
> +
> +size_t _Thread_queue_Queue_get_name_and_id(
> + const Thread_queue_Queue *queue,
> + char *buffer,
> + size_t buffer_size,
> + Objects_Id *id
> +)
> +{
> + const char *name;
> +
> + name = queue->name;
> +
> + if ( name == _Thread_queue_Object_name ) {
> + const Thread_queue_Object *queue_object;
> +
> + queue_object = THREAD_QUEUE_QUEUE_TO_OBJECT( queue );
> + *id = queue_object->Object.id;
> + return _Objects_Name_to_string(
> + queue_object->Object.name,
> + false,
> + buffer,
> + buffer_size
> + );
> + } else {
> + if ( name == NULL ) {
> + name = _Thread_queue_Object_name;
> + }
> +
> + *id = 0;
> + return strlcpy( buffer, name, buffer_size );
> + }
> +}
> diff --git a/spec/build/cpukit/librtemscpu.yml
> b/spec/build/cpukit/librtemscpu.yml
> index 682032182f..ac9e494f0c 100644
> --- a/spec/build/cpukit/librtemscpu.yml
> +++ b/spec/build/cpukit/librtemscpu.yml
> @@ -1542,6 +1542,7 @@ source:
> - cpukit/score/src/threadqextractwithproxy.c
> - cpukit/score/src/threadqfirst.c
> - cpukit/score/src/threadqflush.c
> +- cpukit/score/src/threadqgetnameandid.c
> - cpukit/score/src/threadqops.c
> - cpukit/score/src/threadqtimeout.c
> - cpukit/score/src/threadrestart.c
> --
> 2.26.2
>
> _______________________________________________
> devel mailing list
> devel at rtems.org
> http://lists.rtems.org/mailman/listinfo/devel
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.rtems.org/pipermail/devel/attachments/20210517/1104dcc6/attachment.html>
More information about the devel
mailing list