summaryrefslogtreecommitdiff
path: root/usr.bin
diff options
context:
space:
mode:
authorDamien Miller <djm@cvs.openbsd.org>2016-02-28 22:27:01 +0000
committerDamien Miller <djm@cvs.openbsd.org>2016-02-28 22:27:01 +0000
commit8de157a9491739e5809de06ac09cc33f86aff342 (patch)
tree27b16f0498a9a055518d3948e52808219a817813 /usr.bin
parent328abac2f23cd076f5e3e177fabb2b0651f5c6db (diff)
rearrange DH public value tests to be a little more clear
rearrange DH private value generation to explain rationale more clearly and include an extra sanity check. ok deraadt
Diffstat (limited to 'usr.bin')
-rw-r--r--usr.bin/ssh/dh.c23
1 files changed, 16 insertions, 7 deletions
diff --git a/usr.bin/ssh/dh.c b/usr.bin/ssh/dh.c
index baefdba6268..e40a75776b8 100644
--- a/usr.bin/ssh/dh.c
+++ b/usr.bin/ssh/dh.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dh.c,v 1.57 2015/05/27 23:39:18 dtucker Exp $ */
+/* $OpenBSD: dh.c,v 1.58 2016/02/28 22:27:00 djm Exp $ */
/*
* Copyright (c) 2000 Niels Provos. All rights reserved.
*
@@ -243,12 +243,15 @@ dh_pub_is_valid(DH *dh, BIGNUM *dh_pub)
bits_set++;
debug2("bits set: %d/%d", bits_set, BN_num_bits(dh->p));
- /* if g==2 and bits_set==1 then computing log_g(dh_pub) is trivial */
- if (bits_set > 1)
- return 1;
-
- logit("invalid public DH value (%d/%d)", bits_set, BN_num_bits(dh->p));
- return 0;
+ /*
+ * if g==2 and bits_set==1 then computing log_g(dh_pub) is trivial
+ */
+ if (bits_set < 4) {
+ logit("invalid public DH value (%d/%d)",
+ bits_set, BN_num_bits(dh->p));
+ return 0;
+ }
+ return 1;
}
int
@@ -260,6 +263,12 @@ dh_gen_key(DH *dh, int need)
(pbits = BN_num_bits(dh->p)) <= 0 ||
need > INT_MAX / 2 || 2 * need > pbits)
return SSH_ERR_INVALID_ARGUMENT;
+ if (need < 256)
+ need = 256;
+ /*
+ * Pollard Rho, Big step/Little Step attacks are O(sqrt(n)),
+ * so double requested need here.
+ */
dh->length = MIN(need * 2, pbits - 1);
if (DH_generate_key(dh) == 0 ||
!dh_pub_is_valid(dh, dh->pub_key)) {