This wasn't done correctly in the previous commit. First of all, the
order of cleanup was wrong, the cleanup area should only be called if
failures occurred after the fd allocation, not before. Also, fd should
be reinitialised to -1 once we close the socket.
Change-Id: I96edd3c4685300e4ec8e25e55aa8a17774700eb5
Signed-off-by: Awadhesh Singh <awadhesh1.s@samsung.com>
goto error_umask;
if (fcntl(svr->fd, F_SETFL, O_NONBLOCK) < 0)
- goto error_umask;
+ goto error_fd;
if (fcntl(svr->fd, F_SETFD, FD_CLOEXEC) < 0)
- goto error_umask;
+ goto error_fd;
lin.l_onoff = 1;
lin.l_linger = 0;
if (setsockopt(svr->fd, SOL_SOCKET, SO_LINGER, (const void *)&lin,
sizeof(struct linger)) < 0)
- goto error_umask;
+ goto error_fd;
if (bind(svr->fd, (struct sockaddr *)&socket_unix, socket_unix_len) < 0)
{
else
{
ERR("Local socket '%s' removal failed: %s", buf, strerror(errno));
- goto error_umask;
+ goto error_fd;
}
}
}
if (listen(svr->fd, 4096) < 0)
- goto error_umask;
+ goto error_fd;
#ifdef HAVE_SYSTEMD
fd_ready:
return 1;
+error_fd:
+ close(svr->fd);
+ svr->fd = -1;
error_umask:
umask(pmode);
error: