diff options
author | Ted Unangst <tedu@cvs.openbsd.org> | 2015-01-05 13:10:11 +0000 |
---|---|---|
committer | Ted Unangst <tedu@cvs.openbsd.org> | 2015-01-05 13:10:11 +0000 |
commit | 8431a624d4d6c709c4e6b5452e8c085dfc622da9 (patch) | |
tree | e14b15390b34f700f13cef86c3fa1906a4861b13 /lib/libc/crypt | |
parent | 90d9bc25269b36377be7454c13f99bdb6bb60fa0 (diff) |
convert clock() to clock_gettime() for improved precision (and accuracy?)
guenther suggested using thread time, which actually may improve accuracy
if somebody puts this in a threaded program.
Diffstat (limited to 'lib/libc/crypt')
-rw-r--r-- | lib/libc/crypt/bcrypt.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/lib/libc/crypt/bcrypt.c b/lib/libc/crypt/bcrypt.c index abcbe138ca3..1114eae44ef 100644 --- a/lib/libc/crypt/bcrypt.c +++ b/lib/libc/crypt/bcrypt.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bcrypt.c,v 1.47 2014/12/30 10:27:24 tedu Exp $ */ +/* $OpenBSD: bcrypt.c,v 1.48 2015/01/05 13:10:10 tedu Exp $ */ /* * Copyright (c) 2014 Ted Unangst <tedu@openbsd.org> @@ -231,24 +231,26 @@ bcrypt_checkpass(const char *pass, const char *goodhash) int bcrypt_autorounds(void) { - clock_t before, after; + struct timespec before, after; int r = 8; char buf[_PASSWORD_LEN]; int duration; - before = clock(); + clock_gettime(CLOCK_THREAD_CPUTIME_ID, &before); bcrypt_newhash("testpassword", r, buf, sizeof(buf)); - after = clock(); + clock_gettime(CLOCK_THREAD_CPUTIME_ID, &after); - duration = after - before; + duration = after.tv_sec - before.tv_sec; + duration *= 1000000; + duration += (after.tv_nsec - before.tv_nsec) / 1000; /* too quick? slow it down. */ - while (r < 16 && duration <= CLOCKS_PER_SEC / 4) { + while (r < 16 && duration <= 1000000 / 4) { r += 1; duration *= 2; } /* too slow? speed it up. */ - while (r > 4 && duration > CLOCKS_PER_SEC / 2) { + while (r > 4 && duration > 1000000 / 2) { r -= 1; duration /= 2; } |