diff options
author | joe <joe@FreeBSD.org> | 2003-09-26 19:15:53 +0000 |
---|---|---|
committer | joe <joe@FreeBSD.org> | 2003-09-26 19:15:53 +0000 |
commit | dc42ef026434942c55e8af3dd0e975d36afc6843 (patch) | |
tree | f8739ebe09332a7122569bd3e41f1574f5aaa117 /crypto/openssh/channels.c | |
parent | 0689a1c0d3a7bf6f827a1f7ee07bdb8d1e3c1fb1 (diff) | |
download | FreeBSD-src-dc42ef026434942c55e8af3dd0e975d36afc6843.zip FreeBSD-src-dc42ef026434942c55e8af3dd0e975d36afc6843.tar.gz |
Additional corrections to OpenSSH buffer handling.
Obtained from: openssh.org
Originally committed to head by: nectar
Diffstat (limited to 'crypto/openssh/channels.c')
-rw-r--r-- | crypto/openssh/channels.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/crypto/openssh/channels.c b/crypto/openssh/channels.c index 1937b02..218744d 100644 --- a/crypto/openssh/channels.c +++ b/crypto/openssh/channels.c @@ -229,12 +229,13 @@ channel_new(char *ctype, int type, int rfd, int wfd, int efd, if (found == -1) { /* There are no free slots. Take last+1 slot and expand the array. */ found = channels_alloc; - channels_alloc += 10; if (channels_alloc > 10000) fatal("channel_new: internal error: channels_alloc %d " "too big.", channels_alloc); + channels = xrealloc(channels, + (channels_alloc + 10) * sizeof(Channel *)); + channels_alloc += 10; debug2("channel: expanding %d", channels_alloc); - channels = xrealloc(channels, channels_alloc * sizeof(Channel *)); for (i = found; i < channels_alloc; i++) channels[i] = NULL; } |