From d5f5fa86e466885168e9bb2aef0522fe8ac0b875 Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Tue, 1 Jan 2013 12:45:18 +0200 Subject: [PATCH] SAE: Set pwd-value length based on prime length The buffer is set based on maximum group prime length, but pwd-value needs to be correct length for the negotiated group. Signed-hostap: Jouni Malinen --- src/common/sae.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/common/sae.c b/src/common/sae.c index 0bd895471..ff26e9e31 100644 --- a/src/common/sae.c +++ b/src/common/sae.c @@ -129,16 +129,16 @@ static int sae_test_pwd_seed(struct sae_data *sae, const u8 *pwd_seed, /* pwd-value = KDF-z(pwd-seed, "SAE Hunting and Pecking", p) */ sha256_prf(pwd_seed, SHA256_MAC_LEN, "SAE Hunting and Pecking", - prime, sae->prime_len, pwd_value, sizeof(pwd_value)); + prime, sae->prime_len, pwd_value, sae->prime_len); wpa_hexdump_key(MSG_DEBUG, "SAE: pwd-value", - pwd_value, sizeof(pwd_value)); + pwd_value, sae->prime_len); if (os_memcmp(pwd_value, prime, sae->prime_len) >= 0) return 0; y_bit = pwd_seed[SHA256_MAC_LEN - 1] & 0x01; - x = crypto_bignum_init_set(pwd_value, sizeof(pwd_value)); + x = crypto_bignum_init_set(pwd_value, sae->prime_len); if (x == NULL) return -1; if (crypto_ec_point_solve_y_coord(sae->ec, pwe, x, y_bit) < 0) {