X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=blobdiff_plain;ds=sidebyside;f=sshpubk.c;h=ac9e0fa7e11e20bbbe1293aa2fa45dc12279b070;hb=f1d6fa47125cf625bfebdeca2b7d3c0022acd01c;hp=b860040dbfbe55f321978a8c2b0d8c6fdead895f;hpb=1dbdd2c43ff7c72f560cac113e7dfe114636767f;p=PuTTY.git diff --git a/sshpubk.c b/sshpubk.c index b860040d..ac9e0fa7 100644 --- a/sshpubk.c +++ b/sshpubk.c @@ -67,12 +67,13 @@ static int loadrsakey_main(FILE * fp, struct RSAKey *key, int pub_only, i += 4; /* Now the serious stuff. An ordinary SSH-1 public key. */ - i += makekey(buf + i, len, key, NULL, 1); - if (i < 0) + j = makekey(buf + i, len, key, NULL, 1); + if (j < 0) goto end; /* overran */ + i += j; /* Next, the comment field. */ - j = GET_32BIT(buf + i); + j = toint(GET_32BIT(buf + i)); i += 4; if (j < 0 || len - i < j) goto end; @@ -462,7 +463,7 @@ static int read_header(FILE * fp, char *header) int len = 39; int c; - while (len > 0) { + while (1) { c = fgetc(fp); if (c == '\n' || c == '\r' || c == EOF) return 0; /* failure */ @@ -1007,6 +1008,8 @@ int ssh2_userkey_encrypted(const Filename *filename, char **commentptr) if (commentptr) *commentptr = comment; + else + sfree(comment); fclose(fp); if (!strcmp(b, "aes256-cbc"))