From 75e15fe4430bf6f9c5bd65b851d771e88bbd2096 Mon Sep 17 00:00:00 2001 From: paul Date: Sun, 31 Oct 2004 02:13:09 +0000 Subject: 2004-10-31 Paul Jakma * vty.c: As per Andrew's suggestions.. (vty_serv_un) remove flags. (vtysh_accept) close socket if we cant set NONBLOCK. Add flags. --- lib/ChangeLog | 6 ++++++ lib/vty.c | 11 ++++++++--- 2 files changed, 14 insertions(+), 3 deletions(-) (limited to 'lib') diff --git a/lib/ChangeLog b/lib/ChangeLog index 28c0c005..292f8500 100644 --- a/lib/ChangeLog +++ b/lib/ChangeLog @@ -1,3 +1,9 @@ +2004-10-31 Paul Jakma + + * vty.c: As per Andrew's suggestions.. + (vty_serv_un) remove flags. + (vtysh_accept) close socket if we cant set NONBLOCK. Add flags. + 2004-10-29 Paul Jakma * vty.c: Move setting of sock to O_NONBLOCK from vty_serv_un diff --git a/lib/vty.c b/lib/vty.c index 7db1aa91..e37c99f5 100644 --- a/lib/vty.c +++ b/lib/vty.c @@ -1857,7 +1857,7 @@ void vty_serv_un (const char *path) { int ret; - int sock, len, flags; + int sock, len; struct sockaddr_un serv; mode_t old_mask; struct zprivs_ids_t ids; @@ -1927,6 +1927,7 @@ vtysh_accept (struct thread *thread) int accept_sock; int sock; int client_len; + int flags; struct sockaddr_un client; struct vty *vty; @@ -1949,8 +1950,12 @@ vtysh_accept (struct thread *thread) /* set to non-blocking*/ if ( ((flags = fcntl (sock, F_GETFL)) == -1) || (fcntl (sock, F_SETFL, flags|O_NONBLOCK) == -1) ) - zlog_warn ("vty_serv_un: could not set vty socket to non-blocking," - " %s", strerror (errno)); + { + zlog_warn ("vtysh_accept: could not set vty socket to non-blocking," + " %s, closing", strerror (errno)); + close (sock); + return -1; + } #ifdef VTYSH_DEBUG printf ("VTY shell accept\n"); -- cgit v1.2.1