1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Fix another giant batch of resource leaks. (Mostly memory, but there's

one missing fclose too.)

[originally from svn r9919]
This commit is contained in:
Simon Tatham 2013-07-14 10:46:07 +00:00
parent 896bb7c74d
commit ea301bdd9b
20 changed files with 70 additions and 19 deletions

View File

@ -370,8 +370,10 @@ static struct openssh_key *load_openssh_key(const Filename *filename,
} }
strip_crlf(line); strip_crlf(line);
if (0 == strncmp(line, "-----END ", 9) && if (0 == strncmp(line, "-----END ", 9) &&
0 == strcmp(line+strlen(line)-16, "PRIVATE KEY-----")) 0 == strcmp(line+strlen(line)-16, "PRIVATE KEY-----")) {
sfree(line);
break; /* done */ break; /* done */
}
if ((p = strchr(line, ':')) != NULL) { if ((p = strchr(line, ':')) != NULL) {
if (headers_done) { if (headers_done) {
errmsg = "header found in body of key data"; errmsg = "header found in body of key data";
@ -1091,8 +1093,10 @@ static struct sshcom_key *load_sshcom_key(const Filename *filename,
goto error; goto error;
} }
strip_crlf(line); strip_crlf(line);
if (!strcmp(line, "---- END SSH2 ENCRYPTED PRIVATE KEY ----")) if (!strcmp(line, "---- END SSH2 ENCRYPTED PRIVATE KEY ----")) {
sfree(line);
break; /* done */ break; /* done */
}
if ((p = strchr(line, ':')) != NULL) { if ((p = strchr(line, ':')) != NULL) {
if (headers_done) { if (headers_done) {
errmsg = "header found in body of key data"; errmsg = "header found in body of key data";
@ -1181,10 +1185,14 @@ static struct sshcom_key *load_sshcom_key(const Filename *filename,
goto error; goto error;
} }
fclose(fp);
if (errmsg_p) *errmsg_p = NULL; if (errmsg_p) *errmsg_p = NULL;
return ret; return ret;
error: error:
if (fp)
fclose(fp);
if (line) { if (line) {
smemclr(line, strlen(line)); smemclr(line, strlen(line));
sfree(line); sfree(line);
@ -1207,20 +1215,22 @@ int sshcom_encrypted(const Filename *filename, char **comment)
struct sshcom_key *key = load_sshcom_key(filename, NULL); struct sshcom_key *key = load_sshcom_key(filename, NULL);
int pos, len, answer; int pos, len, answer;
answer = 0;
*comment = NULL; *comment = NULL;
if (!key) if (!key)
return 0; goto done;
/* /*
* Check magic number. * Check magic number.
*/ */
if (GET_32BIT(key->keyblob) != 0x3f6ff9eb) if (GET_32BIT(key->keyblob) != 0x3f6ff9eb) {
return 0; /* key is invalid */ goto done; /* key is invalid */
}
/* /*
* Find the cipher-type string. * Find the cipher-type string.
*/ */
answer = 0;
pos = 8; pos = 8;
if (key->keyblob_len < pos+4) if (key->keyblob_len < pos+4)
goto done; /* key is far too short */ goto done; /* key is far too short */
@ -1235,7 +1245,7 @@ int sshcom_encrypted(const Filename *filename, char **comment)
answer = 1; answer = 1;
done: done:
*comment = dupstr(key->comment); *comment = dupstr(key ? key->comment : "");
smemclr(key->keyblob, key->keyblob_size); smemclr(key->keyblob, key->keyblob_size);
sfree(key->keyblob); sfree(key->keyblob);
smemclr(key, sizeof(*key)); smemclr(key, sizeof(*key));

View File

@ -386,6 +386,7 @@ const char *pfd_newconnect(Socket *s, char *hostname, int port,
pr->s = *s = new_connection(addr, dummy_realhost, port, pr->s = *s = new_connection(addr, dummy_realhost, port,
0, 1, 0, 0, (Plug) pr, conf); 0, 1, 0, 0, (Plug) pr, conf);
sfree(dummy_realhost);
if ((err = sk_socket_error(*s)) != NULL) { if ((err = sk_socket_error(*s)) != NULL) {
free_portfwd_private(pr); free_portfwd_private(pr);
return err; return err;

View File

@ -473,6 +473,7 @@ Socket new_connection(SockAddr addr, char *hostname,
conf_get_int(conf, CONF_addressfamily)); conf_get_int(conf, CONF_addressfamily));
if (sk_addr_error(proxy_addr) != NULL) { if (sk_addr_error(proxy_addr) != NULL) {
ret->error = "Proxy error: Unable to resolve proxy host name"; ret->error = "Proxy error: Unable to resolve proxy host name";
sfree(pplug);
return (Socket)ret; return (Socket)ret;
} }
sfree(proxy_canonical_name); sfree(proxy_canonical_name);

11
pscp.c
View File

@ -1118,6 +1118,9 @@ int scp_sink_setup(char *source, int preserve, int recursive)
if (!wc_unescape(newsource, source)) { if (!wc_unescape(newsource, source)) {
/* Yes, here we go; it's a wildcard. Bah. */ /* Yes, here we go; it's a wildcard. Bah. */
char *dupsource, *lastpart, *dirpart, *wildcard; char *dupsource, *lastpart, *dirpart, *wildcard;
sfree(newsource);
dupsource = dupstr(source); dupsource = dupstr(source);
lastpart = stripslashes(dupsource, 0); lastpart = stripslashes(dupsource, 0);
wildcard = dupstr(lastpart); wildcard = dupstr(lastpart);
@ -1722,17 +1725,21 @@ static void source(char *src)
return; return;
} }
if (preserve) { if (preserve) {
if (scp_send_filetimes(mtime, atime)) if (scp_send_filetimes(mtime, atime)) {
close_rfile(f);
return; return;
} }
}
if (verbose) { if (verbose) {
char sizestr[40]; char sizestr[40];
uint64_decimal(size, sizestr); uint64_decimal(size, sizestr);
tell_user(stderr, "Sending file %s, size=%s", last, sizestr); tell_user(stderr, "Sending file %s, size=%s", last, sizestr);
} }
if (scp_send_filename(last, size, permissions)) if (scp_send_filename(last, size, permissions)) {
close_rfile(f);
return; return;
}
stat_bytes = uint64_make(0,0); stat_bytes = uint64_make(0,0);
stat_starttime = time(NULL); stat_starttime = time(NULL);

View File

@ -1035,6 +1035,7 @@ int sftp_cmd_ls(struct sftp_command *cmd)
char *tmpdir; char *tmpdir;
int len, check; int len, check;
sfree(unwcdir);
wildcard = stripslashes(dir, 0); wildcard = stripslashes(dir, 0);
unwcdir = dupstr(dir); unwcdir = dupstr(dir);
len = wildcard - dir; len = wildcard - dir;
@ -2233,6 +2234,7 @@ struct sftp_command *sftp_getcmd(FILE *fp, int mode, int modeflags)
cmd->obey = sftp_cmd_quit; cmd->obey = sftp_cmd_quit;
if ((mode == 0) || (modeflags & 1)) if ((mode == 0) || (modeflags & 1))
printf("quit\n"); printf("quit\n");
sfree(line);
return cmd; /* eof */ return cmd; /* eof */
} }

1
raw.c
View File

@ -50,6 +50,7 @@ static void raw_log(Plug plug, int type, SockAddr addr, int port,
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg); msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
logevent(raw->frontend, msg); logevent(raw->frontend, msg);
sfree(msg);
} }
static void raw_check_close(Raw raw) static void raw_check_close(Raw raw)

View File

@ -58,6 +58,7 @@ static void rlogin_log(Plug plug, int type, SockAddr addr, int port,
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg); msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
logevent(rlogin->frontend, msg); logevent(rlogin->frontend, msg);
sfree(msg);
} }
static int rlogin_closing(Plug plug, const char *error_msg, int error_code, static int rlogin_closing(Plug plug, const char *error_msg, int error_code,

6
ssh.c
View File

@ -4869,14 +4869,11 @@ static void ssh1_msg_port_open(Ssh ssh, struct Packet *pktin)
{ {
/* Remote side is trying to open a channel to talk to a /* Remote side is trying to open a channel to talk to a
* forwarded port. Give them back a local channel number. */ * forwarded port. Give them back a local channel number. */
struct ssh_channel *c;
struct ssh_rportfwd pf, *pfp; struct ssh_rportfwd pf, *pfp;
int remoteid; int remoteid;
int hostsize, port; int hostsize, port;
char *host; char *host;
const char *e; const char *e;
c = snew(struct ssh_channel);
c->ssh = ssh;
remoteid = ssh_pkt_getuint32(pktin); remoteid = ssh_pkt_getuint32(pktin);
ssh_pkt_getstring(pktin, &host, &hostsize); ssh_pkt_getstring(pktin, &host, &hostsize);
@ -4895,6 +4892,9 @@ static void ssh1_msg_port_open(Ssh ssh, struct Packet *pktin)
send_packet(ssh, SSH1_MSG_CHANNEL_OPEN_FAILURE, send_packet(ssh, SSH1_MSG_CHANNEL_OPEN_FAILURE,
PKT_INT, remoteid, PKT_END); PKT_INT, remoteid, PKT_END);
} else { } else {
struct ssh_channel *c = snew(struct ssh_channel);
c->ssh = ssh;
logeventf(ssh, "Received remote port open request for %s:%d", logeventf(ssh, "Received remote port open request for %s:%d",
pf.dhost, port); pf.dhost, port);
e = pfd_newconnect(&c->u.pfd.s, pf.dhost, port, e = pfd_newconnect(&c->u.pfd.s, pf.dhost, port,

View File

@ -289,6 +289,8 @@ static int dss_verifysig(void *key, char *sig, int siglen,
freebn(w); freebn(w);
freebn(sha); freebn(sha);
freebn(u1);
freebn(u2);
freebn(gu1p); freebn(gu1p);
freebn(yu2p); freebn(yu2p);
freebn(gu1yu2p); freebn(gu1yu2p);
@ -404,6 +406,7 @@ static void *dss_createkey(unsigned char *pub_blob, int pub_len,
ytest = modpow(dss->g, dss->x, dss->p); ytest = modpow(dss->g, dss->x, dss->p);
if (0 != bignum_cmp(ytest, dss->y)) { if (0 != bignum_cmp(ytest, dss->y)) {
dss_freekey(dss); dss_freekey(dss);
freebn(ytest);
return NULL; return NULL;
} }
freebn(ytest); freebn(ytest);

View File

@ -1008,6 +1008,8 @@ int ssh2_userkey_encrypted(const Filename *filename, char **commentptr)
if (commentptr) if (commentptr)
*commentptr = comment; *commentptr = comment;
else
sfree(comment);
fclose(fp); fclose(fp);
if (!strcmp(b, "aes256-cbc")) if (!strcmp(b, "aes256-cbc"))

View File

@ -413,6 +413,7 @@ int rsa_verify(struct RSAKey *key)
pm1 = copybn(key->p); pm1 = copybn(key->p);
decbn(pm1); decbn(pm1);
ed = modmul(key->exponent, key->private_exponent, pm1); ed = modmul(key->exponent, key->private_exponent, pm1);
freebn(pm1);
cmp = bignum_cmp(ed, One); cmp = bignum_cmp(ed, One);
sfree(ed); sfree(ed);
if (cmp != 0) if (cmp != 0)
@ -421,6 +422,7 @@ int rsa_verify(struct RSAKey *key)
qm1 = copybn(key->q); qm1 = copybn(key->q);
decbn(qm1); decbn(qm1);
ed = modmul(key->exponent, key->private_exponent, qm1); ed = modmul(key->exponent, key->private_exponent, qm1);
freebn(qm1);
cmp = bignum_cmp(ed, One); cmp = bignum_cmp(ed, One);
sfree(ed); sfree(ed);
if (cmp != 0) if (cmp != 0)

View File

@ -662,6 +662,7 @@ static void telnet_log(Plug plug, int type, SockAddr addr, int port,
msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg); msg = dupprintf("Failed to connect to %s: %s", addrbuf, error_msg);
logevent(telnet->frontend, msg); logevent(telnet->frontend, msg);
sfree(msg);
} }
static int telnet_closing(Plug plug, const char *error_msg, int error_code, static int telnet_closing(Plug plug, const char *error_msg, int error_code,

View File

@ -191,8 +191,10 @@ static char *x11_guess_derived_font_name(XFontStruct *xfs, int bold, int wide)
p++; p++;
} }
if (nstr < lenof(strings)) if (nstr < lenof(strings)) {
sfree(dupname);
return NULL; /* XLFD was malformed */ return NULL; /* XLFD was malformed */
}
if (bold) if (bold)
strings[2] = "bold"; strings[2] = "bold";

View File

@ -3009,7 +3009,7 @@ void change_settings_menuitem(GtkMenuItem *item, gpointer data)
4, 12, 5, 13, 6, 14, 7, 15 4, 12, 5, 13, 6, 14, 7, 15
}; };
struct gui_data *inst = (struct gui_data *)data; struct gui_data *inst = (struct gui_data *)data;
char *title = dupcat(appname, " Reconfiguration", NULL); char *title;
Conf *oldconf, *newconf; Conf *oldconf, *newconf;
int i, j, need_size; int i, j, need_size;
@ -3020,6 +3020,8 @@ void change_settings_menuitem(GtkMenuItem *item, gpointer data)
else else
inst->reconfiguring = TRUE; inst->reconfiguring = TRUE;
title = dupcat(appname, " Reconfiguration", NULL);
oldconf = inst->conf; oldconf = inst->conf;
newconf = conf_copy(inst->conf); newconf = conf_copy(inst->conf);
@ -3134,6 +3136,7 @@ void change_settings_menuitem(GtkMenuItem *item, gpointer data)
string_width("Could not change fonts in terminal window:"), string_width("Could not change fonts in terminal window:"),
"OK", 'o', +1, 1, "OK", 'o', +1, 1,
NULL); NULL);
sfree(msgboxtext);
sfree(errmsg); sfree(errmsg);
} else { } else {
need_size = TRUE; need_size = TRUE;
@ -3228,6 +3231,7 @@ void fork_and_exec_self(struct gui_data *inst, int fd_to_close, ...)
pid = fork(); pid = fork();
if (pid < 0) { if (pid < 0) {
perror("fork"); perror("fork");
sfree(args);
return; return;
} }
@ -3261,6 +3265,7 @@ void fork_and_exec_self(struct gui_data *inst, int fd_to_close, ...)
} else { } else {
int status; int status;
sfree(args);
waitpid(pid, &status, 0); waitpid(pid, &status, 0);
} }
@ -3339,6 +3344,7 @@ int read_dupsession_data(struct gui_data *inst, Conf *conf, char *arg)
} }
size_used = conf_deserialise(conf, data, size); size_used = conf_deserialise(conf, data, size);
sfree(data);
if (use_pty_argv && size > size_used) { if (use_pty_argv && size > size_used) {
int n = 0; int n = 0;
i = size_used; i = size_used;

View File

@ -26,6 +26,7 @@ char *get_random_data(int len)
ret = read(fd, buf+ngot, len-ngot); ret = read(fd, buf+ngot, len-ngot);
if (ret < 0) { if (ret < 0) {
close(fd); close(fd);
sfree(buf);
perror("puttygen: unable to read /dev/random"); perror("puttygen: unable to read /dev/random");
return NULL; return NULL;
} }

View File

@ -297,6 +297,7 @@ Socket platform_new_connection(SockAddr addr, char *hostname,
if (pid < 0) { if (pid < 0) {
ret->error = dupprintf("fork: %s", strerror(errno)); ret->error = dupprintf("fork: %s", strerror(errno));
sfree(cmd);
return (Socket)ret; return (Socket)ret;
} else if (pid == 0) { } else if (pid == 0) {
close(0); close(0);

View File

@ -308,6 +308,7 @@ static const char *serial_init(void *frontend_handle, void **backend_handle,
{ {
char *msg = dupprintf("Opening serial device %s", line); char *msg = dupprintf("Opening serial device %s", line);
logevent(serial->frontend, msg); logevent(serial->frontend, msg);
sfree(msg);
} }
serial->fd = open(line, O_RDWR | O_NOCTTY | O_NDELAY | O_NONBLOCK); serial->fd = open(line, O_RDWR | O_NOCTTY | O_NDELAY | O_NONBLOCK);

View File

@ -565,6 +565,7 @@ char *ssh_sftp_get_cmdline(char *prompt, int no_fds_ok)
ret = ssh_sftp_do_select(TRUE, no_fds_ok); ret = ssh_sftp_do_select(TRUE, no_fds_ok);
if (ret < 0) { if (ret < 0) {
printf("connection died\n"); printf("connection died\n");
sfree(buf);
return NULL; /* woop woop */ return NULL; /* woop woop */
} }
if (ret > 0) { if (ret > 0) {
@ -575,10 +576,12 @@ char *ssh_sftp_get_cmdline(char *prompt, int no_fds_ok)
ret = read(0, buf+buflen, 1); ret = read(0, buf+buflen, 1);
if (ret < 0) { if (ret < 0) {
perror("read"); perror("read");
sfree(buf);
return NULL; return NULL;
} }
if (ret == 0) { if (ret == 0) {
/* eof on stdin; no error, but no answer either */ /* eof on stdin; no error, but no answer either */
sfree(buf);
return NULL; return NULL;
} }

View File

@ -299,8 +299,10 @@ void *open_settings_r(const char *sessionname)
char *value = strchr(line, '='); char *value = strchr(line, '=');
struct skeyval *kv; struct skeyval *kv;
if (!value) if (!value) {
sfree(line);
continue; continue;
}
*value++ = '\0'; *value++ = '\0';
value[strcspn(value, "\r\n")] = '\0'; /* trim trailing NL */ value[strcspn(value, "\r\n")] = '\0'; /* trim trailing NL */
@ -589,9 +591,6 @@ void store_host_key(const char *hostname, int port,
int headerlen; int headerlen;
char *filename, *tmpfilename; char *filename, *tmpfilename;
newtext = dupprintf("%s@%d:%s %s\n", keytype, port, hostname, key);
headerlen = 1 + strcspn(newtext, " "); /* count the space too */
/* /*
* Open both the old file and a new file. * Open both the old file and a new file.
*/ */
@ -613,6 +612,9 @@ void store_host_key(const char *hostname, int port,
filename = make_filename(INDEX_HOSTKEYS, NULL); filename = make_filename(INDEX_HOSTKEYS, NULL);
rfp = fopen(filename, "r"); rfp = fopen(filename, "r");
newtext = dupprintf("%s@%d:%s %s\n", keytype, port, hostname, key);
headerlen = 1 + strcspn(newtext, " "); /* count the space too */
/* /*
* Copy all lines from the old file to the new one that _don't_ * Copy all lines from the old file to the new one that _don't_
* involve the same host key identifier as the one we're adding. * involve the same host key identifier as the one we're adding.
@ -621,6 +623,7 @@ void store_host_key(const char *hostname, int port,
while ( (line = fgetline(rfp)) ) { while ( (line = fgetline(rfp)) ) {
if (strncmp(line, newtext, headerlen)) if (strncmp(line, newtext, headerlen))
fputs(line, wfp); fputs(line, wfp);
sfree(line);
} }
fclose(rfp); fclose(rfp);
} }

View File

@ -171,6 +171,7 @@ struct X11Display *x11_setup_display(char *display, int authtype, Conf *conf)
sk_addr_free(disp->addr); sk_addr_free(disp->addr);
sfree(disp->hostname); sfree(disp->hostname);
sfree(disp->unixsocketpath); sfree(disp->unixsocketpath);
sfree(disp);
return NULL; /* FIXME: report an error */ return NULL; /* FIXME: report an error */
} }
} }
@ -343,7 +344,7 @@ void x11_get_auth_from_authfile(struct X11Display *disp,
int len[4]; int len[4];
int family, protocol; int family, protocol;
int ideal_match = FALSE; int ideal_match = FALSE;
char *ourhostname = get_hostname(); char *ourhostname;
/* /*
* Normally we should look for precisely the details specified in * Normally we should look for precisely the details specified in
@ -372,6 +373,8 @@ void x11_get_auth_from_authfile(struct X11Display *disp,
if (!authfp) if (!authfp)
return; return;
ourhostname = get_hostname();
/* Records in .Xauthority contain four strings of up to 64K each */ /* Records in .Xauthority contain four strings of up to 64K each */
buf = snewn(65537 * 4, char); buf = snewn(65537 * 4, char);