From 6c77cf8da397a4610a46e16f60d9c28996d8e34b Mon Sep 17 00:00:00 2001 From: "Andrey A. Chernov" Date: Sat, 16 Aug 2008 15:41:03 +0000 Subject: [PATCH] Use arc4random_uniform() to avoid "modulo bias" Remove pw_getrand() unneded now: arc4random_uniform() is stronger then pw_getrand()'s MD5 tricks (inactive) and its active version, mixing arc4random() bytes in one, not make things better at all. --- pw/pw_user.c | 57 ++-------------------------------------------------- 1 file changed, 2 insertions(+), 55 deletions(-) diff --git a/pw/pw_user.c b/pw/pw_user.c index 7da16f8..4c62fe8 100644 --- a/pw/pw_user.c +++ b/pw/pw_user.c @@ -43,9 +43,6 @@ static const char rcsid[] = #include #include #include -#if defined(USE_MD5RAND) -#include -#endif #include "pw.h" #include "bitmap.h" @@ -1045,74 +1042,24 @@ pw_pwcrypt(char *password) * Calculate a salt value */ for (i = 0; i < SALTSIZE; i++) - salt[i] = chars[arc4random() % (sizeof(chars) - 1)]; + salt[i] = chars[arc4random_uniform(sizeof(chars) - 1)]; salt[SALTSIZE] = '\0'; return strcpy(buf, crypt(password, salt)); } -#if defined(USE_MD5RAND) -u_char * -pw_getrand(u_char *buf, int len) /* cryptographically secure rng */ -{ - int i; - for (i=0;i> 24) ^ (val >> 16) ^ (val >> 8) ^ val); - } - return buf; -} - -#endif static char * pw_password(struct userconf * cnf, struct cargs * args, char const * user) { int i, l; char pwbuf[32]; - u_char rndbuf[sizeof pwbuf]; switch (cnf->default_password) { case -1: /* Random password */ l = (arc4random() % 8 + 8); /* 8 - 16 chars */ - pw_getrand(rndbuf, l); for (i = 0; i < l; i++) - pwbuf[i] = chars[rndbuf[i] % (sizeof(chars)-1)]; + pwbuf[i] = chars[arc4random_uniform(sizeof(chars)-1)]; pwbuf[i] = '\0'; /* -- 2.47.1