Commit 56fcd2ca authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

Revert "Win32: use native Win32 functions directly..." (fixes #5252)

This reverts commit 6e54f3fd.

Conflicts:

	src/win32/thread.c
parent 6a0baf64
...@@ -61,8 +61,8 @@ struct vlc_thread ...@@ -61,8 +61,8 @@ struct vlc_thread
void *data; void *data;
}; };
static CRITICAL_SECTION super_mutex; static vlc_mutex_t super_mutex;
static HANDLE super_cond; static vlc_cond_t super_variable;
extern vlc_rwlock_t config_lock, msg_lock; extern vlc_rwlock_t config_lock, msg_lock;
BOOL WINAPI DllMain (HINSTANCE, DWORD, LPVOID); BOOL WINAPI DllMain (HINSTANCE, DWORD, LPVOID);
...@@ -75,10 +75,8 @@ BOOL WINAPI DllMain (HINSTANCE hinstDll, DWORD fdwReason, LPVOID lpvReserved) ...@@ -75,10 +75,8 @@ BOOL WINAPI DllMain (HINSTANCE hinstDll, DWORD fdwReason, LPVOID lpvReserved)
switch (fdwReason) switch (fdwReason)
{ {
case DLL_PROCESS_ATTACH: case DLL_PROCESS_ATTACH:
super_cond = CreateEvent (NULL, TRUE, FALSE, NULL); vlc_mutex_init (&super_mutex);
if (unlikely(!super_cond)) vlc_cond_init (&super_variable);
return FALSE;
InitializeCriticalSection (&super_mutex);
vlc_threadvar_create (&thread_key, NULL); vlc_threadvar_create (&thread_key, NULL);
vlc_rwlock_init (&config_lock); vlc_rwlock_init (&config_lock);
vlc_rwlock_init (&msg_lock); vlc_rwlock_init (&msg_lock);
...@@ -89,8 +87,8 @@ BOOL WINAPI DllMain (HINSTANCE hinstDll, DWORD fdwReason, LPVOID lpvReserved) ...@@ -89,8 +87,8 @@ BOOL WINAPI DllMain (HINSTANCE hinstDll, DWORD fdwReason, LPVOID lpvReserved)
vlc_rwlock_destroy (&msg_lock); vlc_rwlock_destroy (&msg_lock);
vlc_rwlock_destroy (&config_lock); vlc_rwlock_destroy (&config_lock);
vlc_threadvar_delete (&thread_key); vlc_threadvar_delete (&thread_key);
DeleteCriticalSection (&super_mutex); vlc_cond_destroy (&super_variable);
CloseHandle (super_cond); vlc_mutex_destroy (&super_mutex);
break; break;
} }
return TRUE; return TRUE;
...@@ -181,19 +179,20 @@ void vlc_mutex_destroy (vlc_mutex_t *p_mutex) ...@@ -181,19 +179,20 @@ void vlc_mutex_destroy (vlc_mutex_t *p_mutex)
void vlc_mutex_lock (vlc_mutex_t *p_mutex) void vlc_mutex_lock (vlc_mutex_t *p_mutex)
{ {
if (!p_mutex->dynamic) if (!p_mutex->dynamic)
{ /* static mutexes (inefficient on Windows) */ { /* static mutexes */
EnterCriticalSection (&super_mutex); int canc = vlc_savecancel ();
assert (p_mutex != &super_mutex); /* this one cannot be static */
vlc_mutex_lock (&super_mutex);
while (p_mutex->locked) while (p_mutex->locked)
{ {
p_mutex->contention++; p_mutex->contention++;
LeaveCriticalSection (&super_mutex); vlc_cond_wait (&super_variable, &super_mutex);
WaitForSingleObject (super_cond, INFINITE);
EnterCriticalSection (&super_mutex);
assert (p_mutex->contention > 0);
p_mutex->contention--; p_mutex->contention--;
} }
p_mutex->locked = true; p_mutex->locked = true;
LeaveCriticalSection (&super_mutex); vlc_mutex_unlock (&super_mutex);
vlc_restorecancel (canc);
return; return;
} }
...@@ -206,13 +205,14 @@ int vlc_mutex_trylock (vlc_mutex_t *p_mutex) ...@@ -206,13 +205,14 @@ int vlc_mutex_trylock (vlc_mutex_t *p_mutex)
{ /* static mutexes */ { /* static mutexes */
int ret = EBUSY; int ret = EBUSY;
EnterCriticalSection (&super_mutex); assert (p_mutex != &super_mutex); /* this one cannot be static */
vlc_mutex_lock (&super_mutex);
if (!p_mutex->locked) if (!p_mutex->locked)
{ {
p_mutex->locked = true; p_mutex->locked = true;
ret = 0; ret = 0;
} }
LeaveCriticalSection (&super_mutex); vlc_mutex_unlock (&super_mutex);
return ret; return ret;
} }
...@@ -223,12 +223,14 @@ void vlc_mutex_unlock (vlc_mutex_t *p_mutex) ...@@ -223,12 +223,14 @@ void vlc_mutex_unlock (vlc_mutex_t *p_mutex)
{ {
if (!p_mutex->dynamic) if (!p_mutex->dynamic)
{ /* static mutexes */ { /* static mutexes */
EnterCriticalSection (&super_mutex); assert (p_mutex != &super_mutex); /* this one cannot be static */
vlc_mutex_lock (&super_mutex);
assert (p_mutex->locked); assert (p_mutex->locked);
p_mutex->locked = false; p_mutex->locked = false;
if (p_mutex->contention > 0) if (p_mutex->contention)
SetEvent (super_cond); vlc_cond_broadcast (&super_variable);
LeaveCriticalSection (&super_mutex); vlc_mutex_unlock (&super_mutex);
return; return;
} }
...@@ -491,10 +493,10 @@ int vlc_threadvar_create (vlc_threadvar_t *p_tls, void (*destr) (void *)) ...@@ -491,10 +493,10 @@ int vlc_threadvar_create (vlc_threadvar_t *p_tls, void (*destr) (void *))
var->next = NULL; var->next = NULL;
*p_tls = var; *p_tls = var;
EnterCriticalSection (&super_mutex); vlc_mutex_lock (&super_mutex);
var->prev = vlc_threadvar_last; var->prev = vlc_threadvar_last;
vlc_threadvar_last = var; vlc_threadvar_last = var;
LeaveCriticalSection (&super_mutex); vlc_mutex_unlock (&super_mutex);
return 0; return 0;
} }
...@@ -502,14 +504,14 @@ void vlc_threadvar_delete (vlc_threadvar_t *p_tls) ...@@ -502,14 +504,14 @@ void vlc_threadvar_delete (vlc_threadvar_t *p_tls)
{ {
struct vlc_threadvar *var = *p_tls; struct vlc_threadvar *var = *p_tls;
EnterCriticalSection (&super_mutex); vlc_mutex_lock (&super_mutex);
if (var->prev != NULL) if (var->prev != NULL)
var->prev->next = var->next; var->prev->next = var->next;
else else
vlc_threadvar_last = var->next; vlc_threadvar_last = var->next;
if (var->next != NULL) if (var->next != NULL)
var->next->prev = var->prev; var->next->prev = var->prev;
LeaveCriticalSection (&super_mutex); vlc_mutex_unlock (&super_mutex);
TlsFree (var->id); TlsFree (var->id);
free (var); free (var);
...@@ -537,19 +539,19 @@ static void vlc_thread_cleanup (struct vlc_thread *th) ...@@ -537,19 +539,19 @@ static void vlc_thread_cleanup (struct vlc_thread *th)
retry: retry:
/* TODO: use RW lock or something similar */ /* TODO: use RW lock or something similar */
EnterCriticalSection (&super_mutex); vlc_mutex_lock (&super_mutex);
for (key = vlc_threadvar_last; key != NULL; key = key->prev) for (key = vlc_threadvar_last; key != NULL; key = key->prev)
{ {
void *value = vlc_threadvar_get (key); void *value = vlc_threadvar_get (key);
if (value != NULL && key->destroy != NULL) if (value != NULL && key->destroy != NULL)
{ {
EnterCriticalSection (&super_mutex); vlc_mutex_unlock (&super_mutex);
vlc_threadvar_set (key, NULL); vlc_threadvar_set (key, NULL);
key->destroy (value); key->destroy (value);
goto retry; goto retry;
} }
} }
EnterCriticalSection (&super_mutex); vlc_mutex_unlock (&super_mutex);
if (th->detached) if (th->detached)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment