Both SDK 0.10.0-beta2 and the ARM gcc 2018q2 run into a build issue with newlib and conflict definitions of mode_t type. First we need to add some ifdef protection if mode_t is already defined and set _MODE_T_DECLARED if we are the first to define it. Secondarily, we rename include/posix/sys/types.h to include/posix/posix_types.h so that we aren't getting a name collusion with the system sys/types.h and that we can easily and clearily include it (which we need to do to pull in the info from newlib). Fixes: #12224 Signed-off-by: Kumar Gala <kumar.gala@linaro.org>
28 lines
687 B
C
28 lines
687 B
C
/*
|
|
* Copyright (c) 2018 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
#ifndef ZEPHYR_INCLUDE_POSIX_SEMAPHORE_H_
|
|
#define ZEPHYR_INCLUDE_POSIX_SEMAPHORE_H_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <posix/time.h>
|
|
#include "posix_types.h"
|
|
|
|
int sem_destroy(sem_t *semaphore);
|
|
int sem_getvalue(sem_t *restrict semaphore, int *restrict value);
|
|
int sem_init(sem_t *semaphore, int pshared, unsigned int value);
|
|
int sem_post(sem_t *semaphore);
|
|
int sem_timedwait(sem_t *restrict semaphore, struct timespec *restrict abstime);
|
|
int sem_trywait(sem_t *semaphore);
|
|
int sem_wait(sem_t *semaphore);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* ZEPHYR_INCLUDE_POSIX_SEMAPHORE_H_ */
|