Implement dTHR via __declspec(thread) - part 2
Nick Ing-Simmons [Sat, 15 Nov 1997 20:42:28 +0000 (20:42 +0000)]
p4raw-id: //depot/ansiperl@258

win32/makedef.pl
win32/win32thread.c
win32/win32thread.h

index 3ec9b82..03a4239 100644 (file)
@@ -402,6 +402,6 @@ win32_open_osfhandle
 win32_get_osfhandle
 Perl_win32_init
 Perl_init_os_extras
-Perl_setTHR
 Perl_getTHR
+Perl_setTHR
 RunPerl
index eefa92c..c0c3c60 100644 (file)
@@ -1,18 +1,18 @@
 #include "EXTERN.h"
 #include "perl.h"
 
-__declspec(thread) struct thread *current_thread;
+__declspec(thread) struct thread *Perl_current_thread = NULL;
 
 void
 Perl_setTHR(struct thread *t)
 {
- current_thread = t;
+ Perl_current_thread = t;
 }
 
 struct thread *
 Perl_getTHR(void)
 {
- return current_thread;
+ return Perl_current_thread;
 }
 
 void
index 6af548d..1807f3b 100644 (file)
@@ -98,7 +98,6 @@ typedef HANDLE perl_mutex;
     } STMT_END
 
 
-#define THR                    Perl_getTHR()
 #define THREAD_CREATE(t, f)    Perl_thread_create(t, f)
 #define THREAD_POST_CREATE(t)  NOOP
 #define THREAD_RET_TYPE                DWORD WINAPI
@@ -106,16 +105,28 @@ typedef HANDLE perl_mutex;
 
 typedef THREAD_RET_TYPE thread_func_t(void *);
 
+
 START_EXTERN_C
+
+#ifdef PERLDLL
+extern __declspec(thread) struct thread *Perl_current_thread;
+#define SET_THR(t)             (Perl_current_thread = t)
+#define THR                    Perl_current_thread
+#else
+#define THR                    Perl_getTHR()
+#define SET_THR(t)             Perl_setTHR(t)
+#endif
+
 void Perl_alloc_thread_key _((void));
 int Perl_thread_create _((struct thread *thr, thread_func_t *fn));
 void Perl_set_thread_self _((struct thread *thr));
 struct thread *Perl_getTHR _((void));
 void Perl_setTHR _((struct thread *t));
+
 END_EXTERN_C
 
 #define INIT_THREADS NOOP
-#define ALLOC_THREAD_KEY Perl_alloc_thread_key()
+#define ALLOC_THREAD_KEY NOOP
 #define SET_THREAD_SELF(thr) Perl_set_thread_self(thr)
 
 #define JOIN(t, avp)                                                   \
@@ -125,7 +136,7 @@ END_EXTERN_C
            croak("panic: JOIN");                                       \
     } STMT_END
 
-#define SET_THR(t)             Perl_setTHR(t)
 #define YIELD                  Sleep(0)
 
 #endif /* _WIN32THREAD_H */
+