[EMAIL PROTECTED] wrote: > > Olivier PRENANT wrote: > > > >> It's ok to assume thread-safety, as the SCO developer (Kean Johnston) > > > >> asked the threads guys, and he said that the libc stuff is > > > >> thread-safe so they don't have to have 2 different versions in libc. > > > > > > > If any one can write a program that can prove anything (I can't), I'm > > > willing to test it here on a bi-pro (bi PIII and bi-XEON with JT > > > enabled) running uw713. > > > Maybe it will end the discussion and make a point in either way. So that > > > we (you?) can move on with the other unixware patches. > > > > You don't need a SMP machine to test threads. You just need one thread > > to do the function call, then another to do the function call and see if > > the two pointers are different. They calls don't have to happen at the > > same time. Ideally you could make call in the two threads with > > different arguments, then after both calls are completed, test that the > > two static areas have the proper _different_ values. > > > > > Ok, I don't know much about threads; would you write a simple program for > us to test?
OK, done, and attached. It is also now in CVS as src/tools/test_thread_funcs.c. In hindsight, I should have done this long ago. However, it only tests the thread-safety of functions. It does not completely test your threading capability. I would like every operating system that supports thread-safety to run this program and report back the results. -- Bruce Momjian | http://candle.pha.pa.us [EMAIL PROTECTED] | (610) 359-1001 + If your life is a hard drive, | 13 Roberts Road + Christ can be your backup. | Newtown Square, Pennsylvania 19073
/*------------------------------------------------------------------------- * * test_thread_funcs.c * libc thread test program * * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1994, Regents of the University of California * * $Header: /cvsroot/pgsql-server/src/tools/test_thread_funcs.c,v 1.2 2003/09/03 19:36:31 momjian Exp $ * * This program tests to see if your standard libc functions use * pthread_setspecific()/pthread_getspecific() to be thread-safe. * See src/port/thread.c for more details. * * This program first tests to see if each function returns a constant * memory pointer within the same thread, then, assuming it does, tests * to see if the pointers are different for different threads. If they * are, the function is thread-safe. * * This program must be compiled with the thread flags required by your * operating system. See src/template for the appropriate flags, if any. * *------------------------------------------------------------------------- */ #include <pthread.h> #include <unistd.h> #include <stdio.h> #include <stdlib.h> #include <netdb.h> #include <sys/types.h> #include <pwd.h> #include <string.h> #include <errno.h> void func_call_1(void); void func_call_2(void); struct hostent *hostent_p1; struct hostent *hostent_p2; struct passwd *passwd_p1; struct passwd *passwd_p2; char *strerror_p1; char *strerror_p2; int main(int argc, char *argv[]) { pthread_t thread1, thread2; if (argc > 1) { fprintf(stderr, "Usage: %s\n", argv[0]); return 1; } pthread_create(&thread1, NULL, (void *) func_call_1, NULL); pthread_create(&thread2, NULL, (void *) func_call_2, NULL); pthread_join(thread1, NULL); pthread_join(thread2, NULL); if (hostent_p1 == hostent_p2) printf("Your gethostbyname() is _not_ thread-safe\n"); if (passwd_p1 == passwd_p2) printf("Your getpwuid() is _not_ thread-safe\n"); if (strerror_p1 == strerror_p2) printf("Your strerror() is _not_ thread-safe\n"); if (hostent_p1 != hostent_p2 && passwd_p1 != passwd_p2 && strerror_p1 != strerror_p2) printf("Your functions are all thread-safe\n"); else printf("Your functions are _not_ all thread-safe\n"); return 0; } void func_call_1(void) { void *p; hostent_p1 = gethostbyname("yahoo.com"); p = gethostbyname("slashdot.org"); if (hostent_p1 != p) { printf("Your gethostbyname() changes the static memory area between calls\n"); hostent_p1 = NULL; /* force thread-safe failure report */ } passwd_p1 = getpwuid(0); p = getpwuid(1); if (passwd_p1 != p) { printf("Your getpwuid() changes the static memory area between calls\n"); passwd_p1 = NULL; /* force thread-safe failure report */ } strerror_p1 = strerror(EACCES); /* * If strerror() uses sys_errlist, the pointer might change for different * errno values, so we don't check to see if it varies within the thread. */ } void func_call_2(void) { void *p; hostent_p2 = gethostbyname("google.com"); p = gethostbyname("postgresql.org"); if (hostent_p2 != p) { printf("Your gethostbyname() changes the static memory area between calls\n"); hostent_p2 = NULL; /* force thread-safe failure report */ } passwd_p2 = getpwuid(2); p = getpwuid(3); if (passwd_p2 != p) { printf("Your getpwuid() changes the static memory area between calls\n"); passwd_p2 = NULL; /* force thread-safe failure report */ } strerror_p2 = strerror(EINVAL); /* * If strerror() uses sys_errlist, the pointer might change for different * errno values, so we don't check to see if it varies within the thread. */ }
---------------------------(end of broadcast)--------------------------- TIP 3: if posting/reading through Usenet, please send an appropriate subscribe-nomail command to [EMAIL PROTECTED] so that your message can get through to the mailing list cleanly