Commit 206378e4 authored by Magnus Hagander's avatar Magnus Hagander

Use CRITICAL_SECTION instead of Mutexes for thread-locking in libpq on

Windows, for better performance.

Per suggestion from Andrew Chernow, but not his patch since the underlying
code was changed to deal with return values.
parent 763c4866
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* *
* Copyright (c) 2004-2008, PostgreSQL Global Development Group * Copyright (c) 2004-2008, PostgreSQL Global Development Group
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/interfaces/libpq/pthread-win32.c,v 1.16 2008/05/16 18:30:53 mha Exp $ * $PostgreSQL: pgsql/src/interfaces/libpq/pthread-win32.c,v 1.17 2008/05/21 14:20:48 mha Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -35,24 +35,27 @@ pthread_getspecific(pthread_key_t key) ...@@ -35,24 +35,27 @@ pthread_getspecific(pthread_key_t key)
int int
pthread_mutex_init(pthread_mutex_t *mp, void *attr) pthread_mutex_init(pthread_mutex_t *mp, void *attr)
{ {
*mp = CreateMutex(0, 0, 0); *mp = (CRITICAL_SECTION *)malloc(sizeof(CRITICAL_SECTION));
if (*mp == NULL) if (!*mp)
return 1; return 1;
InitializeCriticalSection(*mp);
return 0; return 0;
} }
int int
pthread_mutex_lock(pthread_mutex_t *mp) pthread_mutex_lock(pthread_mutex_t *mp)
{ {
if (WaitForSingleObject(*mp, INFINITE) != WAIT_OBJECT_0) if (!*mp)
return 1; return 1;
EnterCriticalSection(*mp);
return 0; return 0;
} }
int int
pthread_mutex_unlock(pthread_mutex_t *mp) pthread_mutex_unlock(pthread_mutex_t *mp)
{ {
if (!ReleaseMutex(*mp)) if (!*mp)
return 1; return 1;
LeaveCriticalSection(*mp);
return 0; return 0;
} }
/* /*
* $PostgreSQL: pgsql/src/port/pthread-win32.h,v 1.4 2008/05/17 01:28:25 adunstan Exp $ * $PostgreSQL: pgsql/src/port/pthread-win32.h,v 1.5 2008/05/21 14:20:48 mha Exp $
*/ */
#ifndef __PTHREAD_H #ifndef __PTHREAD_H
#define __PTHREAD_H #define __PTHREAD_H
typedef ULONG pthread_key_t; typedef ULONG pthread_key_t;
typedef HANDLE pthread_mutex_t; typedef CRITICAL_SECTION *pthread_mutex_t;
typedef int pthread_once_t; typedef int pthread_once_t;
DWORD pthread_self(void); DWORD pthread_self(void);
......
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