summaryrefslogtreecommitdiff
path: root/kex.c
diff options
context:
space:
mode:
authordjm@openbsd.org <djm@openbsd.org>2015-11-13 04:39:35 +0000
committerDamien Miller <djm@mindrot.org>2015-11-16 11:31:38 +1100
commitd87063d9baf5479b6e813d47dfb694a97df6f6f5 (patch)
treeb79091decb70207be9bb0dd27e8b37943e75c1d4 /kex.c
parent9fd04681a1e9b0af21e08ff82eb674cf0a499bfc (diff)
downloadopenssh-git-d87063d9baf5479b6e813d47dfb694a97df6f6f5.tar.gz
upstream commit
send SSH2_MSG_UNIMPLEMENTED replies to unexpected messages during KEX; bz#2949, ok dtucker@ Upstream-ID: 2b3abdff344d53c8d505f45c83a7b12e84935786
Diffstat (limited to 'kex.c')
-rw-r--r--kex.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/kex.c b/kex.c
index d8793b91..b409f276 100644
--- a/kex.c
+++ b/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.
*
@@ -315,7 +315,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;
}