mirror of
https://github.com/apache/nuttx.git
synced 2025-01-13 06:18:40 +08:00
Revert "system: pthread_barrierwait should be moved to kernel space"
reason:
new implementation does not requires the use of enter_critical_section,
so the source code needs to be moved to user space
This reverts commit d189a86a35
.
This commit is contained in:
parent
238cddde3a
commit
dcc75048be
7 changed files with 16 additions and 8 deletions
|
@ -310,7 +310,6 @@ SYSCALL_LOOKUP(munmap, 2)
|
||||||
/* The following are defined if pthreads are enabled */
|
/* The following are defined if pthreads are enabled */
|
||||||
|
|
||||||
#ifndef CONFIG_DISABLE_PTHREAD
|
#ifndef CONFIG_DISABLE_PTHREAD
|
||||||
SYSCALL_LOOKUP(pthread_barrier_wait, 1)
|
|
||||||
SYSCALL_LOOKUP(pthread_cancel, 1)
|
SYSCALL_LOOKUP(pthread_cancel, 1)
|
||||||
SYSCALL_LOOKUP(pthread_cond_broadcast, 1)
|
SYSCALL_LOOKUP(pthread_cond_broadcast, 1)
|
||||||
SYSCALL_LOOKUP(pthread_cond_signal, 1)
|
SYSCALL_LOOKUP(pthread_cond_signal, 1)
|
||||||
|
|
|
@ -57,6 +57,7 @@ if(NOT CONFIG_DISABLE_PTHREAD)
|
||||||
pthread_barrierattr_setpshared.c
|
pthread_barrierattr_setpshared.c
|
||||||
pthread_barrierinit.c
|
pthread_barrierinit.c
|
||||||
pthread_barrierdestroy.c
|
pthread_barrierdestroy.c
|
||||||
|
pthread_barrierwait.c
|
||||||
pthread_condattr_init.c
|
pthread_condattr_init.c
|
||||||
pthread_condattr_destroy.c
|
pthread_condattr_destroy.c
|
||||||
pthread_condattr_getpshared.c
|
pthread_condattr_getpshared.c
|
||||||
|
|
|
@ -40,7 +40,7 @@ CSRCS += pthread_attr_setschedparam.c pthread_attr_getschedparam.c
|
||||||
CSRCS += pthread_attr_setscope.c pthread_attr_getscope.c
|
CSRCS += pthread_attr_setscope.c pthread_attr_getscope.c
|
||||||
CSRCS += pthread_barrierattr_init.c pthread_barrierattr_destroy.c
|
CSRCS += pthread_barrierattr_init.c pthread_barrierattr_destroy.c
|
||||||
CSRCS += pthread_barrierattr_getpshared.c pthread_barrierattr_setpshared.c
|
CSRCS += pthread_barrierattr_getpshared.c pthread_barrierattr_setpshared.c
|
||||||
CSRCS += pthread_barrierinit.c pthread_barrierdestroy.c
|
CSRCS += pthread_barrierinit.c pthread_barrierdestroy.c pthread_barrierwait.c
|
||||||
CSRCS += pthread_condattr_init.c pthread_condattr_destroy.c
|
CSRCS += pthread_condattr_init.c pthread_condattr_destroy.c
|
||||||
CSRCS += pthread_condattr_getpshared.c pthread_condattr_setpshared.c
|
CSRCS += pthread_condattr_getpshared.c pthread_condattr_setpshared.c
|
||||||
CSRCS += pthread_condattr_setclock.c pthread_condattr_getclock.c
|
CSRCS += pthread_condattr_setclock.c pthread_condattr_getclock.c
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* sched/pthread/pthread_barrierwait.c
|
* libs/libc/pthread/pthread_barrierwait.c
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
*
|
*
|
||||||
|
@ -112,5 +112,16 @@ int pthread_barrier_wait(FAR pthread_barrier_t *barrier)
|
||||||
|
|
||||||
nxmutex_unlock(&barrier->mutex);
|
nxmutex_unlock(&barrier->mutex);
|
||||||
|
|
||||||
return -nxsem_wait_uninterruptible(&barrier->sem);
|
while (sem_wait(&barrier->sem) != OK)
|
||||||
|
{
|
||||||
|
/* If the thread is awakened by a signal, just continue to wait */
|
||||||
|
|
||||||
|
int errornumber = get_errno();
|
||||||
|
if (errornumber != EINTR)
|
||||||
|
{
|
||||||
|
return errornumber;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return OK;
|
||||||
}
|
}
|
|
@ -43,8 +43,7 @@ if(NOT CONFIG_DISABLE_PTHREAD)
|
||||||
pthread_completejoin.c
|
pthread_completejoin.c
|
||||||
pthread_findjoininfo.c
|
pthread_findjoininfo.c
|
||||||
pthread_release.c
|
pthread_release.c
|
||||||
pthread_setschedprio.c
|
pthread_setschedprio.c)
|
||||||
pthread_barrierwait.c)
|
|
||||||
|
|
||||||
if(NOT CONFIG_PTHREAD_MUTEX_UNSAFE)
|
if(NOT CONFIG_PTHREAD_MUTEX_UNSAFE)
|
||||||
list(APPEND SRCS pthread_mutex.c pthread_mutexconsistent.c
|
list(APPEND SRCS pthread_mutex.c pthread_mutexconsistent.c
|
||||||
|
|
|
@ -30,7 +30,6 @@ CSRCS += pthread_condwait.c pthread_condsignal.c pthread_condbroadcast.c
|
||||||
CSRCS += pthread_condclockwait.c pthread_sigmask.c pthread_cancel.c
|
CSRCS += pthread_condclockwait.c pthread_sigmask.c pthread_cancel.c
|
||||||
CSRCS += pthread_completejoin.c pthread_findjoininfo.c
|
CSRCS += pthread_completejoin.c pthread_findjoininfo.c
|
||||||
CSRCS += pthread_release.c pthread_setschedprio.c
|
CSRCS += pthread_release.c pthread_setschedprio.c
|
||||||
CSRCS += pthread_barrierwait.c
|
|
||||||
|
|
||||||
ifneq ($(CONFIG_PTHREAD_MUTEX_UNSAFE),y)
|
ifneq ($(CONFIG_PTHREAD_MUTEX_UNSAFE),y)
|
||||||
CSRCS += pthread_mutex.c pthread_mutexconsistent.c pthread_mutexinconsistent.c
|
CSRCS += pthread_mutex.c pthread_mutexconsistent.c pthread_mutexinconsistent.c
|
||||||
|
|
|
@ -105,7 +105,6 @@
|
||||||
"prctl","sys/prctl.h","","int","int","...","uintptr_t","uintptr_t"
|
"prctl","sys/prctl.h","","int","int","...","uintptr_t","uintptr_t"
|
||||||
"pread","unistd.h","","ssize_t","int","FAR void *","size_t","off_t"
|
"pread","unistd.h","","ssize_t","int","FAR void *","size_t","off_t"
|
||||||
"pselect","sys/select.h","","int","int","FAR fd_set *","FAR fd_set *","FAR fd_set *","FAR const struct timespec *","FAR const sigset_t *"
|
"pselect","sys/select.h","","int","int","FAR fd_set *","FAR fd_set *","FAR fd_set *","FAR const struct timespec *","FAR const sigset_t *"
|
||||||
"pthread_barrier_wait","pthread.h","!defined(CONFIG_DISABLE_PTHREAD)","int","FAR pthread_barrier_t *"
|
|
||||||
"pthread_cancel","pthread.h","!defined(CONFIG_DISABLE_PTHREAD)","int","pthread_t"
|
"pthread_cancel","pthread.h","!defined(CONFIG_DISABLE_PTHREAD)","int","pthread_t"
|
||||||
"pthread_cond_broadcast","pthread.h","!defined(CONFIG_DISABLE_PTHREAD)","int","FAR pthread_cond_t *"
|
"pthread_cond_broadcast","pthread.h","!defined(CONFIG_DISABLE_PTHREAD)","int","FAR pthread_cond_t *"
|
||||||
"pthread_cond_clockwait","pthread.h","!defined(CONFIG_DISABLE_PTHREAD)","int","FAR pthread_cond_t *","FAR pthread_mutex_t *","clockid_t","FAR const struct timespec *"
|
"pthread_cond_clockwait","pthread.h","!defined(CONFIG_DISABLE_PTHREAD)","int","FAR pthread_cond_t *","FAR pthread_mutex_t *","clockid_t","FAR const struct timespec *"
|
||||||
|
|
Can't render this file because it has a wrong number of fields in line 2.
|
Loading…
Reference in a new issue