upstream commit
Remove NULL-checks before free(). ok dtucker@ Upstream-ID: e3d3cb1ce900179906af36517b5eea0fb15e6ef8
This commit is contained in:
parent
8e56dd46cb
commit
d59ce08811
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: auth-options.c,v 1.69 2015/11/16 00:30:02 djm Exp $ */
|
/* $OpenBSD: auth-options.c,v 1.70 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -75,14 +75,10 @@ auth_clear_options(void)
|
||||||
free(ce->s);
|
free(ce->s);
|
||||||
free(ce);
|
free(ce);
|
||||||
}
|
}
|
||||||
if (forced_command) {
|
free(forced_command);
|
||||||
free(forced_command);
|
forced_command = NULL;
|
||||||
forced_command = NULL;
|
free(authorized_principals);
|
||||||
}
|
authorized_principals = NULL;
|
||||||
if (authorized_principals) {
|
|
||||||
free(authorized_principals);
|
|
||||||
authorized_principals = NULL;
|
|
||||||
}
|
|
||||||
forced_tun_device = -1;
|
forced_tun_device = -1;
|
||||||
channel_clear_permitted_opens();
|
channel_clear_permitted_opens();
|
||||||
}
|
}
|
||||||
|
@ -175,8 +171,7 @@ auth_parse_options(struct passwd *pw, char *opts, char *file, u_long linenum)
|
||||||
cp = "command=\"";
|
cp = "command=\"";
|
||||||
if (strncasecmp(opts, cp, strlen(cp)) == 0) {
|
if (strncasecmp(opts, cp, strlen(cp)) == 0) {
|
||||||
opts += strlen(cp);
|
opts += strlen(cp);
|
||||||
if (forced_command != NULL)
|
free(forced_command);
|
||||||
free(forced_command);
|
|
||||||
forced_command = xmalloc(strlen(opts) + 1);
|
forced_command = xmalloc(strlen(opts) + 1);
|
||||||
i = 0;
|
i = 0;
|
||||||
while (*opts) {
|
while (*opts) {
|
||||||
|
@ -206,8 +201,7 @@ auth_parse_options(struct passwd *pw, char *opts, char *file, u_long linenum)
|
||||||
cp = "principals=\"";
|
cp = "principals=\"";
|
||||||
if (strncasecmp(opts, cp, strlen(cp)) == 0) {
|
if (strncasecmp(opts, cp, strlen(cp)) == 0) {
|
||||||
opts += strlen(cp);
|
opts += strlen(cp);
|
||||||
if (authorized_principals != NULL)
|
free(authorized_principals);
|
||||||
free(authorized_principals);
|
|
||||||
authorized_principals = xmalloc(strlen(opts) + 1);
|
authorized_principals = xmalloc(strlen(opts) + 1);
|
||||||
i = 0;
|
i = 0;
|
||||||
while (*opts) {
|
while (*opts) {
|
||||||
|
@ -593,8 +587,7 @@ parse_option_list(struct sshbuf *oblob, struct passwd *pw,
|
||||||
free(*cert_forced_command);
|
free(*cert_forced_command);
|
||||||
*cert_forced_command = NULL;
|
*cert_forced_command = NULL;
|
||||||
}
|
}
|
||||||
if (name != NULL)
|
free(name);
|
||||||
free(name);
|
|
||||||
sshbuf_free(data);
|
sshbuf_free(data);
|
||||||
sshbuf_free(c);
|
sshbuf_free(c);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -638,8 +631,7 @@ auth_cert_options(struct sshkey *k, struct passwd *pw)
|
||||||
no_user_rc |= cert_no_user_rc;
|
no_user_rc |= cert_no_user_rc;
|
||||||
/* CA-specified forced command supersedes key option */
|
/* CA-specified forced command supersedes key option */
|
||||||
if (cert_forced_command != NULL) {
|
if (cert_forced_command != NULL) {
|
||||||
if (forced_command != NULL)
|
free(forced_command);
|
||||||
free(forced_command);
|
|
||||||
forced_command = cert_forced_command;
|
forced_command = cert_forced_command;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: authfile.c,v 1.117 2015/09/13 14:39:16 tim Exp $ */
|
/* $OpenBSD: authfile.c,v 1.118 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2013 Markus Friedl. All rights reserved.
|
* Copyright (c) 2000, 2013 Markus Friedl. All rights reserved.
|
||||||
*
|
*
|
||||||
|
@ -426,8 +426,7 @@ sshkey_load_cert(const char *filename, struct sshkey **keyp)
|
||||||
r = 0;
|
r = 0;
|
||||||
|
|
||||||
out:
|
out:
|
||||||
if (file != NULL)
|
free(file);
|
||||||
free(file);
|
|
||||||
if (pub != NULL)
|
if (pub != NULL)
|
||||||
sshkey_free(pub);
|
sshkey_free(pub);
|
||||||
return r;
|
return r;
|
||||||
|
|
5
cipher.c
5
cipher.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: cipher.c,v 1.100 2015/01/14 10:29:45 djm Exp $ */
|
/* $OpenBSD: cipher.c,v 1.101 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -353,8 +353,7 @@ cipher_init(struct sshcipher_ctx *cc, const struct sshcipher *cipher,
|
||||||
if (cipher->discard_len > 0) {
|
if (cipher->discard_len > 0) {
|
||||||
if ((junk = malloc(cipher->discard_len)) == NULL ||
|
if ((junk = malloc(cipher->discard_len)) == NULL ||
|
||||||
(discard = malloc(cipher->discard_len)) == NULL) {
|
(discard = malloc(cipher->discard_len)) == NULL) {
|
||||||
if (junk != NULL)
|
free(junk);
|
||||||
free(junk);
|
|
||||||
ret = SSH_ERR_ALLOC_FAIL;
|
ret = SSH_ERR_ALLOC_FAIL;
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
5
kex.c
5
kex.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: kex.c,v 1.113 2015/12/04 16:41:28 markus Exp $ */
|
/* $OpenBSD: kex.c,v 1.114 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2001 Markus Friedl. All rights reserved.
|
* Copyright (c) 2000, 2001 Markus Friedl. All rights reserved.
|
||||||
*
|
*
|
||||||
|
@ -906,8 +906,7 @@ derive_key(struct ssh *ssh, int id, u_int need, u_char *hash, u_int hashlen,
|
||||||
digest = NULL;
|
digest = NULL;
|
||||||
r = 0;
|
r = 0;
|
||||||
out:
|
out:
|
||||||
if (digest)
|
free(digest);
|
||||||
free(digest);
|
|
||||||
ssh_digest_free(hashctx);
|
ssh_digest_free(hashctx);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
14
packet.c
14
packet.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: packet.c,v 1.218 2015/12/04 16:41:28 markus Exp $ */
|
/* $OpenBSD: packet.c,v 1.219 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -519,10 +519,8 @@ ssh_packet_close(struct ssh *ssh)
|
||||||
error("%s: cipher_cleanup failed: %s", __func__, ssh_err(r));
|
error("%s: cipher_cleanup failed: %s", __func__, ssh_err(r));
|
||||||
if ((r = cipher_cleanup(&state->receive_context)) != 0)
|
if ((r = cipher_cleanup(&state->receive_context)) != 0)
|
||||||
error("%s: cipher_cleanup failed: %s", __func__, ssh_err(r));
|
error("%s: cipher_cleanup failed: %s", __func__, ssh_err(r));
|
||||||
if (ssh->remote_ipaddr) {
|
free(ssh->remote_ipaddr);
|
||||||
free(ssh->remote_ipaddr);
|
ssh->remote_ipaddr = NULL;
|
||||||
ssh->remote_ipaddr = NULL;
|
|
||||||
}
|
|
||||||
free(ssh->state);
|
free(ssh->state);
|
||||||
ssh->state = NULL;
|
ssh->state = NULL;
|
||||||
}
|
}
|
||||||
|
@ -1784,8 +1782,7 @@ ssh_packet_read_poll_seqnr(struct ssh *ssh, u_char *typep, u_int32_t *seqnr_p)
|
||||||
if ((r = sshpkt_get_u8(ssh, NULL)) != 0 ||
|
if ((r = sshpkt_get_u8(ssh, NULL)) != 0 ||
|
||||||
(r = sshpkt_get_string(ssh, &msg, NULL)) != 0 ||
|
(r = sshpkt_get_string(ssh, &msg, NULL)) != 0 ||
|
||||||
(r = sshpkt_get_string(ssh, NULL, NULL)) != 0) {
|
(r = sshpkt_get_string(ssh, NULL, NULL)) != 0) {
|
||||||
if (msg)
|
free(msg);
|
||||||
free(msg);
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
debug("Remote: %.900s", msg);
|
debug("Remote: %.900s", msg);
|
||||||
|
@ -2570,8 +2567,7 @@ newkeys_from_blob(struct sshbuf *m, struct ssh *ssh, int mode)
|
||||||
newkey = NULL;
|
newkey = NULL;
|
||||||
r = 0;
|
r = 0;
|
||||||
out:
|
out:
|
||||||
if (newkey != NULL)
|
free(newkey);
|
||||||
free(newkey);
|
|
||||||
if (b != NULL)
|
if (b != NULL)
|
||||||
sshbuf_free(b);
|
sshbuf_free(b);
|
||||||
return r;
|
return r;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: ssh-dss.c,v 1.32 2014/06/24 01:13:21 djm Exp $ */
|
/* $OpenBSD: ssh-dss.c,v 1.33 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000 Markus Friedl. All rights reserved.
|
* Copyright (c) 2000 Markus Friedl. All rights reserved.
|
||||||
*
|
*
|
||||||
|
@ -211,8 +211,7 @@ ssh_dss_verify(const struct sshkey *key,
|
||||||
DSA_SIG_free(sig);
|
DSA_SIG_free(sig);
|
||||||
if (b != NULL)
|
if (b != NULL)
|
||||||
sshbuf_free(b);
|
sshbuf_free(b);
|
||||||
if (ktype != NULL)
|
free(ktype);
|
||||||
free(ktype);
|
|
||||||
if (sigblob != NULL) {
|
if (sigblob != NULL) {
|
||||||
explicit_bzero(sigblob, len);
|
explicit_bzero(sigblob, len);
|
||||||
free(sigblob);
|
free(sigblob);
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: ssh-rsa.c,v 1.56 2015/12/07 20:04:09 markus Exp $ */
|
/* $OpenBSD: ssh-rsa.c,v 1.57 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2003 Markus Friedl <markus@openbsd.org>
|
* Copyright (c) 2000, 2003 Markus Friedl <markus@openbsd.org>
|
||||||
*
|
*
|
||||||
|
@ -226,8 +226,7 @@ ssh_rsa_verify(const struct sshkey *key,
|
||||||
explicit_bzero(sigblob, len);
|
explicit_bzero(sigblob, len);
|
||||||
free(sigblob);
|
free(sigblob);
|
||||||
}
|
}
|
||||||
if (ktype != NULL)
|
free(ktype);
|
||||||
free(ktype);
|
|
||||||
if (b != NULL)
|
if (b != NULL)
|
||||||
sshbuf_free(b);
|
sshbuf_free(b);
|
||||||
explicit_bzero(digest, sizeof(digest));
|
explicit_bzero(digest, sizeof(digest));
|
||||||
|
|
5
ssh.c
5
ssh.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: ssh.c,v 1.430 2015/11/19 08:23:27 djm Exp $ */
|
/* $OpenBSD: ssh.c,v 1.431 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -911,8 +911,7 @@ main(int ac, char **av)
|
||||||
subsystem_flag = 1;
|
subsystem_flag = 1;
|
||||||
break;
|
break;
|
||||||
case 'S':
|
case 'S':
|
||||||
if (options.control_path != NULL)
|
free(options.control_path);
|
||||||
free(options.control_path);
|
|
||||||
options.control_path = xstrdup(optarg);
|
options.control_path = xstrdup(optarg);
|
||||||
break;
|
break;
|
||||||
case 'b':
|
case 'b':
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: sshconnect2.c,v 1.231 2015/12/04 16:41:28 markus Exp $ */
|
/* $OpenBSD: sshconnect2.c,v 1.232 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000 Markus Friedl. All rights reserved.
|
* Copyright (c) 2000 Markus Friedl. All rights reserved.
|
||||||
* Copyright (c) 2008 Damien Miller. All rights reserved.
|
* Copyright (c) 2008 Damien Miller. All rights reserved.
|
||||||
|
@ -1257,8 +1257,7 @@ load_identity_file(Identity *id)
|
||||||
explicit_bzero(passphrase, strlen(passphrase));
|
explicit_bzero(passphrase, strlen(passphrase));
|
||||||
free(passphrase);
|
free(passphrase);
|
||||||
}
|
}
|
||||||
if (comment)
|
free(comment);
|
||||||
free(comment);
|
|
||||||
if (private != NULL || quit)
|
if (private != NULL || quit)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
5
sshd.c
5
sshd.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: sshd.c,v 1.461 2015/12/04 16:41:28 markus Exp $ */
|
/* $OpenBSD: sshd.c,v 1.462 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -1257,8 +1257,7 @@ server_accept_loop(int *sock_in, int *sock_out, int *newsock, int *config_s)
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (received_sighup)
|
if (received_sighup)
|
||||||
sighup_restart();
|
sighup_restart();
|
||||||
if (fdset != NULL)
|
free(fdset);
|
||||||
free(fdset);
|
|
||||||
fdset = xcalloc(howmany(maxfd + 1, NFDBITS),
|
fdset = xcalloc(howmany(maxfd + 1, NFDBITS),
|
||||||
sizeof(fd_mask));
|
sizeof(fd_mask));
|
||||||
|
|
||||||
|
|
17
sshkey.c
17
sshkey.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: sshkey.c,v 1.28 2015/12/04 16:41:28 markus Exp $ */
|
/* $OpenBSD: sshkey.c,v 1.29 2015/12/10 17:08:40 mmcc Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2001 Markus Friedl. All rights reserved.
|
* Copyright (c) 2000, 2001 Markus Friedl. All rights reserved.
|
||||||
* Copyright (c) 2008 Alexander von Gernler. All rights reserved.
|
* Copyright (c) 2008 Alexander von Gernler. All rights reserved.
|
||||||
|
@ -426,12 +426,10 @@ cert_free(struct sshkey_cert *cert)
|
||||||
sshbuf_free(cert->critical);
|
sshbuf_free(cert->critical);
|
||||||
if (cert->extensions != NULL)
|
if (cert->extensions != NULL)
|
||||||
sshbuf_free(cert->extensions);
|
sshbuf_free(cert->extensions);
|
||||||
if (cert->key_id != NULL)
|
free(cert->key_id);
|
||||||
free(cert->key_id);
|
|
||||||
for (i = 0; i < cert->nprincipals; i++)
|
for (i = 0; i < cert->nprincipals; i++)
|
||||||
free(cert->principals[i]);
|
free(cert->principals[i]);
|
||||||
if (cert->principals != NULL)
|
free(cert->principals);
|
||||||
free(cert->principals);
|
|
||||||
if (cert->signature_key != NULL)
|
if (cert->signature_key != NULL)
|
||||||
sshkey_free(cert->signature_key);
|
sshkey_free(cert->signature_key);
|
||||||
explicit_bzero(cert, sizeof(*cert));
|
explicit_bzero(cert, sizeof(*cert));
|
||||||
|
@ -2473,10 +2471,8 @@ sshkey_certify(struct sshkey *k, struct sshkey *ca)
|
||||||
out:
|
out:
|
||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
sshbuf_reset(cert);
|
sshbuf_reset(cert);
|
||||||
if (sig_blob != NULL)
|
free(sig_blob);
|
||||||
free(sig_blob);
|
free(ca_blob);
|
||||||
if (ca_blob != NULL)
|
|
||||||
free(ca_blob);
|
|
||||||
if (principals != NULL)
|
if (principals != NULL)
|
||||||
sshbuf_free(principals);
|
sshbuf_free(principals);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -3764,8 +3760,7 @@ sshkey_parse_private_rsa1(struct sshbuf *blob, const char *passphrase,
|
||||||
}
|
}
|
||||||
out:
|
out:
|
||||||
explicit_bzero(&ciphercontext, sizeof(ciphercontext));
|
explicit_bzero(&ciphercontext, sizeof(ciphercontext));
|
||||||
if (comment != NULL)
|
free(comment);
|
||||||
free(comment);
|
|
||||||
if (prv != NULL)
|
if (prv != NULL)
|
||||||
sshkey_free(prv);
|
sshkey_free(prv);
|
||||||
if (copy != NULL)
|
if (copy != NULL)
|
||||||
|
|
Loading…
Reference in New Issue