]> git.ipfire.org Git - thirdparty/openssh-portable.git/commitdiff
upstream commit
authordjm@openbsd.org <djm@openbsd.org>
Mon, 5 Oct 2015 17:11:21 +0000 (17:11 +0000)
committerDamien Miller <djm@mindrot.org>
Tue, 6 Oct 2015 01:26:41 +0000 (12:26 +1100)
some more bzero->explicit_bzero, from Michael McConville

Upstream-ID: 17f19545685c33327db2efdc357c1c9225ff00d0

sshbuf-misc.c
sshbuf.c

index d022065f92a4f9fe3c20adecc23b126865c6e30a..3da4b80e765880b0065f1d181af2dc7d62467232 100644 (file)
@@ -1,4 +1,4 @@
-/*     $OpenBSD: sshbuf-misc.c,v 1.4 2015/03/24 20:03:44 markus Exp $  */
+/*     $OpenBSD: sshbuf-misc.c,v 1.5 2015/10/05 17:11:21 djm Exp $     */
 /*
  * Copyright (c) 2011 Damien Miller
  *
@@ -103,7 +103,7 @@ sshbuf_dtob64(struct sshbuf *buf)
        if (SIZE_MAX / 2 <= len || (ret = malloc(plen)) == NULL)
                return NULL;
        if ((r = b64_ntop(p, len, ret, plen)) == -1) {
-               bzero(ret, plen);
+               explicit_bzero(ret, plen);
                free(ret);
                return NULL;
        }
@@ -122,16 +122,16 @@ sshbuf_b64tod(struct sshbuf *buf, const char *b64)
        if ((p = malloc(plen)) == NULL)
                return SSH_ERR_ALLOC_FAIL;
        if ((nlen = b64_pton(b64, p, plen)) < 0) {
-               bzero(p, plen);
+               explicit_bzero(p, plen);
                free(p);
                return SSH_ERR_INVALID_FORMAT;
        }
        if ((r = sshbuf_put(buf, p, nlen)) < 0) {
-               bzero(p, plen);
+               explicit_bzero(p, plen);
                free(p);
                return r;
        }
-       bzero(p, plen);
+       explicit_bzero(p, plen);
        free(p);
        return 0;
 }
index dbe0c9192e2f1a98c54e25eab5a0ff63b51d278a..fd281ed9eac9150e8565fedb64a18c15e5834364 100644 (file)
--- a/sshbuf.c
+++ b/sshbuf.c
@@ -1,4 +1,4 @@
-/*     $OpenBSD: sshbuf.c,v 1.3 2015/01/20 23:14:00 deraadt Exp $      */
+/*     $OpenBSD: sshbuf.c,v 1.4 2015/10/05 17:11:21 djm Exp $  */
 /*
  * Copyright (c) 2011 Damien Miller
  *
@@ -177,7 +177,7 @@ sshbuf_free(struct sshbuf *buf)
                return;
        dont_free = buf->dont_free;
        if (!buf->readonly) {
-               bzero(buf->d, buf->alloc);
+               explicit_bzero(buf->d, buf->alloc);
                free(buf->d);
        }
        bzero(buf, sizeof(*buf));