Fixed memory leaks

This commit is contained in:
Gerhard Rieger 2015-04-02 16:34:48 +02:00
parent 8a1cd142f2
commit 8bc0f03a59
3 changed files with 20 additions and 5 deletions

View file

@ -207,6 +207,9 @@ corrections:
Socat did not work in FIPS mode because 1024 instead of 512 bit DH prime Socat did not work in FIPS mode because 1024 instead of 512 bit DH prime
is required. Thanks to Zhigang Wang for reporting and sending a patch. is required. Thanks to Zhigang Wang for reporting and sending a patch.
Christophe Leroy provided a patch that fixes memory leaks reported by
valgrind
porting: porting:
Red Hat issue 1020203: configure checks fail with some compilers. Red Hat issue 1020203: configure checks fail with some compilers.
Use case: clang Use case: clang

View file

@ -1,5 +1,5 @@
/* source: xio-ipapp.c */ /* source: xio-ipapp.c */
/* Copyright Gerhard Rieger 2001-2008 */ /* Copyright Gerhard Rieger */
/* Published under the GNU General Public License V.2, see file COPYING */ /* Published under the GNU General Public License V.2, see file COPYING */
/* this file contains the source for TCP and UDP related options */ /* this file contains the source for TCP and UDP related options */
@ -91,12 +91,13 @@ int xioopen_ipapp_connect(int argc, const char *argv[], struct opt *opts,
if (result == STAT_RETRYLATER) { if (result == STAT_RETRYLATER) {
Nanosleep(&xfd->intervall, NULL); Nanosleep(&xfd->intervall, NULL);
} }
dropopts(opts, PH_ALL); opts = copyopts(opts0, GROUP_ALL); dropopts(opts, PH_ALL); free(opts); opts = copyopts(opts0, GROUP_ALL);
continue; continue;
} }
return STAT_NORETRY; return STAT_NORETRY;
#endif /* WITH_RETRY */ #endif /* WITH_RETRY */
default: default:
free(opts0); free(opts);
return result; return result;
} }
if (XIOWITHWR(rw)) xfd->wfd = xfd->rfd; if (XIOWITHWR(rw)) xfd->wfd = xfd->rfd;
@ -114,6 +115,7 @@ int xioopen_ipapp_connect(int argc, const char *argv[], struct opt *opts,
if (xfd->forever || --xfd->retry) { if (xfd->forever || --xfd->retry) {
Nanosleep(&xfd->intervall, NULL); continue; Nanosleep(&xfd->intervall, NULL); continue;
} }
free(opts0);
return STAT_RETRYLATER; return STAT_RETRYLATER;
} }
@ -128,7 +130,7 @@ int xioopen_ipapp_connect(int argc, const char *argv[], struct opt *opts,
/* with and without retry */ /* with and without retry */
Nanosleep(&xfd->intervall, NULL); Nanosleep(&xfd->intervall, NULL);
dropopts(opts, PH_ALL); opts = copyopts(opts0, GROUP_ALL); dropopts(opts, PH_ALL); free(opts); opts = copyopts(opts0, GROUP_ALL);
continue; /* with next socket() bind() connect() */ continue; /* with next socket() bind() connect() */
} else } else
#endif /* WITH_RETRY */ #endif /* WITH_RETRY */
@ -139,8 +141,10 @@ int xioopen_ipapp_connect(int argc, const char *argv[], struct opt *opts,
/* only "active" process breaks (master without fork, or child) */ /* only "active" process breaks (master without fork, or child) */
if ((result = _xio_openlate(xfd, opts)) < 0) { if ((result = _xio_openlate(xfd, opts)) < 0) {
free(opts0);free(opts);
return result; return result;
} }
free(opts0);free(opts);
return 0; return 0;
} }

View file

