summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGuillaume Nault <g.nault@alphalink.fr>2013-03-13 18:43:27 +0100
committerKozlov Dmitry <xeb@mail.ru>2013-03-15 23:59:32 +0400
commit58eb38dd629db88d8ce0e321cbf4ba0e7ead206b (patch)
treeb656750a4fef75ff4f169eb1b70b18d7455c26b2
parentc80d2145d2dd0062560cff50186fbb38964c2bfd (diff)
downloadaccel-ppp-xebd-58eb38dd629db88d8ce0e321cbf4ba0e7ead206b.tar.gz
accel-ppp-xebd-58eb38dd629db88d8ce0e321cbf4ba0e7ead206b.zip
l2tp: Strict error management in start_udp_server()
Check for errors in start_udp_server() and return exit status to calling function. Signed-off-by: Guillaume Nault <g.nault@alphalink.fr>
-rw-r--r--accel-pppd/ctrl/l2tp/l2tp.c88
1 files changed, 69 insertions, 19 deletions
diff --git a/accel-pppd/ctrl/l2tp/l2tp.c b/accel-pppd/ctrl/l2tp/l2tp.c
index f784135..43c985a 100644
--- a/accel-pppd/ctrl/l2tp/l2tp.c
+++ b/accel-pppd/ctrl/l2tp/l2tp.c
@@ -3088,20 +3088,31 @@ static struct l2tp_serv_t udp_serv =
.ctx.close=l2tp_ip_close,
};*/
-static void start_udp_server(void)
+static int start_udp_server(void)
{
struct sockaddr_in addr;
const char *opt;
- int flag = 1;
+ int flag;
udp_serv.hnd.fd = socket(PF_INET, SOCK_DGRAM, 0);
if (udp_serv.hnd.fd < 0) {
log_error("l2tp: impossible to start L2TP server:"
" socket(PF_INET) failed: %s\n", strerror(errno));
- return;
+ return -1;
+ }
+
+ flag = fcntl(udp_serv.hnd.fd, F_GETFD);
+ if (flag < 0) {
+ log_error("l2tp: impossible to start L2TP server:"
+ " fcntl(F_GETFD) failed: %s\n", strerror(errno));
+ goto err_fd;
+ }
+ flag = fcntl(udp_serv.hnd.fd, F_SETFD, flag | FD_CLOEXEC);
+ if (flag < 0) {
+ log_error("l2tp: impossible to start L2TP server:"
+ " fcntl(F_SETFD) failed: %s\n", strerror(errno));
+ goto err_fd;
}
-
- fcntl(udp_serv.hnd.fd, F_SETFD, fcntl(udp_serv.hnd.fd, F_GETFD) | FD_CLOEXEC);
memset(&addr, 0, sizeof(addr));
addr.sin_family = AF_INET;
@@ -3113,25 +3124,51 @@ static void start_udp_server(void)
else
addr.sin_addr.s_addr = htonl(INADDR_ANY);
- setsockopt(udp_serv.hnd.fd, SOL_SOCKET, SO_REUSEADDR, &udp_serv.hnd.fd, sizeof(udp_serv.hnd.fd));
- setsockopt(udp_serv.hnd.fd, SOL_SOCKET, SO_NO_CHECK, &udp_serv.hnd.fd, sizeof(udp_serv.hnd.fd));
+ if (setsockopt(udp_serv.hnd.fd, SOL_SOCKET, SO_REUSEADDR,
+ &udp_serv.hnd.fd, sizeof(udp_serv.hnd.fd)) < 0) {
+ log_error("l2tp: impossible to start L2TP server:"
+ " setsockopt(SO_REUSEADDR) failed: %s\n",
+ strerror(errno));
+ goto err_fd;
+ }
+ if (setsockopt(udp_serv.hnd.fd, SOL_SOCKET, SO_NO_CHECK,
+ &udp_serv.hnd.fd, sizeof(udp_serv.hnd.fd)) < 0) {
+ log_error("l2tp: impossible to start L2TP server:"
+ " setsockopt(SO_NO_CHECK) failed: %s\n",
+ strerror(errno));
+ goto err_fd;
+ }
- if (bind (udp_serv.hnd.fd, (struct sockaddr *) &addr, sizeof (addr)) < 0) {
- log_emerg("l2tp: bind: %s\n", strerror(errno));
- close(udp_serv.hnd.fd);
- return;
+ if (bind(udp_serv.hnd.fd,
+ (struct sockaddr *) &addr, sizeof (addr)) < 0) {
+ log_error("l2tp: impossible to start L2TP server:"
+ " bind() failed: %s\n",
+ strerror(errno));
+ goto err_fd;
}
- if (fcntl(udp_serv.hnd.fd, F_SETFL, O_NONBLOCK)) {
- log_emerg("l2tp: failed to set nonblocking mode: %s\n", strerror(errno));
- close(udp_serv.hnd.fd);
- return;
+ flag = fcntl(udp_serv.hnd.fd, F_GETFL);
+ if (flag < 0) {
+ log_error("l2tp: impossible to start L2TP server:"
+ " fcntl(F_GETFL) failed: %s\n",
+ strerror(errno));
+ goto err_fd;
+ }
+ flag = fcntl(udp_serv.hnd.fd, F_SETFL, flag | O_NONBLOCK);
+ if (flag < 0) {
+ log_error("l2tp: impossible to start L2TP server:"
+ " fcntl(F_SETFL) failed: %s\n",
+ strerror(errno));
+ goto err_fd;
}
- if (setsockopt(udp_serv.hnd.fd, IPPROTO_IP, IP_PKTINFO, &flag, sizeof(flag))) {
- log_emerg("l2tp: setsockopt(IP_PKTINFO): %s\n", strerror(errno));
- close(udp_serv.hnd.fd);
- return;
+ flag = 1;
+ if (setsockopt(udp_serv.hnd.fd, IPPROTO_IP,
+ IP_PKTINFO, &flag, sizeof(flag)) < 0) {
+ log_error("l2tp: impossible to start L2TP server:"
+ " setsockopt(IP_PKTINFO) failed: %s\n",
+ strerror(errno));
+ goto err_fd;
}
memcpy(&udp_serv.addr, &addr, sizeof(addr));
@@ -3139,13 +3176,26 @@ static void start_udp_server(void)
if (triton_context_register(&udp_serv.ctx, NULL) < 0) {
log_error("l2tp: impossible to start L2TP server:"
" context registration failed\n");
+ goto err_fd;
}
triton_md_register_handler(&udp_serv.ctx, &udp_serv.hnd);
if (triton_md_enable_handler(&udp_serv.hnd, MD_MODE_READ) < 0) {
log_error("l2tp: impossible to start L2TP server:"
" enabling handler failed\n");
+ goto err_hnd;
}
triton_context_wakeup(&udp_serv.ctx);
+
+ return 0;
+
+err_hnd:
+ triton_md_unregister_handler(&udp_serv.hnd);
+ triton_context_unregister(&udp_serv.ctx);
+err_fd:
+ close(udp_serv.hnd.fd);
+ udp_serv.hnd.fd = -1;
+
+ return -1;
}
static int show_stat_exec(const char *cmd, char * const *fields, int fields_cnt, void *client)