]> granicus.if.org Git - openssl/commitdiff
apps/speed.c: Cygwin alarm() fails sometimes.
authorAndy Polyakov <appro@openssl.org>
Thu, 15 Dec 2011 22:30:03 +0000 (22:30 +0000)
committerAndy Polyakov <appro@openssl.org>
Thu, 15 Dec 2011 22:30:03 +0000 (22:30 +0000)
PR: 2655

apps/speed.c

index d4b0fddf7b8113b209aa48800f8ddecfa3bb6bda..2c489eb029a194a37487e60718321f5beb83e022 100644 (file)
 #include <signal.h>
 #endif
 
-#ifdef _WIN32
+#if defined(_WIN32) || defined(__CYGWIN__)
 #include <windows.h>
+# if defined(__CYGwIN__) && !defined(_WIN32)
+  /* <windows.h> should define _WIN32, which normally is mutually
+   * exclusive with __CYGWIN__, but if it didn't... */
+#  define _WIN32
+  /* this is done because Cygwin alarm() fails sometimes. */
+# endif
 #endif
 
 #include <openssl/bn.h>
@@ -274,9 +280,12 @@ static SIGRETTYPE sig_done(int sig)
 
 #if defined(_WIN32)
 
-#define SIGALRM
+#if !defined(SIGALRM)
+# define SIGALRM
+#endif
 static unsigned int lapse,schlock;
-static void alarm(unsigned int secs) { lapse = secs*1000; }
+static void alarm_win32(unsigned int secs) { lapse = secs*1000; }
+#define alarm alarm_win32
 
 static DWORD WINAPI sleepy(VOID *arg)
        {