summaryrefslogtreecommitdiff
path: root/win32/win32thread.h
diff options
context:
space:
mode:
authorNick Ing-Simmons <nik@tiuk.ti.com>1997-11-29 01:35:45 +0000
committerNick Ing-Simmons <nik@tiuk.ti.com>1997-11-29 01:35:45 +0000
commitc69f112c145fabe210a7e2c5c2406baeea71af2f (patch)
treef99acaeffc5cdd4e8b5cd9931d8e74da85deb578 /win32/win32thread.h
parent900941544544b9ca5ecbb5e1f24f9c23b3635b68 (diff)
downloadperl-c69f112c145fabe210a7e2c5c2406baeea71af2f.tar.gz
GCC + Threads on Win32 - best gcc results yet
p4raw-id: //depot/ansiperl@331
Diffstat (limited to 'win32/win32thread.h')
-rw-r--r--win32/win32thread.h5
1 files changed, 3 insertions, 2 deletions
diff --git a/win32/win32thread.h b/win32/win32thread.h
index 591184b007..6f355f09eb 100644
--- a/win32/win32thread.h
+++ b/win32/win32thread.h
@@ -108,7 +108,7 @@ typedef THREAD_RET_TYPE thread_func_t(void *);
START_EXTERN_C
-#if defined(PERLDLL) && (!defined(__BORLANDC__) || defined(_DLL))
+#if defined(PERLDLL) && defined(USE_DECLSPEC_THREAD) && (!defined(__BORLANDC__) || defined(_DLL))
extern __declspec(thread) struct perl_thread *Perl_current_thread;
#define SET_THR(t) (Perl_current_thread = t)
#define THR Perl_current_thread
@@ -116,6 +116,7 @@ extern __declspec(thread) struct perl_thread *Perl_current_thread;
#define THR Perl_getTHR()
#define SET_THR(t) Perl_setTHR(t)
#endif
+struct perl_thread;
void Perl_alloc_thread_key _((void));
int Perl_thread_create _((struct perl_thread *thr, thread_func_t *fn));
@@ -126,7 +127,7 @@ void Perl_setTHR _((struct perl_thread *t));
END_EXTERN_C
#define INIT_THREADS NOOP
-#define ALLOC_THREAD_KEY NOOP
+#define ALLOC_THREAD_KEY Perl_alloc_thread_key()
#define SET_THREAD_SELF(thr) Perl_set_thread_self(thr)
#define JOIN(t, avp) \