@ -159,6 +159,7 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
if (total_timeout.tv_sec < 0 || if (total_timeout.tv_sec < 0 ||
total_timeout.tv_sec == 0 && total_timeout.tv_usec < 0) { total_timeout.tv_sec == 0 && total_timeout.tv_usec < 0) {
Notice("inactivity timeout triggered"); Notice("inactivity timeout triggered");
free(buff);
return 0; return 0;
} }
} }
@ -172,7 +173,7 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
/* there is a ignoreeof poll timeout, use it */ /* there is a ignoreeof poll timeout, use it */
timeout = xioparams->pollintv; timeout = xioparams->pollintv;
to = &timeout; to = &timeout;
} else if (xioparams->total_timeout.tv_sec != 0 || } else if (xioparams->total_timeout.tv_sec != 0 ||
xioparams->total_timeout.tv_usec != 0) { xioparams->total_timeout.tv_usec != 0) {
/* there might occur a total inactivity timeout */ /* there might occur a total inactivity timeout */
timeout = xioparams->total_timeout; timeout = xioparams->total_timeout;
@ -289,7 +290,8 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
fds[0].fd, fds[0].events, fds[1].fd, fds[1].events, fds[0].fd, fds[0].events, fds[1].fd, fds[1].events,
fds[2].fd, fds[2].events, fds[3].fd, fds[3].events, fds[2].fd, fds[2].events, fds[3].fd, fds[3].events,
timeout.tv_sec, timeout.tv_usec, strerror(errno)); timeout.tv_sec, timeout.tv_usec, strerror(errno));
return -1; free(buff);
return -1;
} else if (retval == 0) { } else if (retval == 0) {
Info2("poll timed out (no data within %ld.%06ld seconds)", Info2("poll timed out (no data within %ld.%06ld seconds)",
(sock1->stream.closing>=1||sock2->stream.closing>=1)? (sock1->stream.closing>=1||sock2->stream.closing>=1)?
@ -312,6 +314,7 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
xioparams->total_timeout.tv_usec != 0) { xioparams->total_timeout.tv_usec != 0) {
/* there was a total inactivity timeout */ /* there was a total inactivity timeout */
Notice("inactivity timeout triggered"); Notice("inactivity timeout triggered");
free(buff);
return 0; return 0;
} }
@ -332,6 +335,7 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
named pipe. a read() might imm. return with 0 bytes, resulting named pipe. a read() might imm. return with 0 bytes, resulting
in a loop? */ in a loop? */
Error1("poll(...[%d]: invalid request", fd1in->fd); Error1("poll(...[%d]: invalid request", fd1in->fd);
free(buff);
return -1; return -1;
} }
mayrd1 = true; mayrd1 = true;
@ -343,6 +347,7 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
(fd2in->revents)) { (fd2in->revents)) {
if (fd2in->revents & POLLNVAL) { if (fd2in->revents & POLLNVAL) {
Error1("poll(...[%d]: invalid request", fd2in->fd); Error1("poll(...[%d]: invalid request", fd2in->fd);
free(buff);
return -1; return -1;
} }
mayrd2 = true; mayrd2 = true;
@ -351,6 +356,7 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
if (XIO_GETWRFD(sock1) >= 0 && fd1out->fd >= 0 && fd1out->revents) { if (XIO_GETWRFD(sock1) >= 0 && fd1out->fd >= 0 && fd1out->revents) {
if (fd1out->revents & POLLNVAL) { if (fd1out->revents & POLLNVAL) {
Error1("poll(...[%d]: invalid request", fd1out->fd); Error1("poll(...[%d]: invalid request", fd1out->fd);
free(buff);
return -1; return -1;
} }
maywr1 = true; maywr1 = true;
@ -358,6 +364,7 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
if (XIO_GETWRFD(sock2) >= 0 && fd2out->fd >= 0 && fd2out->revents) { if (XIO_GETWRFD(sock2) >= 0 && fd2out->fd >= 0 && fd2out->revents) {
if (fd2out->revents & POLLNVAL) { if (fd2out->revents & POLLNVAL) {
Error1("poll(...[%d]: invalid request", fd2out->fd); Error1("poll(...[%d]: invalid request", fd2out->fd);
free(buff);
return -1; return -1;
} }
maywr2 = true; maywr2 = true;
@ -494,6 +501,7 @@ int _socat(xiofile_t *xfd1, xiofile_t *xfd2) {
xioclose(sock1); xioclose(sock1);
xioclose(sock2); xioclose(sock2);
free(buff);
return 0; return 0;
} }