mirror of
https://github.com/apache/nuttx.git
synced 2026-05-27 11:26:12 +08:00
sched/semaphore: add support to customize semaphore max allowed value
Build Documentation / build-html (push) Has been cancelled
Build Documentation / build-html (push) Has been cancelled
Curernt implementation default semaphore max allowed value to SEM_VALUE_MAX. In some cases, user may want to change this, so provide a function to do this: sem_setmaxvalue Signed-off-by: Chengdong Wang <wangchengdong@lixiang.com>
This commit is contained in:
committed by
Xiang Xiao
parent
5676bf8227
commit
7d0fb9d34f
@@ -108,6 +108,11 @@ result.
|
|||||||
Semaphore does not support priority inheritance by default. If you need to
|
Semaphore does not support priority inheritance by default. If you need to
|
||||||
use a semaphore as a mutex you need to change its default behavior.
|
use a semaphore as a mutex you need to change its default behavior.
|
||||||
|
|
||||||
|
Each semaphore is assigned a default maximum value defined by SEM_VALUE_MAX.
|
||||||
|
If ``CONFIG_CUSTOM_SEMAPHORE_MAXVALUE`` is enabled, applications may override this limit.
|
||||||
|
In such cases, the function ``nxsem_setmaxvalue()`` can be used to specify a custom maximum value
|
||||||
|
for an individual semaphore.
|
||||||
|
|
||||||
In user space, it is recommended to use pthread_mutex instead of
|
In user space, it is recommended to use pthread_mutex instead of
|
||||||
semaphore for resource protection
|
semaphore for resource protection
|
||||||
|
|
||||||
|
|||||||
@@ -412,6 +412,27 @@ int nxsem_post_slow(FAR sem_t *sem);
|
|||||||
|
|
||||||
int nxsem_get_value(FAR sem_t *sem, FAR int *sval);
|
int nxsem_get_value(FAR sem_t *sem, FAR int *sval);
|
||||||
|
|
||||||
|
#ifdef CONFIG_CUSTOM_SEMAPHORE_MAXVALUE
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: nxsem_setmaxvalue
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* This function sets the maximum allowed value for a specific semaphore.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* sem - Semaphore descriptor
|
||||||
|
* maxvalue - The maximum allowed value
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* This is an internal OS interface and should not be used by applications.
|
||||||
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
||||||
|
* returned on success. A negated errno value is returned on failure.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int nxsem_setmaxvalue(FAR sem_t *sem, int32_t maxvalue);
|
||||||
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: nxsem_open
|
* Name: nxsem_open
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -123,6 +123,10 @@ struct sem_s
|
|||||||
|
|
||||||
dq_queue_t waitlist;
|
dq_queue_t waitlist;
|
||||||
|
|
||||||
|
#ifdef CONFIG_CUSTOM_SEMAPHORE_MAXVALUE
|
||||||
|
int32_t maxvalue;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_PRIORITY_INHERITANCE
|
#ifdef CONFIG_PRIORITY_INHERITANCE
|
||||||
# if CONFIG_SEM_PREALLOCHOLDERS > 0
|
# if CONFIG_SEM_PREALLOCHOLDERS > 0
|
||||||
FAR struct semholder_s *hhead; /* List of holders of semaphore counts */
|
FAR struct semholder_s *hhead; /* List of holders of semaphore counts */
|
||||||
|
|||||||
@@ -36,6 +36,10 @@ if(CONFIG_FS_NAMED_SEMAPHORES)
|
|||||||
list(APPEND SRCS sem_open.c sem_close.c sem_unlink.c)
|
list(APPEND SRCS sem_open.c sem_close.c sem_unlink.c)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(CONFIG_CUSTOM_SEMAPHORE_MAXVALUE)
|
||||||
|
list(APPEND SRCS sem_setmaxvalue.c)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(CONFIG_PRIORITY_PROTECT)
|
if(CONFIG_PRIORITY_PROTECT)
|
||||||
list(APPEND SRCS sem_getprioceiling.c sem_setprioceiling.c)
|
list(APPEND SRCS sem_getprioceiling.c sem_setprioceiling.c)
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
@@ -30,6 +30,10 @@ ifeq ($(CONFIG_FS_NAMED_SEMAPHORES),y)
|
|||||||
CSRCS += sem_open.c sem_close.c sem_unlink.c
|
CSRCS += sem_open.c sem_close.c sem_unlink.c
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_CUSTOM_SEMAPHORE_MAXVALUE),y)
|
||||||
|
CSRCS += sem_setmaxvalue.c
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(CONFIG_PRIORITY_PROTECT),y)
|
ifeq ($(CONFIG_PRIORITY_PROTECT),y)
|
||||||
CSRCS += sem_getprioceiling.c sem_setprioceiling.c
|
CSRCS += sem_getprioceiling.c sem_setprioceiling.c
|
||||||
endif
|
endif
|
||||||
|
|||||||
@@ -72,6 +72,10 @@ int nxsem_init(FAR sem_t *sem, int pshared, int32_t value)
|
|||||||
|
|
||||||
sem->val.semcount = (int32_t)value;
|
sem->val.semcount = (int32_t)value;
|
||||||
|
|
||||||
|
#ifdef CONFIG_CUSTOM_SEMAPHORE_MAXVALUE
|
||||||
|
sem->maxvalue = SEM_VALUE_MAX;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Initialize semaphore wait list */
|
/* Initialize semaphore wait list */
|
||||||
|
|
||||||
dq_init(&sem->waitlist);
|
dq_init(&sem->waitlist);
|
||||||
|
|||||||
@@ -0,0 +1,66 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* libs/libc/semaphore/sem_setmaxvalue.c
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
* contributor license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright ownership. The
|
||||||
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance with the
|
||||||
|
* License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
* License for the specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
#include <nuttx/trace.h>
|
||||||
|
|
||||||
|
#include <nuttx/semaphore.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_CUSTOM_SEMAPHORE_MAXVALUE
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: nxsem_setmaxvalue
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Set sem max allowed value
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* sem - Semaphore object
|
||||||
|
* delay - Max allowed semaphore value.
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* This is an internal OS interface and should not be used by applications.
|
||||||
|
* It follows the NuttX internal error return policy: Zero (OK) is
|
||||||
|
* returned on success. A negated errno value is returned on failure.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int nxsem_setmaxvalue(FAR sem_t *sem, int32_t maxvalue)
|
||||||
|
{
|
||||||
|
if (sem != NULL)
|
||||||
|
{
|
||||||
|
sem->maxvalue = maxvalue;
|
||||||
|
return OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* CONFIG_PRIORITY_INHERITANCE */
|
||||||
@@ -2027,3 +2027,10 @@ config COREDUMP
|
|||||||
The memory state embeds a snapshot of all segments mapped in the
|
The memory state embeds a snapshot of all segments mapped in the
|
||||||
memory space of the program. The CPU state contains register values
|
memory space of the program. The CPU state contains register values
|
||||||
when the core dump has been generated.
|
when the core dump has been generated.
|
||||||
|
|
||||||
|
config CUSTOM_SEMAPHORE_MAXVALUE
|
||||||
|
bool "Custom max value for semaphores"
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
Enable to support custom max value for semaphores.
|
||||||
|
When this option is enabled, the max value of a semaphore can be set
|
||||||
|
|||||||
@@ -125,7 +125,11 @@ int nxsem_post_slow(FAR sem_t *sem)
|
|||||||
sem_count = atomic_read(NXSEM_COUNT(sem));
|
sem_count = atomic_read(NXSEM_COUNT(sem));
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
#ifdef CONFIG_CUSTOM_SEMAPHORE_MAXVALUE
|
||||||
|
if (sem_count >= sem->maxvalue)
|
||||||
|
#else
|
||||||
if (sem_count >= SEM_VALUE_MAX)
|
if (sem_count >= SEM_VALUE_MAX)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
leave_critical_section(flags);
|
leave_critical_section(flags);
|
||||||
return -EOVERFLOW;
|
return -EOVERFLOW;
|
||||||
|
|||||||
Reference in New Issue
Block a user