mirror of
https://github.com/matrix-construct/construct
synced 2024-12-25 23:14:13 +01:00
ircd::ctx::posix: Enforce noexcept on the full surface.
This commit is contained in:
parent
00350ab96c
commit
6c89faee13
2 changed files with 41 additions and 12 deletions
|
@ -17,15 +17,20 @@ noexcept;
|
|||
|
||||
extern "C" int
|
||||
ircd_pthread_join(pthread_t __th,
|
||||
void **__thread_return);
|
||||
void **__thread_return)
|
||||
noexcept;
|
||||
|
||||
extern "C" int
|
||||
ircd_pthread_tryjoin_np(pthread_t __th,
|
||||
void **__thread_return);
|
||||
void **__thread_return)
|
||||
noexcept;
|
||||
|
||||
extern "C" int
|
||||
ircd_pthread_timedjoin_np(pthread_t __th,
|
||||
void **__thread_return,
|
||||
const struct timespec *__abstime);
|
||||
const struct timespec *__abstime)
|
||||
noexcept;
|
||||
|
||||
extern "C" int
|
||||
ircd_pthread_detach(pthread_t __th)
|
||||
noexcept;
|
||||
|
@ -42,7 +47,8 @@ ircd_pthread_atfork(void (*__prepare)(void),
|
|||
noexcept;
|
||||
|
||||
extern "C" void
|
||||
ircd_pthread_exit(void *const retval);
|
||||
ircd_pthread_exit(void *const retval)
|
||||
noexcept;
|
||||
|
||||
extern "C" pthread_t
|
||||
ircd_pthread_self(void)
|
||||
|
@ -54,7 +60,8 @@ noexcept;
|
|||
|
||||
extern "C" int
|
||||
ircd_pthread_once(pthread_once_t *__once_control,
|
||||
void (*__init_routine)(void));
|
||||
void (*__init_routine)(void))
|
||||
noexcept;
|
||||
|
||||
//
|
||||
// Cancellation
|
||||
|
@ -62,15 +69,21 @@ ircd_pthread_once(pthread_once_t *__once_control,
|
|||
|
||||
extern "C" int
|
||||
ircd_pthread_setcancelstate(int __state,
|
||||
int *__oldstate);
|
||||
int *__oldstate)
|
||||
noexcept;
|
||||
|
||||
extern "C" int
|
||||
ircd_pthread_setcanceltype(int __type,
|
||||
int *__oldtype);
|
||||
int *__oldtype)
|
||||
noexcept;
|
||||
|
||||
extern "C" int
|
||||
ircd_pthread_cancel(pthread_t __th);
|
||||
ircd_pthread_cancel(pthread_t __th)
|
||||
noexcept;
|
||||
|
||||
extern "C" void
|
||||
ircd_pthread_testcancel(void);
|
||||
ircd_pthread_testcancel(void)
|
||||
noexcept;
|
||||
|
||||
//
|
||||
// Scheduling
|
||||
|
@ -541,18 +554,21 @@ noexcept;
|
|||
|
||||
extern "C" int
|
||||
ircd_pthread_cond_wait(pthread_cond_t *const __restrict __cond,
|
||||
pthread_mutex_t *const __restrict __mutex);
|
||||
pthread_mutex_t *const __restrict __mutex)
|
||||
noexcept;
|
||||
|
||||
extern "C" int
|
||||
ircd_pthread_cond_timedwait(pthread_cond_t *const __restrict __cond,
|
||||
pthread_mutex_t *const __restrict __mutex,
|
||||
const struct timespec *__restrict __abstime);
|
||||
const struct timespec *__restrict __abstime)
|
||||
noexcept;
|
||||
|
||||
extern "C" int
|
||||
ircd_pthread_cond_clockwait(pthread_cond_t *__restrict __cond,
|
||||
pthread_mutex_t *__restrict __mutex,
|
||||
__clockid_t __clock_id,
|
||||
const struct timespec *__restrict __abstime);
|
||||
const struct timespec *__restrict __abstime)
|
||||
noexcept;
|
||||
|
||||
//
|
||||
// Condition Variable Attributes
|
||||
|
|
|
@ -107,6 +107,7 @@ IRCD_WRAP(pthread_join, "__wrap_pthread_join",
|
|||
int
|
||||
ircd_pthread_join(pthread_t __th,
|
||||
void **__thread_return)
|
||||
noexcept
|
||||
{
|
||||
ircd::log::debug
|
||||
{
|
||||
|
@ -136,6 +137,7 @@ ircd_pthread_join(pthread_t __th,
|
|||
int
|
||||
ircd_pthread_tryjoin_np(pthread_t __th,
|
||||
void **__thread_return)
|
||||
noexcept
|
||||
{
|
||||
always_assert(false);
|
||||
return EINVAL;
|
||||
|
@ -156,6 +158,7 @@ int
|
|||
ircd_pthread_timedjoin_np(pthread_t __th,
|
||||
void **__thread_return,
|
||||
const struct timespec *__abstime)
|
||||
noexcept
|
||||
{
|
||||
//TODO: XXX ctx timed join
|
||||
ircd_pthread_join(__th, __thread_return);
|
||||
|
@ -163,7 +166,9 @@ ircd_pthread_timedjoin_np(pthread_t __th,
|
|||
}
|
||||
|
||||
void
|
||||
__attribute__((noreturn))
|
||||
ircd_pthread_exit(void *const retval)
|
||||
noexcept
|
||||
{
|
||||
always_assert(false);
|
||||
__builtin_unreachable();
|
||||
|
@ -228,6 +233,7 @@ noexcept
|
|||
int
|
||||
ircd_pthread_once(pthread_once_t *__once_control,
|
||||
void (*__init_routine)(void))
|
||||
noexcept
|
||||
{
|
||||
static_assert(sizeof(std::atomic<int>) == sizeof(pthread_once_t));
|
||||
|
||||
|
@ -255,6 +261,7 @@ ircd_pthread_once(pthread_once_t *__once_control,
|
|||
int
|
||||
ircd_pthread_setcancelstate(int __state,
|
||||
int *__oldstate)
|
||||
noexcept
|
||||
{
|
||||
always_assert(false);
|
||||
return EINVAL;
|
||||
|
@ -263,6 +270,7 @@ ircd_pthread_setcancelstate(int __state,
|
|||
int
|
||||
ircd_pthread_setcanceltype(int __type,
|
||||
int *__oldtype)
|
||||
noexcept
|
||||
{
|
||||
always_assert(false);
|
||||
return EINVAL;
|
||||
|
@ -270,6 +278,7 @@ ircd_pthread_setcanceltype(int __type,
|
|||
|
||||
int
|
||||
ircd_pthread_cancel(pthread_t __th)
|
||||
noexcept
|
||||
{
|
||||
always_assert(false);
|
||||
return EINVAL;
|
||||
|
@ -277,6 +286,7 @@ ircd_pthread_cancel(pthread_t __th)
|
|||
|
||||
void
|
||||
ircd_pthread_testcancel(void)
|
||||
noexcept
|
||||
{
|
||||
always_assert(false);
|
||||
}
|
||||
|
@ -1283,6 +1293,7 @@ noexcept
|
|||
int
|
||||
ircd_pthread_cond_wait(pthread_cond_t *const __restrict __cond,
|
||||
pthread_mutex_t *const __restrict __mutex)
|
||||
noexcept
|
||||
{
|
||||
assert(__cond);
|
||||
assert(__mutex);
|
||||
|
@ -1305,6 +1316,7 @@ int
|
|||
ircd_pthread_cond_timedwait(pthread_cond_t *const __restrict __cond,
|
||||
pthread_mutex_t *const __restrict __mutex,
|
||||
const struct timespec *__restrict __abstime)
|
||||
noexcept
|
||||
{
|
||||
using namespace std::chrono;
|
||||
|
||||
|
@ -1349,6 +1361,7 @@ ircd_pthread_cond_clockwait(pthread_cond_t *__restrict __cond,
|
|||
pthread_mutex_t *__restrict __mutex,
|
||||
__clockid_t __clock_id,
|
||||
const struct timespec *__restrict __abstime)
|
||||
noexcept
|
||||
{
|
||||
always_assert(false);
|
||||
return EINVAL;
|
||||
|
|
Loading…
Reference in a new issue