From: miod Date: Mon, 27 Jun 2022 20:22:26 +0000 (+0000) Subject: Revert 1.44; that slow getsecs() workaround had been added for the sake of X-Git-Url: http://artulab.com/gitweb/?a=commitdiff_plain;h=b83d90f0d5e8a270c46d6c99c6609668bd21a378;p=openbsd Revert 1.44; that slow getsecs() workaround had been added for the sake of an i386 system noone remembers details about and which is unlikely to be relevant those days, and has been found to misbehave on some modern systems, such as the OnLogic Helix 500, or RPi4 with glass console. --- diff --git a/sys/stand/boot/cmd.c b/sys/stand/boot/cmd.c index b11f454a6bb..c11c7e9f204 100644 --- a/sys/stand/boot/cmd.c +++ b/sys/stand/boot/cmd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd.c,v 1.68 2021/10/24 17:49:19 deraadt Exp $ */ +/* $OpenBSD: cmd.c,v 1.69 2022/06/27 20:22:26 miod Exp $ */ /* * Copyright (c) 1997-1999 Michael Shalayeff @@ -248,17 +248,13 @@ readline(char *buf, size_t n, int to) /* Only do timeout if greater than 0 */ if (to > 0) { - u_long i = 0; time_t tt = getsecs() + to; #ifdef DEBUG if (debug > 2) printf ("readline: timeout(%d) at %u\n", to, tt); #endif - /* check for timeout expiration less often - (for some very constrained archs) */ - while (!cnischar()) - if (!(i++ % 1000) && (getsecs() >= tt)) - break; + while (!cnischar() && getsecs() < tt) + continue; if (!cnischar()) { strlcpy(buf, "boot", 5);