X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Flock.h;h=e25a223432be572bf1e07118e93100e0a058f8b5;hb=65f8b6dbc0b4cdb6a27313bad5a1043edd16a779;hp=715755d36900c167ff390f2951ddf453458d06cf;hpb=5c81602d14539f8259a715477315e28b5de7cb54;p=stockfish diff --git a/src/lock.h b/src/lock.h index 715755d3..e25a2234 100644 --- a/src/lock.h +++ b/src/lock.h @@ -1,7 +1,7 @@ /* Stockfish, a UCI chess playing engine derived from Glaurung 2.1 Copyright (C) 2004-2008 Tord Romstad (Glaurung author) - Copyright (C) 2008-2009 Marco Costalba + Copyright (C) 2008-2010 Marco Costalba, Joona Kiiski, Tord Romstad Stockfish is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -22,57 +22,7 @@ #define LOCK_H_INCLUDED -// x86 assembly language locks or OS spin locks may perform faster than -// mutex locks on some platforms. On my machine, mutexes seem to be the -// best. - -//#define ASM_LOCK -//#define OS_SPIN_LOCK - - -#if defined(ASM_LOCK) - - -typedef volatile int Lock; - -static inline void LockX86(Lock *lock) { - int dummy; - asm __volatile__("1: movl $1, %0" "\n\t" - " xchgl (%1), %0" "\n\t" " testl %0, %0" "\n\t" - " jz 3f" "\n\t" "2: pause" "\n\t" - " movl (%1), %0" "\n\t" " testl %0, %0" "\n\t" - " jnz 2b" "\n\t" " jmp 1b" "\n\t" "3:" - "\n\t":"=&q"(dummy) - :"q"(lock) - :"cc"); -} - -static inline void UnlockX86(Lock *lock) { - int dummy; - asm __volatile__("movl $0, (%1)":"=&q"(dummy) - :"q"(lock)); -} - -# define lock_init(x, y) (*(x) = 0) -# define lock_grab(x) LockX86(x) -# define lock_release(x) UnlockX86(x) -# define lock_destroy(x) - - -#elif defined(OS_SPIN_LOCK) - - -# include - -typedef OSSpinLock Lock; - -# define lock_init(x, y) (*(x) = 0) -# define lock_grab(x) OSSpinLockLock(x) -# define lock_release(x) OSSpinLockUnlock(x) -# define lock_destroy(x) - - -#elif !defined(_MSC_VER) +#if !defined(_MSC_VER) # include @@ -86,8 +36,9 @@ typedef pthread_mutex_t Lock; #else - +#define WIN32_LEAN_AND_MEAN #include +#undef WIN32_LEAN_AND_MEAN typedef CRITICAL_SECTION Lock; # define lock_init(x, y) InitializeCriticalSection(x) @@ -98,5 +49,4 @@ typedef CRITICAL_SECTION Lock; #endif - #endif // !defined(LOCK_H_INCLUDED)