summaryrefslogtreecommitdiff
path: root/lib/libc
diff options
context:
space:
mode:
authorTed Unangst <tedu@cvs.openbsd.org>2015-01-05 13:10:11 +0000
committerTed Unangst <tedu@cvs.openbsd.org>2015-01-05 13:10:11 +0000
commit8431a624d4d6c709c4e6b5452e8c085dfc622da9 (patch)
treee14b15390b34f700f13cef86c3fa1906a4861b13 /lib/libc
parent90d9bc25269b36377be7454c13f99bdb6bb60fa0 (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')
-rw-r--r--lib/libc/crypt/bcrypt.c16
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;
}