aboutsummaryrefslogtreecommitdiffstats
path: root/manager.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-02-07 07:13:33 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-02-07 07:13:33 +0000
commit8ea5ae4418c3b1e36c3e107ca921d4b3b839fef4 (patch)
tree2eaf0b6ea450ded48ac40cf920a9c6906693eb8b /manager.c
parent687781a1f8453c67ea49717fcbbbfd7d46401142 (diff)
Insert blank after REFER (bug #997)
Correct path to VM sample (bug #994) Make manager interface non-blocking (bug #861) Don't bork on empty from in SIP (bug #887) git-svn-id: http://svn.digium.com/svn/asterisk/trunk@2138 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'manager.c')
-rwxr-xr-xmanager.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/manager.c b/manager.c
index fe8d2769b..ed285ec69 100755
--- a/manager.c
+++ b/manager.c
@@ -727,6 +727,7 @@ static void *accept_thread(void *ignore)
struct mansession *s;
struct protoent *p;
int arg = 1;
+ int flags;
pthread_attr_t attr;
pthread_attr_init(&attr);
@@ -752,6 +753,9 @@ static void *accept_thread(void *ignore)
}
memset(s, 0, sizeof(struct mansession));
memcpy(&s->sin, &sin, sizeof(sin));
+ /* For safety, make sure socket is non-blocking */
+ flags = fcntl(as, F_GETFL);
+ fcntl(as, F_SETFL, flags | O_NONBLOCK);
ast_mutex_init(&s->lock);
s->fd = as;
ast_mutex_lock(&sessionlock);