mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 09:35:35 +00:00
Get rid of locks added InterlockedExchangeAdd function in thread.cpp
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@748 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
65f8c4bca1
commit
3d6d64c632
@ -344,6 +344,17 @@ void Event::Wait()
|
||||
is_set_ = false;
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
}
|
||||
|
||||
int InterlockedExchangeAdd( int* Addend, int Increment )
|
||||
{
|
||||
|
||||
#if defined(__GNUC__) && defined (__GNUC_MINOR__) && ((4 < __GNUC__) || (4 == __GNUC__ && 1 <= __GNUC_MINOR__))
|
||||
return __sync_add_and_fetch(Addend, Increment);
|
||||
#else
|
||||
// TODO support old gcc
|
||||
#endif
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
|
@ -113,6 +113,9 @@ class Event
|
||||
void SleepCurrentThread(int ms);
|
||||
|
||||
void SetCurrentThreadName(const char* name);
|
||||
|
||||
int InterlockedExchangeAdd( int* Addend, int Increment );
|
||||
} // end of namespace Common
|
||||
|
||||
|
||||
#endif
|
||||
|
@ -378,10 +378,8 @@ void GatherPipeBursted()
|
||||
Common::SleepCurrentThread(1);
|
||||
#ifdef _WIN32
|
||||
InterlockedExchangeAdd((LONG*)&fifo.CPReadWriteDistance, GPFifo::GATHER_PIPE_SIZE);
|
||||
#else
|
||||
fifo.sync->Enter();
|
||||
fifo.CPReadWriteDistance += GPFifo::GATHER_PIPE_SIZE;
|
||||
fifo.sync->Leave();
|
||||
#else
|
||||
Common::InterlockedExchangeAdd((int*)&fifo.CPReadWriteDistance, GPFifo::GATHER_PIPE_SIZE);
|
||||
#endif
|
||||
|
||||
// check if we are in sync
|
||||
|
@ -217,12 +217,13 @@ void Fifo_EnterLoop(const SVideoInitialize &video_initialize)
|
||||
#endif
|
||||
_fifo.CPReadPointer += 32;
|
||||
Video_SendFifoData(uData);
|
||||
|
||||
#ifdef _WIN32
|
||||
InterlockedExchangeAdd((LONG*)&_fifo.CPReadWriteDistance, -32);
|
||||
LeaveCriticalSection(&_fifo.sync);
|
||||
#else
|
||||
_fifo.CPReadWriteDistance -= 32;
|
||||
_fifo.sync->Leave();
|
||||
Common::InterlockedExchangeAdd((int*)&_fifo.CPReadWriteDistance, -32);
|
||||
_fifo.sync->Leave();
|
||||
#endif
|
||||
// increase the ReadPtr
|
||||
if (_fifo.CPReadPointer >= _fifo.CPEnd)
|
||||
|
Loading…
x
Reference in New Issue
Block a user