From a6f16dd4d0ecf27255be2c93f473fae987eeff91 Mon Sep 17 00:00:00 2001 From: brain Date: Fri, 22 Feb 2008 15:08:41 +0000 Subject: Win32ThreadEngine makes sense now. No gaurantees it compiles yet. git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@8990 e03df62e-2008-0410-955e-edbf42e46eb7 --- include/threadengines/threadengine_win32.h | 2 +- src/threadengines/threadengine_win32.cpp | 45 ++++++++++-------------------- 2 files changed, 16 insertions(+), 31 deletions(-) diff --git a/include/threadengines/threadengine_win32.h b/include/threadengines/threadengine_win32.h index c426372a9..696948d19 100644 --- a/include/threadengines/threadengine_win32.h +++ b/include/threadengines/threadengine_win32.h @@ -33,7 +33,7 @@ class CoreExport Win32ThreadEngine : public ThreadEngine void Run(); - static void* Entry(void* parameter); + static DWORD WINAPI Entry(void* parameter); void Create(Thread* thread_to_init); diff --git a/src/threadengines/threadengine_win32.cpp b/src/threadengines/threadengine_win32.cpp index 5bc88fce0..b2279ee2f 100644 --- a/src/threadengines/threadengine_win32.cpp +++ b/src/threadengines/threadengine_win32.cpp @@ -11,22 +11,11 @@ * --------------------------------------------------- */ -/* $Core: libIRCDthreadengine */ - -/********* DEFAULTS **********/ -/* $ExtraSources: socketengines/socketengine_pthread.cpp */ -/* $ExtraObjects: socketengine_pthread.o */ - -/* $If: USE_WIN32 */ -/* $ExtraSources: socketengines/socketengine_win32.cpp */ -/* $ExtraObjects: socketengine_win32.o */ -/* $EndIf */ - #include "inspircd.h" #include "threadengines/threadengine_win32.h" #include -pthread_mutex_t MyMutex = PTHREAD_MUTEX_INITIALIZER; +CRITICAL_SECTION MyMutex; Win32ThreadEngine::Win32ThreadEngine(InspIRCd* Instance) : ThreadEngine(Instance) { @@ -34,22 +23,18 @@ Win32ThreadEngine::Win32ThreadEngine(InspIRCd* Instance) : ThreadEngine(Instance void Win32ThreadEngine::Create(Thread* thread_to_init) { - pthread_attr_t attribs; - pthread_attr_init(&attribs); - pthread_attr_setdetachstate(&attribs, PTHREAD_CREATE_JOINABLE); - pthread_t* MyPThread = new pthread_t; + HANDLE* MyThread = new HANDLE; + DWORD ThreadId = 0; - if (pthread_create(MyPThread, &attribs, Win32ThreadEngine::Entry, (void*)this) != 0) + if (!(MyThread = CreateThread(NULL,0,Win32ThreadEngine::Entry,this,0,&ThreadId))) { - delete MyPThread; - throw CoreException("Unable to create new Win32ThreadEngine: " + std::string(strerror(errno))); + delete MyThread; + throw CoreException("Unable to reate new Win32ThreadEngine: " + dlerror()); } - pthread_attr_destroy(&attribs); - NewThread = thread_to_init; NewThread->Creator = this; - NewThread->Extend("pthread", MyPThread); + NewThread->Extend("winthread", MyThread); } Win32ThreadEngine::~Win32ThreadEngine() @@ -64,30 +49,30 @@ void Win32ThreadEngine::Run() bool Win32ThreadEngine::Mutex(bool enable) { if (enable) - pthread_mutex_lock(&MyMutex); + EnterCriticalSection(&MyMutex); else - pthread_mutex_unlock(&MyMutex); + LeaveCriticalSection(&MyMutex); return false; } -void* Win32ThreadEngine::Entry(void* parameter) +DWORD WINAPI Win32ThreadEngine::Entry(void* parameter) { ThreadEngine * pt = (ThreadEngine*)parameter; pt->Run(); - return NULL; + return 0; } void Win32ThreadEngine::FreeThread(Thread* thread) { - pthread_t* pthread = NULL; - if (thread->GetExt("pthread", pthread)) + HANDLE* winthread = NULL; + if (thread->GetExt("winthread", winthread)) { thread->SetExitFlag(); int rc; void* status; - rc = pthread_join(*pthread, &status); - delete pthread; + WaitForSingleObject(*winthread,INFINITE); + delete winthread; } } -- cgit v1.2.3