mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-13 00:04:53 +00:00
Try a test compile to see if PTHREAD_ONCE_INIT requires extra braces.
There was conditional code (based on build platform) to optioinally wrap PTHREAD_ONCE_INIT in braces that was removed since it is fixed in newer versions of Solaris/OpenSolaris, but I am still running into it on Solaris 10 x86 so add a configure-time check for it. git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@236585 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
20
configure.ac
20
configure.ac
@@ -352,6 +352,26 @@ if test "${ac_cv_pthread_rwlock_timedwrlock}" = "yes"; then
|
|||||||
AC_DEFINE([HAVE_PTHREAD_RWLOCK_TIMEDWRLOCK], 1, [Define if your system has pthread_rwlock_timedwrlock()])
|
AC_DEFINE([HAVE_PTHREAD_RWLOCK_TIMEDWRLOCK], 1, [Define if your system has pthread_rwlock_timedwrlock()])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
AC_MSG_CHECKING(if PTHREAD_ONCE_INIT needs braces)
|
||||||
|
saved_CFLAGS="${CFLAGS}"
|
||||||
|
CFLAGS="${CFLAGS} -Werror -Wmissing-braces"
|
||||||
|
AC_COMPILE_IFELSE(
|
||||||
|
[AC_LANG_PROGRAM(
|
||||||
|
[#include <pthread.h>],
|
||||||
|
[pthread_once_t once = PTHREAD_ONCE_INIT;])
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
ac_cv_pthread_once_needsbraces="no"
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
ac_cv_pthread_once_needsbraces="yes"
|
||||||
|
]
|
||||||
|
)
|
||||||
|
CFLAGS="${saved_CFLAGS}"
|
||||||
|
if test "${ac_cv_pthread_once_needsbraces}" = "yes"; then
|
||||||
|
AC_DEFINE([PTHREAD_ONCE_INIT_NEEDS_BRACES], 1, [Define if your system needs braces around PTHREAD_ONCE_INIT])
|
||||||
|
fi
|
||||||
|
|
||||||
AC_MSG_CHECKING(for compiler atomic operations)
|
AC_MSG_CHECKING(for compiler atomic operations)
|
||||||
AC_LINK_IFELSE(
|
AC_LINK_IFELSE(
|
||||||
AC_LANG_PROGRAM([], [int foo1; int foo2 = __sync_fetch_and_add(&foo1, 1);]),
|
AC_LANG_PROGRAM([], [int foo1; int foo2 = __sync_fetch_and_add(&foo1, 1);]),
|
||||||
|
@@ -457,7 +457,7 @@
|
|||||||
/* Define to 1 if you have the `strtoq' function. */
|
/* Define to 1 if you have the `strtoq' function. */
|
||||||
#undef HAVE_STRTOQ
|
#undef HAVE_STRTOQ
|
||||||
|
|
||||||
/* Define to 1 if `st_blksize' is member of `struct stat'. */
|
/* Define to 1 if `struct stat' is a member of `st_blksize'. */
|
||||||
#undef HAVE_STRUCT_STAT_ST_BLKSIZE
|
#undef HAVE_STRUCT_STAT_ST_BLKSIZE
|
||||||
|
|
||||||
/* Define to 1 if you have the mISDN Supplemental Services library. */
|
/* Define to 1 if you have the mISDN Supplemental Services library. */
|
||||||
@@ -646,16 +646,19 @@
|
|||||||
/* Define to the one symbol short name of this package. */
|
/* Define to the one symbol short name of this package. */
|
||||||
#undef PACKAGE_TARNAME
|
#undef PACKAGE_TARNAME
|
||||||
|
|
||||||
|
/* Define to the home page for this package. */
|
||||||
|
#undef PACKAGE_URL
|
||||||
|
|
||||||
/* Define to the version of this package. */
|
/* Define to the version of this package. */
|
||||||
#undef PACKAGE_VERSION
|
#undef PACKAGE_VERSION
|
||||||
|
|
||||||
/* Define to 1 if the C compiler supports function prototypes. */
|
|
||||||
#undef PROTOTYPES
|
|
||||||
|
|
||||||
/* Define to necessary symbol if this constant uses a non-standard name on
|
/* Define to necessary symbol if this constant uses a non-standard name on
|
||||||
your system. */
|
your system. */
|
||||||
#undef PTHREAD_CREATE_JOINABLE
|
#undef PTHREAD_CREATE_JOINABLE
|
||||||
|
|
||||||
|
/* Define if your system needs braces around PTHREAD_ONCE_INIT */
|
||||||
|
#undef PTHREAD_ONCE_INIT_NEEDS_BRACES
|
||||||
|
|
||||||
/* Define as the return type of signal handlers (`int' or `void'). */
|
/* Define as the return type of signal handlers (`int' or `void'). */
|
||||||
#undef RETSIGTYPE
|
#undef RETSIGTYPE
|
||||||
|
|
||||||
@@ -668,11 +671,6 @@
|
|||||||
/* Define to the type of arg 5 for `select'. */
|
/* Define to the type of arg 5 for `select'. */
|
||||||
#undef SELECT_TYPE_ARG5
|
#undef SELECT_TYPE_ARG5
|
||||||
|
|
||||||
/* Define to 1 if the `setvbuf' function takes the buffering type as its
|
|
||||||
second argument and the buffer pointer as the third, as on System V before
|
|
||||||
release 3. */
|
|
||||||
#undef SETVBUF_REVERSED
|
|
||||||
|
|
||||||
/* The size of `int', as computed by sizeof. */
|
/* The size of `int', as computed by sizeof. */
|
||||||
#undef SIZEOF_INT
|
#undef SIZEOF_INT
|
||||||
|
|
||||||
@@ -693,20 +691,30 @@
|
|||||||
/* Define to 1 if your <sys/time.h> declares `struct tm'. */
|
/* Define to 1 if your <sys/time.h> declares `struct tm'. */
|
||||||
#undef TM_IN_SYS_TIME
|
#undef TM_IN_SYS_TIME
|
||||||
|
|
||||||
/* Define to 1 if on AIX 3.
|
/* Enable extensions on AIX 3, Interix. */
|
||||||
System headers sometimes define this.
|
|
||||||
We just want to avoid a redefinition error message. */
|
|
||||||
#ifndef _ALL_SOURCE
|
#ifndef _ALL_SOURCE
|
||||||
# undef _ALL_SOURCE
|
# undef _ALL_SOURCE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Number of bits in a file offset, on hosts where this is settable. */
|
|
||||||
#undef _FILE_OFFSET_BITS
|
|
||||||
|
|
||||||
/* Enable GNU extensions on systems that have them. */
|
/* Enable GNU extensions on systems that have them. */
|
||||||
#ifndef _GNU_SOURCE
|
#ifndef _GNU_SOURCE
|
||||||
# undef _GNU_SOURCE
|
# undef _GNU_SOURCE
|
||||||
#endif
|
#endif
|
||||||
|
/* Enable threading extensions on Solaris. */
|
||||||
|
#ifndef _POSIX_PTHREAD_SEMANTICS
|
||||||
|
# undef _POSIX_PTHREAD_SEMANTICS
|
||||||
|
#endif
|
||||||
|
/* Enable extensions on HP NonStop. */
|
||||||
|
#ifndef _TANDEM_SOURCE
|
||||||
|
# undef _TANDEM_SOURCE
|
||||||
|
#endif
|
||||||
|
/* Enable general extensions on Solaris. */
|
||||||
|
#ifndef __EXTENSIONS__
|
||||||
|
# undef __EXTENSIONS__
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Number of bits in a file offset, on hosts where this is settable. */
|
||||||
|
#undef _FILE_OFFSET_BITS
|
||||||
|
|
||||||
/* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */
|
/* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */
|
||||||
#undef _LARGEFILE_SOURCE
|
#undef _LARGEFILE_SOURCE
|
||||||
@@ -724,20 +732,6 @@
|
|||||||
/* Define to 1 if you need to in order for `stat' and other things to work. */
|
/* Define to 1 if you need to in order for `stat' and other things to work. */
|
||||||
#undef _POSIX_SOURCE
|
#undef _POSIX_SOURCE
|
||||||
|
|
||||||
/* Enable extensions on Solaris. */
|
|
||||||
#ifndef __EXTENSIONS__
|
|
||||||
# undef __EXTENSIONS__
|
|
||||||
#endif
|
|
||||||
#ifndef _POSIX_PTHREAD_SEMANTICS
|
|
||||||
# undef _POSIX_PTHREAD_SEMANTICS
|
|
||||||
#endif
|
|
||||||
#ifndef _TANDEM_SOURCE
|
|
||||||
# undef _TANDEM_SOURCE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Define like PROTOTYPES; this can be used by system headers. */
|
|
||||||
#undef __PROTOTYPES
|
|
||||||
|
|
||||||
/* Define to empty if `const' does not conform to ANSI C. */
|
/* Define to empty if `const' does not conform to ANSI C. */
|
||||||
#undef const
|
#undef const
|
||||||
|
|
||||||
|
@@ -67,11 +67,17 @@ void __ast_threadstorage_object_replace(void *key_old, void *key_new, size_t len
|
|||||||
#define AST_THREADSTORAGE(name, name_init) \
|
#define AST_THREADSTORAGE(name, name_init) \
|
||||||
AST_THREADSTORAGE_CUSTOM(name, name_init, ast_free_ptr)
|
AST_THREADSTORAGE_CUSTOM(name, name_init, ast_free_ptr)
|
||||||
|
|
||||||
|
#if defined(PTHREAD_ONCE_INIT_NEEDS_BRACES)
|
||||||
|
# define AST_PTHREAD_ONCE_INIT { PTHREAD_ONCE_INIT }
|
||||||
|
#else
|
||||||
|
# define AST_PTHREAD_ONCE_INIT PTHREAD_ONCE_INIT
|
||||||
|
#endif
|
||||||
|
|
||||||
#if !defined(DEBUG_THREADLOCALS)
|
#if !defined(DEBUG_THREADLOCALS)
|
||||||
#define AST_THREADSTORAGE_CUSTOM(name, name_init, cleanup) \
|
#define AST_THREADSTORAGE_CUSTOM(name, name_init, cleanup) \
|
||||||
static void name_init(void); \
|
static void name_init(void); \
|
||||||
static struct ast_threadstorage name = { \
|
static struct ast_threadstorage name = { \
|
||||||
.once = PTHREAD_ONCE_INIT, \
|
.once = AST_PTHREAD_ONCE_INIT, \
|
||||||
.key_init = name_init, \
|
.key_init = name_init, \
|
||||||
}; \
|
}; \
|
||||||
static void name_init(void) \
|
static void name_init(void) \
|
||||||
@@ -82,7 +88,7 @@ static void name_init(void) \
|
|||||||
#define AST_THREADSTORAGE_CUSTOM(name, name_init, cleanup) \
|
#define AST_THREADSTORAGE_CUSTOM(name, name_init, cleanup) \
|
||||||
static void name_init(void); \
|
static void name_init(void); \
|
||||||
static struct ast_threadstorage name = { \
|
static struct ast_threadstorage name = { \
|
||||||
.once = PTHREAD_ONCE_INIT, \
|
.once = AST_PTHREAD_ONCE_INIT, \
|
||||||
.key_init = name_init, \
|
.key_init = name_init, \
|
||||||
}; \
|
}; \
|
||||||
static void __cleanup_##name(void *data) \
|
static void __cleanup_##name(void *data) \
|
||||||
|
Reference in New Issue
Block a user