aboutsummaryrefslogtreecommitdiff
path: root/src/tools/thread/thread_test.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/tools/thread/thread_test.c')
-rw-r--r--src/tools/thread/thread_test.c122
1 files changed, 111 insertions, 11 deletions
diff --git a/src/tools/thread/thread_test.c b/src/tools/thread/thread_test.c
index a608029f2ca..5e643890e4e 100644
--- a/src/tools/thread/thread_test.c
+++ b/src/tools/thread/thread_test.c
@@ -6,7 +6,7 @@
* Portions Copyright (c) 1996-2005, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
- * $PostgreSQL: pgsql/src/tools/thread/thread_test.c,v 1.37 2005/03/11 15:25:31 momjian Exp $
+ * $PostgreSQL: pgsql/src/tools/thread/thread_test.c,v 1.38 2005/08/23 20:45:11 momjian Exp $
*
* This program tests to see if your standard libc functions use
* pthread_setspecific()/pthread_getspecific() to be thread-safe.
@@ -20,7 +20,7 @@
*-------------------------------------------------------------------------
*/
-#ifndef IN_CONFIGURE
+#if !defined(IN_CONFIGURE) && !defined(WIN32)
#include "postgres.h"
#else
/* From src/include/c.h" */
@@ -47,12 +47,43 @@ typedef char bool;
#include <fcntl.h>
#include <errno.h>
+
+/******************************************************************
+ * Windows Hacks
+ *****************************************************************/
+
+#ifdef WIN32
+#define MAXHOSTNAMELEN 63
+#include <winsock2.h>
+
+int mkstemp(char *template);
+
+int
+mkstemp(char *template)
+{
+ FILE *foo;
+
+ mktemp(template);
+ foo = fopen(template, "rw");
+ if (!foo)
+ return -1;
+ else
+ return (int)foo;
+}
+
+#endif
+
+/******************************************************************
+ * End Windows Hacks
+ *****************************************************************/
+
+
/* Test for POSIX.1c 2-arg sigwait() and fail on single-arg version */
#include <signal.h>
int sigwait(const sigset_t *set, int *sig);
-#if !defined(ENABLE_THREAD_SAFETY) && !defined(IN_CONFIGURE)
+#if !defined(ENABLE_THREAD_SAFETY) && !defined(IN_CONFIGURE) && !(defined(WIN32))
int
main(int argc, char *argv[])
{
@@ -69,8 +100,13 @@ main(int argc, char *argv[])
static void func_call_1(void);
static void func_call_2(void);
+#ifdef WIN32
+#define TEMP_FILENAME_1 "thread_test.1.XXXXXX"
+#define TEMP_FILENAME_2 "thread_test.2.XXXXXX"
+#else
#define TEMP_FILENAME_1 "/tmp/thread_test.1.XXXXXX"
#define TEMP_FILENAME_2 "/tmp/thread_test.2.XXXXXX"
+#endif
static char *temp_filename_1;
static char *temp_filename_2;
@@ -89,11 +125,13 @@ static char *strerror_p2;
static bool strerror_threadsafe = false;
#endif
+#ifndef WIN32
#ifndef HAVE_GETPWUID_R
static struct passwd *passwd_p1;
static struct passwd *passwd_p2;
static bool getpwuid_threadsafe = false;
#endif
+#endif
#if !defined(HAVE_GETADDRINFO) && !defined(HAVE_GETHOSTBYNAME_R)
static struct hostent *hostent_p1;
@@ -108,8 +146,12 @@ int
main(int argc, char *argv[])
{
pthread_t thread1,
- thread2;
- int fd;
+ thread2;
+ int fd;
+#ifdef WIN32
+ WSADATA wsaData;
+ int err;
+#endif
if (argc > 1)
{
@@ -123,6 +165,14 @@ main(int argc, char *argv[])
dup(5);
#endif
+#ifdef WIN32
+ err = WSAStartup(MAKEWORD(1, 1), &wsaData);
+ if (err != 0) {
+ fprintf(stderr, "Cannot start the network subsystem - %d**\nexiting\n", err);
+ exit(1);
+ }
+#endif
+
/* Make temp filenames, might not have strdup() */
temp_filename_1 = malloc(strlen(TEMP_FILENAME_1) + 1);
strcpy(temp_filename_1, TEMP_FILENAME_1);
@@ -151,18 +201,23 @@ main(int argc, char *argv[])
while (thread1_done == 0 || thread2_done == 0)
sched_yield(); /* if this is a portability problem,
* remove it */
-
+#ifdef WIN32
+ printf("Your GetLastError() is thread-safe.\n");
+#else
printf("Your errno is thread-safe.\n");
+#endif
#ifndef HAVE_STRERROR_R
if (strerror_p1 != strerror_p2)
strerror_threadsafe = true;
#endif
+#ifndef WIN32
#ifndef HAVE_GETPWUID_R
if (passwd_p1 != passwd_p2)
getpwuid_threadsafe = true;
#endif
+#endif
#if !defined(HAVE_GETADDRINFO) && !defined(HAVE_GETHOSTBYNAME_R)
if (hostent_p1 != hostent_p2)
@@ -187,6 +242,7 @@ main(int argc, char *argv[])
}
#endif
+#ifndef WIN32
#ifdef HAVE_GETPWUID_R
printf("Your system has getpwuid_r(); it does not need getpwuid().\n");
#else
@@ -199,6 +255,9 @@ main(int argc, char *argv[])
platform_is_threadsafe = false;
}
#endif
+#else
+ printf("getpwuid_r()/getpwuid() are not applicable to Win32 platforms.\n");
+#endif
#ifdef HAVE_GETADDRINFO
printf("Your system has getaddrinfo(); it does not need gethostbyname()\n"
@@ -238,14 +297,30 @@ func_call_1(void)
!defined(HAVE_GETHOSTBYNAME_R))
void *p;
#endif
-
+#ifdef WIN32
+ HANDLE h1;
+ HANDLE h2;
+#endif
unlink(temp_filename_1);
+
+
/* create, then try to fail on exclusive create open */
+#ifdef WIN32
+ h1 = CreateFile(temp_filename_1, GENERIC_WRITE, 0, NULL, OPEN_ALWAYS, 0, NULL);
+ h2 = CreateFile(temp_filename_1, GENERIC_WRITE, 0, NULL, CREATE_NEW, 0, NULL);
+ if (h1 == INVALID_HANDLE_VALUE || GetLastError() != ERROR_FILE_EXISTS)
+#else
if (open(temp_filename_1, O_RDWR | O_CREAT, 0600) < 0 ||
open(temp_filename_1, O_RDWR | O_CREAT | O_EXCL, 0600) >= 0)
+#endif
{
+#ifdef WIN32
+ fprintf(stderr, "Could not create file in current directory or\n");
+ fprintf(stderr, "Could not generate failure for create file in current directory **\nexiting\n");
+#else
fprintf(stderr, "Could not create file in /tmp or\n");
fprintf(stderr, "Could not generate failure for create file in /tmp **\nexiting\n");
+#endif
exit(1);
}
@@ -256,9 +331,17 @@ func_call_1(void)
errno1_set = 1;
while (errno2_set == 0)
sched_yield();
- if (errno != EEXIST)
+#ifdef WIN32
+ if (GetLastError() != ERROR_FILE_EXISTS)
+#else
+ if (errno != EEXIST)
+#endif
{
- fprintf(stderr, "errno not thread-safe **\nexiting\n");
+#ifdef WIN32
+ fprintf(stderr, "GetLastError() not thread-safe **\nexiting\n");
+#else
+ fprintf(stderr, "errno not thread-safe **\nexiting\n");
+#endif
unlink(temp_filename_1);
exit(1);
}
@@ -274,6 +357,7 @@ func_call_1(void)
*/
#endif
+#ifndef WIN32
#ifndef HAVE_GETPWUID_R
passwd_p1 = getpwuid(0);
p = getpwuid(1);
@@ -283,6 +367,7 @@ func_call_1(void)
passwd_p1 = NULL; /* force thread-safe failure report */
}
#endif
+#endif
#if !defined(HAVE_GETADDRINFO) && !defined(HAVE_GETHOSTBYNAME_R)
/* threads do this in opposite order */
@@ -312,7 +397,12 @@ func_call_2(void)
unlink(temp_filename_2);
/* open non-existant file */
+#ifdef WIN32
+ CreateFile(temp_filename_2, GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, NULL);
+ if (GetLastError() != ERROR_FILE_NOT_FOUND)
+#else
if (open(temp_filename_2, O_RDONLY, 0600) >= 0)
+#endif
{
fprintf(stderr, "Read-only open succeeded without create **\nexiting\n");
exit(1);
@@ -325,9 +415,17 @@ func_call_2(void)
errno2_set = 1;
while (errno1_set == 0)
sched_yield();
- if (errno != ENOENT)
+#ifdef WIN32
+ if (GetLastError() != ENOENT)
+#else
+ if (errno != ENOENT)
+#endif
{
- fprintf(stderr, "errno not thread-safe **\nexiting\n");
+#ifdef WIN32
+ fprintf(stderr, "GetLastError() not thread-safe **\nexiting\n");
+#else
+ fprintf(stderr, "errno not thread-safe **\nexiting\n");
+#endif
unlink(temp_filename_2);
exit(1);
}
@@ -343,6 +441,7 @@ func_call_2(void)
*/
#endif
+#ifndef WIN32
#ifndef HAVE_GETPWUID_R
passwd_p2 = getpwuid(2);
p = getpwuid(3);
@@ -352,6 +451,7 @@ func_call_2(void)
passwd_p2 = NULL; /* force thread-safe failure report */
}
#endif
+#endif
#if !defined(HAVE_GETADDRINFO) && !defined(HAVE_GETHOSTBYNAME_R)
/* threads do this in opposite order */