diff options
author | Markus Friedl <markus@cvs.openbsd.org> | 1999-11-11 10:05:35 +0000 |
---|---|---|
committer | Markus Friedl <markus@cvs.openbsd.org> | 1999-11-11 10:05:35 +0000 |
commit | 55bc80293b862fae893b2be64b63c46f097a721d (patch) | |
tree | cafba3488d183d02e0bd2833ee8b11538bfe2fed /usr.bin | |
parent | d3f9228790c2aa88f1d2149cac647da303186f02 (diff) |
fix fatal/assert() bug reported by damien@ibs.com.au:
allow session_key_int != sizeof(session_key)
[this should fix the pre-assert-removal-core-files]
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/ssh/sshd.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/usr.bin/ssh/sshd.c b/usr.bin/ssh/sshd.c index 03d078982f5..b9b91c0f307 100644 --- a/usr.bin/ssh/sshd.c +++ b/usr.bin/ssh/sshd.c @@ -18,7 +18,7 @@ agent connections. */ #include "includes.h" -RCSID("$Id: sshd.c,v 1.47 1999/11/10 23:36:45 markus Exp $"); +RCSID("$Id: sshd.c,v 1.48 1999/11/11 10:05:34 markus Exp $"); #include "xmalloc.h" #include "rsa.h" @@ -719,7 +719,7 @@ main(int ac, char **av) void do_connection(int privileged_port) { - int i; + int i, len; BIGNUM *session_key_int; unsigned char session_key[SSH_SESSION_KEY_LENGTH]; unsigned char check_bytes[8]; @@ -862,11 +862,12 @@ void do_connection(int privileged_port) least significant 256 bits of the integer; the first byte of the key is in the highest bits. */ BN_mask_bits(session_key_int, sizeof(session_key) * 8); - if (BN_num_bytes(session_key_int) != sizeof(session_key)){ - fatal("do_connection: session_key_int %d != sizeof(session_key) %d", - BN_num_bytes(session_key_int), sizeof(session_key)); - } - BN_bn2bin(session_key_int, session_key); + len = BN_num_bytes(session_key_int); + if (len <= 0 || len > sizeof(session_key)) + fatal("do_connection: bad len: session_key_int %d > sizeof(session_key) %d", + len, sizeof(session_key)); + memset(session_key, 0, sizeof(session_key)); + BN_bn2bin(session_key_int, session_key + sizeof(session_key) - len); /* Xor the first 16 bytes of the session key with the session id. */ for (i = 0; i < 16; i++) |