From: J.W. Jagersma Date: Sun, 25 Sep 2022 17:04:31 +0000 (+0200) Subject: djgpp: Use usleep() for ossl_sleep() X-Git-Tag: openssl-3.2.0-alpha1~1997 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=651255941c49a5089dfc011f2abd636433da8b82;p=thirdparty%2Fopenssl.git djgpp: Use usleep() for ossl_sleep() This part failed to compile due to a circular dependency between internal/e_os.h and internal/time.h, when ossl_sleep() falls back to a busy wait. However, djgpp has a usleep function, so it can use the regular Unix version of ossl_sleep(). It's not great though. The resolution is only ~55ms, and it may break when a user program hooks the timer interrupt without periodically updating BIOS time. A high-resolution alternative is uclock(), but that is generally less desirable since it reprograms the system timer. The circular dependency is still there and may still cause trouble for other platforms. CLA: trivial Reviewed-by: Richard Levitte Reviewed-by: Tomas Mraz (Merged from https://github.com/openssl/openssl/pull/19274) --- diff --git a/include/internal/e_os.h b/include/internal/e_os.h index 8b0c3a933c6..059fae40404 100644 --- a/include/internal/e_os.h +++ b/include/internal/e_os.h @@ -287,7 +287,7 @@ struct servent *getservbyname(const char *name, const char *proto); /* end vxworks */ /* system-specific variants defining ossl_sleep() */ -#ifdef OPENSSL_SYS_UNIX +#if defined(OPENSSL_SYS_UNIX) || defined(__DJGPP__) # include static ossl_inline void ossl_sleep(unsigned long millis) {