From 3a6e79ad80f7bc037bf4b6424147d06b7377eaa8 Mon Sep 17 00:00:00 2001 From: Mark Michelson <mmichelson@digium.com> Date: Wed, 12 Sep 2007 16:24:45 +0000 Subject: [PATCH] Fixes Solaris build warnings (closes issue #10698, reported and patched by snuffy) git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@82283 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- main/app.c | 11 +++++++++-- main/asterisk.c | 1 + main/pbx.c | 3 +++ 3 files changed, 13 insertions(+), 2 deletions(-) diff --git a/main/app.c b/main/app.c index a026f2b8bf..0d6d966664 100644 --- a/main/app.c +++ b/main/app.c @@ -39,6 +39,7 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") #include <sys/stat.h> #include <sys/file.h> #include <regex.h> +#include <fcntl.h> #include "asterisk/channel.h" #include "asterisk/pbx.h" @@ -1146,8 +1147,14 @@ static enum AST_LOCK_RESULT ast_lock_path_flock(const char *path) pl->path = strdup(path); time(&start); - while (((res = flock(pl->fd, LOCK_EX | LOCK_NB)) < 0) && - (errno == EWOULDBLOCK) && (time(NULL) - start < 5)) + while (( + #ifdef SOLARIS + (res = fcntl(pl->fd, F_SETLK, fcntl(pl->fd,F_GETFL)|O_NONBLOCK)) < 0) && + #else + (res = flock(pl->fd, LOCK_EX | LOCK_NB)) < 0) && + #endif + (errno == EWOULDBLOCK) && + (time(NULL) - start < 5)) usleep(1000); if (res) { ast_log(LOG_WARNING, "Failed to lock path '%s': %s\n", diff --git a/main/asterisk.c b/main/asterisk.c index 7a4acf628e..ce6cedf66e 100644 --- a/main/asterisk.c +++ b/main/asterisk.c @@ -95,6 +95,7 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") #include <netdb.h> #if defined(SOLARIS) int daemon(int, int); /* defined in libresolv of all places */ +#include <sys/loadavg.h> #endif #endif diff --git a/main/pbx.c b/main/pbx.c index 666f334588..c879c58345 100644 --- a/main/pbx.c +++ b/main/pbx.c @@ -40,6 +40,9 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") #if defined(HAVE_SYSINFO) #include <sys/sysinfo.h> #endif +#if defined(SOLARIS) +#include <sys/loadavg.h> +#endif #include "asterisk/lock.h" #include "asterisk/cli.h" -- GitLab