diff options
author | Thomas Grill <xovo@users.sourceforge.net> | 2003-11-13 03:33:09 +0000 |
---|---|---|
committer | Thomas Grill <xovo@users.sourceforge.net> | 2003-11-13 03:33:09 +0000 |
commit | 1547eec9428f5ced3c2d5ac1d2420d86254f2048 (patch) | |
tree | c1b02eb66fb439ff36828db2892eb87df6b70ec3 /externals/grill/flext/source | |
parent | fd67d00fc3899625305d74826d3c4244b10bfcc7 (diff) |
""
svn path=/trunk/; revision=1182
Diffstat (limited to 'externals/grill/flext/source')
-rw-r--r-- | externals/grill/flext/source/flext.h | 2 | ||||
-rwxr-xr-x | externals/grill/flext/source/flprefix.h | 5 | ||||
-rw-r--r-- | externals/grill/flext/source/flsupport.h | 60 | ||||
-rw-r--r-- | externals/grill/flext/source/flthr.cpp | 90 |
4 files changed, 143 insertions, 14 deletions
diff --git a/externals/grill/flext/source/flext.h b/externals/grill/flext/source/flext.h index 9fd63487..c18fd29c 100644 --- a/externals/grill/flext/source/flext.h +++ b/externals/grill/flext/source/flext.h @@ -44,7 +44,9 @@ WARRANTIES, see the file, "license.txt," in this distribution. #elif FLEXT_THREADS == FLEXT_THR_MP #include <multiprocessing.h> #elif FLEXT_THREADS == FLEXT_THR_WIN32 + #define _WIN32_WINNT 0x500 // must be WIN2000 at least! #include <windows.h> + #include <process.h> #else #error "Thread model not supported" #endif diff --git a/externals/grill/flext/source/flprefix.h b/externals/grill/flext/source/flprefix.h index 93bfbe4d..693d8630 100755 --- a/externals/grill/flext/source/flprefix.h +++ b/externals/grill/flext/source/flprefix.h @@ -335,8 +335,11 @@ WARRANTIES, see the file, "license.txt," in this distribution. #ifdef FLEXT_THREADS #undef FLEXT_THREADS #if FLEXT_OS == FLEXT_OS_MAC && FLEXT_SYS == FLEXT_SYS_MAX - // Max crashes with posix threads (but don't know why...) + // Max crashes with posix threads (because it's in the CFM model) #define FLEXT_THREADS FLEXT_THR_MP + #elif FLEXT_SYS == FLEXT_SYS_MAX && FLEXT_OS == FLEXT_OS_WIN + // for wmax use native Windows threads + #define FLEXT_THREADS FLEXT_THR_WIN32 #else #define FLEXT_THREADS FLEXT_THR_POSIX #endif diff --git a/externals/grill/flext/source/flsupport.h b/externals/grill/flext/source/flsupport.h index 5e63ded0..e8328ea3 100644 --- a/externals/grill/flext/source/flsupport.h +++ b/externals/grill/flext/source/flsupport.h @@ -636,6 +636,8 @@ public: typedef MPTaskID thrid_t; #elif FLEXT_THREADS == FLEXT_THR_POSIX typedef pthread_t thrid_t; +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + typedef DWORD thrid_t; #else #error #endif @@ -647,6 +649,8 @@ public: return pthread_self(); #elif FLEXT_THREADS == FLEXT_THR_MP return MPCurrentTaskID(); +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + return GetCurrentThreadId(); #else #error #endif @@ -660,6 +664,8 @@ public: static bool IsThread(thrid_t t,thrid_t ref = GetThreadId()) { #if FLEXT_THREADS == FLEXT_THR_POSIX return pthread_equal(ref,t) != 0; +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + return ref == t; #else return ref == t; #endif @@ -727,6 +733,7 @@ protected: static bool StartHelper(); static bool StopHelper(); static void ThrHelper(void *); + static void LaunchHelper(thr_entry *e); //! the system's thread id static thrid_t thrid; // the system thread @@ -742,6 +749,8 @@ public: sched_yield(); #elif FLEXT_THREADS == FLEXT_THR_MP MPYield(); +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + SwitchToThread(); #else #error #endif @@ -800,6 +809,28 @@ public: pthread_mutex_t mutex; // int cnt; }; +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + { + public: + //! Construct thread mutex + ThrMutex() { ::InitializeCriticalSection(&mutex); } + //! Destroy thread mutex + ~ThrMutex() { ::DeleteCriticalSection(&mutex); } + + //! Lock thread mutex + bool Lock() { ::EnterCriticalSection(&mutex); return true; } + /*! Wait to lock thread mutex. + \todo Implement! + */ +// bool WaitForLock(double tm) { return pthread_mutex_lock(&mutex) == 0; } + //! Try to lock, but don't wait + bool TryLock() { return ::TryEnterCriticalSection(&mutex) != 0; } + //! Unlock thread mutex + bool Unlock() { ::LeaveCriticalSection(&mutex); return true; } + + protected: + CRITICAL_SECTION mutex; + }; #elif FLEXT_THREADS == FLEXT_THR_MP { public: @@ -842,18 +873,43 @@ public: /*! Wait for condition (for a certain time). \param ftime Wait time in seconds - \ret 0 = signalled, 1 = timed out + \ret true = signalled, false = timed out \remark If ftime = 0 this may suck away your cpu if used in a signalled loop. \remark The time resolution of the implementation is required to be at least ms. */ bool TimedWait(double ftime); //! Signal condition - bool Signal(); + bool Signal() { return pthread_cond_signal(&cond) == 0; } protected: pthread_cond_t cond; }; +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + { + public: + //! Construct thread conditional + ThrCond() { cond = CreateEvent(NULL,FALSE,FALSE,NULL); } + //! Destroy thread conditional + ~ThrCond() { CloseHandle(cond); } + + //! Wait for condition + bool Wait() { return WaitForSingleObject(cond,INFINITE) == WAIT_OBJECT_0; } + + /*! Wait for condition (for a certain time). + \param ftime Wait time in seconds + \ret true = signalled, false = timed out + \remark If ftime = 0 this may suck away your cpu if used in a signalled loop. + \remark The time resolution of the implementation is required to be at least ms. + */ + bool TimedWait(double ftime) { return WaitForSingleObject(cond,(LONG)(ftime*1000)) == WAIT_OBJECT_0; } + + //! Signal condition + bool Signal() { return SetEvent(cond) != 0; } + + protected: + HANDLE cond; + }; #elif FLEXT_THREADS == FLEXT_THR_MP { public: diff --git a/externals/grill/flext/source/flthr.cpp b/externals/grill/flext/source/flthr.cpp index 0ca03f38..65fd4c3b 100644 --- a/externals/grill/flext/source/flthr.cpp +++ b/externals/grill/flext/source/flthr.cpp @@ -48,6 +48,12 @@ static flext::ThrCond *thrhelpcond = NULL; flext::thrid_t flext::GetSysThreadId() { return thrid; } +void flext::LaunchHelper(thr_entry *e) +{ + e->thrid = GetThreadId(); + e->meth(e->params); +} + //! Start helper thread bool flext::StartHelper() { @@ -75,6 +81,8 @@ bool flext::StartHelper() OSStatus ret = MPCreateTask((TaskProc)ThrHelper,NULL,0,0,0,0,0,&thrhelpid); ok = ret == noErr; } +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + ok = _beginthread(ThrHelper,0,NULL) >= 0; #else #error #endif @@ -100,10 +108,11 @@ bool flext::StopHelper() } #endif - //! Static helper thread function void flext::ThrHelper(void *) { + thrhelpid = GetThreadId(); + #if FLEXT_THREADS == FLEXT_THR_POSIX // set prototype thread attributes pthread_attr_t attr; @@ -139,9 +148,13 @@ void flext::ThrHelper(void *) // post("Helper start thread"); #if FLEXT_THREADS == FLEXT_THR_POSIX - ok = pthread_create (&ti->thrid,&attr,(void *(*)(void *))ti->meth,ti->params) == 0; + thrid_t dummy; + ok = pthread_create (&dummy,&attr,(void *(*)(void *))LaunchHelper,ti) == 0; #elif FLEXT_THREADS == FLEXT_THR_MP - ok = MPCreateTask((TaskProc)ti->meth,ti->params,0,0,0,0,0,&ti->thrid) == noErr; + thrid_t dummy; + ok = MPCreateTask((TaskProc)LaunchHelper,ti,0,0,0,0,0,&dummy) == noErr; +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + ok = _beginthread((void (*)(void *))LaunchHelper,0,ti) >= 0; #else #error #endif @@ -342,6 +355,10 @@ bool flext_base::StopThreads() #elif FLEXT_THREADS == FLEXT_THR_MP MPTerminateTask(t->thrid,0); // here, we should use a task queue to check whether the task has really terminated!! + #elif FLEXT_THREADS == FLEXT_THR_WIN32 + // can't use the c library function _endthread.. memory leaks will occur + HANDLE hnd = OpenThread(THREAD_ALL_ACCESS,TRUE,t->thrid); + TerminateThread(hnd,0); #else #error #endif @@ -399,6 +416,41 @@ bool flext::RelPriority(int dp,thrid_t ref,thrid_t id) } } return true; + +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + HANDLE href = OpenThread(THREAD_ALL_ACCESS,TRUE,ref); + HANDLE hid = OpenThread(THREAD_ALL_ACCESS,TRUE,id); + int pr = GetThreadPriority(href); + + if(pr == THREAD_PRIORITY_ERROR_RETURN) { +#ifdef FLEXT_DEBUG + post("flext - failed to get thread priority"); +#endif + return false; + } + + pr += dp; + if(pr < THREAD_PRIORITY_IDLE) { +#ifdef FLEXT_DEBUG + post("flext - minimum thread priority reached"); +#endif + pr = THREAD_PRIORITY_IDLE; + } + else if(pr > THREAD_PRIORITY_TIME_CRITICAL) { +#ifdef FLEXT_DEBUG + post("flext - maximum thread priority reached"); +#endif + pr = THREAD_PRIORITY_TIME_CRITICAL; + } + + if(SetThreadPriority(hid,pr) == 0) { +#ifdef FLEXT_DEBUG + post("flext - failed to change thread priority"); +#endif + return false; + } + return true; + #elif FLEXT_THREADS == FLEXT_THR_MP thr_entry *t; for(t = thrhead; t && t->Id() != id; t = t->nxt) {} @@ -441,6 +493,19 @@ int flext::GetPriority(thrid_t id) return -1; } return parm.sched_priority; + +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + HANDLE hid = OpenThread(THREAD_ALL_ACCESS,TRUE,id); + int pr = GetThreadPriority(hid); + + if(pr == THREAD_PRIORITY_ERROR_RETURN) { +#ifdef FLEXT_DEBUG + post("flext - failed to get thread priority"); +#endif + return -1; + } + return pr; + #elif FLEXT_THREADS == FLEXT_THR_MP thr_entry *t; for(t = thrhead; t && t->Id() != id; t = t->nxt) {} @@ -472,6 +537,17 @@ bool flext::SetPriority(int p,thrid_t id) } } return true; + +#elif FLEXT_THREADS == FLEXT_THR_WIN32 + HANDLE hid = OpenThread(THREAD_ALL_ACCESS,TRUE,id); + if(SetThreadPriority(hid,p) == 0) { +#ifdef FLEXT_DEBUG + post("flext - failed to change thread priority"); +#endif + return false; + } + return true; + #elif FLEXT_THREADS == FLEXT_THR_MP thr_entry *t; for(t = thrhead; t && t->Id() != id; t = t->nxt) {} @@ -540,14 +616,6 @@ bool flext::ThrCond::TimedWait(double ftime) Unlock(); return ret; } - -bool flext::ThrCond::Signal() -{ -// Lock(); - bool ret = pthread_cond_signal(&cond) == 0; -// Unlock(); - return ret; -} #endif |