diff options
author | 2015-11-13 04:39:35 +0000 | |
---|---|---|
committer | 2015-11-13 04:39:35 +0000 | |
commit | 5f4d5509e5ec5fde8480095b44f867d75f9a5c1c (patch) | |
tree | 098b38e8b73876b2baf494dd413f68e02e5a5f84 | |
parent | Support "none" as an argument for sshd_config ForceCommand and (diff) | |
download | wireguard-openbsd-5f4d5509e5ec5fde8480095b44f867d75f9a5c1c.tar.xz wireguard-openbsd-5f4d5509e5ec5fde8480095b44f867d75f9a5c1c.zip |
send SSH2_MSG_UNIMPLEMENTED replies to unexpected messages during
KEX; bz#2949, ok dtucker@
-rw-r--r-- | usr.bin/ssh/kex.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/usr.bin/ssh/kex.c b/usr.bin/ssh/kex.c index 111a3e52f48..172e2cfd450 100644 --- a/usr.bin/ssh/kex.c +++ b/usr.bin/ssh/kex.c @@ -1,4 +1,4 @@ -/* $OpenBSD: kex.c,v 1.111 2015/10/13 00:21:27 djm Exp $ */ +/* $OpenBSD: kex.c,v 1.112 2015/11/13 04:39:35 djm Exp $ */ /* * Copyright (c) 2000, 2001 Markus Friedl. All rights reserved. * @@ -296,7 +296,14 @@ kex_prop_free(char **proposal) static int kex_protocol_error(int type, u_int32_t seq, void *ctxt) { - error("Hm, kex protocol error: type %d seq %u", type, seq); + struct ssh *ssh = active_state; /* XXX */ + int r; + + error("kex protocol error: type %d seq %u", type, seq); + if ((r = sshpkt_start(ssh, SSH2_MSG_UNIMPLEMENTED)) != 0 || + (r = sshpkt_put_u32(ssh, seq)) != 0 || + (r = sshpkt_send(ssh)) != 0) + return r; return 0; } |