changed the GuiElement Lock-Stuff
The libogc limits the MUTEX up to a count of 64. Therefore we use "only one" global Mutex for all Elements. This has to follow tath a lock hinder each thread tath which tries access to any other element Also the new Lock-Stuff uses one global mutex. But this mutex is locked for the smallest time as possible (Only in the lock- and unlock-process). The threads are no longer hindered unnecessarily each other. This speeds up the gui
This commit is contained in:
parent
79b3c8c5dd
commit
be9d29773f
4 changed files with 58 additions and 87 deletions
|
@ -117,8 +117,6 @@ typedef struct _paddata {
|
|||
#define EFFECT_GOROUND 2048
|
||||
|
||||
#define MAX_SND_VOICES 16
|
||||
#define newGuiSound
|
||||
#define verynewGuiSound
|
||||
|
||||
class GuiSoundDecoder;
|
||||
class GuiSound
|
||||
|
@ -431,7 +429,11 @@ class GuiElement
|
|||
protected:
|
||||
void Lock();
|
||||
void Unlock();
|
||||
static mutex_t mutex;
|
||||
// static mutex_t mutex;
|
||||
static mutex_t _lock_mutex;
|
||||
lwp_t _lock_thread;
|
||||
u16 _lock_count;
|
||||
lwpq_t _lock_queue;
|
||||
friend class SimpleLock;
|
||||
|
||||
//int position2; //! B Scrollbariable
|
||||
|
|
|
@ -13,7 +13,8 @@
|
|||
/**
|
||||
* Constructor for the Object class.
|
||||
*/
|
||||
mutex_t GuiElement::mutex = LWP_MUTEX_NULL;
|
||||
//mutex_t GuiElement::mutex = LWP_MUTEX_NULL;
|
||||
mutex_t GuiElement::_lock_mutex = LWP_MUTEX_NULL;
|
||||
GuiElement::GuiElement()
|
||||
{
|
||||
xoffset = 0;
|
||||
|
@ -65,7 +66,12 @@ GuiElement::GuiElement()
|
|||
// default alignment - align to top left
|
||||
alignmentVert = ALIGN_TOP;
|
||||
alignmentHor = ALIGN_LEFT;
|
||||
if(mutex == LWP_MUTEX_NULL) LWP_MutexInit(&mutex, true);
|
||||
// if(mutex == LWP_MUTEX_NULL) LWP_MutexInit(&mutex, true);
|
||||
if(_lock_mutex == LWP_MUTEX_NULL) LWP_MutexInit(&_lock_mutex, true);
|
||||
_lock_thread = LWP_THREAD_NULL;
|
||||
_lock_count = 0;
|
||||
_lock_queue = LWP_TQUEUE_NULL;
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -754,11 +760,52 @@ bool GuiElement::IsInside(int x, int y)
|
|||
}
|
||||
void GuiElement::Lock()
|
||||
{
|
||||
LWP_MutexLock(mutex);
|
||||
// LWP_MutexLock(mutex);
|
||||
for(;;) // loop while element is locked by self
|
||||
{
|
||||
LWP_MutexLock(_lock_mutex);
|
||||
|
||||
if(_lock_thread == LWP_THREAD_NULL) // element is not locked
|
||||
{
|
||||
_lock_thread = LWP_GetSelf(); // mark as locked
|
||||
_lock_count = 1; // set count of lock to 1
|
||||
LWP_MutexUnlock(_lock_mutex);
|
||||
return;
|
||||
}
|
||||
else if(_lock_thread == LWP_GetSelf()) // thread is locked by my self
|
||||
{
|
||||
_lock_count++; // inc count of locks;
|
||||
LWP_MutexUnlock(_lock_mutex);
|
||||
return;
|
||||
}
|
||||
else // otherwise the element is locked by an other thread
|
||||
{
|
||||
if(_lock_queue == LWP_TQUEUE_NULL) // no queue - meens it is the first access to the locked element
|
||||
LWP_InitQueue(&_lock_queue); // init queue
|
||||
LWP_MutexUnlock(_lock_mutex);
|
||||
LWP_ThreadSleep(_lock_queue); // and sleep
|
||||
// try lock again;
|
||||
}
|
||||
}
|
||||
}
|
||||
void GuiElement::Unlock()
|
||||
{
|
||||
LWP_MutexUnlock(mutex);
|
||||
// LWP_MutexUnlock(mutex);
|
||||
LWP_MutexLock(_lock_mutex);
|
||||
// only the thread was locked this element, can call unlock
|
||||
if(_lock_thread == LWP_GetSelf()) // but we check it here – safe is safe
|
||||
{
|
||||
if(--_lock_count == 0) // dec count of locks and check if it last lock;
|
||||
{
|
||||
_lock_thread = LWP_THREAD_NULL; // mark as unlocked
|
||||
if(_lock_queue != LWP_TQUEUE_NULL) // has a queue
|
||||
{
|
||||
LWP_CloseQueue(_lock_queue); // close the queue and wake all waited threads
|
||||
_lock_queue = LWP_TQUEUE_NULL;
|
||||
}
|
||||
}
|
||||
}
|
||||
LWP_MutexUnlock(_lock_mutex);
|
||||
}
|
||||
|
||||
|
||||
|
@ -770,82 +817,3 @@ SimpleLock::~SimpleLock()
|
|||
{
|
||||
element->Unlock();
|
||||
}
|
||||
#if 0
|
||||
|
||||
|
||||
GuiElement
|
||||
|
||||
|
||||
protected:
|
||||
void Lock();
|
||||
void Unlock();
|
||||
friend class SimpleLock;
|
||||
private:
|
||||
// static mutex_t mutex;
|
||||
static mutex_t _lock_mutex;
|
||||
lwp_t _lock_thread;
|
||||
u16 _lock_count;
|
||||
lwpq_t _lock_queue;
|
||||
u16 _lock_queue_count;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
void GuiElement::Lock()
|
||||
{
|
||||
LWP_MutexLock(_lock_mutex);
|
||||
|
||||
if(_lock_thread = LWP_GetSelf()) // i am self
|
||||
{
|
||||
_lock_count++; // inc count of locks;
|
||||
LWP_MutexUnlock(_lock_mutex);
|
||||
return;
|
||||
}
|
||||
|
||||
if(_lock_thread == THREAD_NULL) // element is not locked
|
||||
{
|
||||
_lock_thread = LWP_GetSelf();
|
||||
_lock_count = 1;
|
||||
LWP_MutexUnlock(_lock_mutex);
|
||||
return;
|
||||
}
|
||||
|
||||
// element is locked
|
||||
if(_lock_queue == LWP_TQUEUE_NULL) // no queue
|
||||
{
|
||||
LWP_InitQueue(&_lock_queue); // init queue
|
||||
_lock_queue_count = 0; // clear count of threads in queue;
|
||||
}
|
||||
_lock_queue_count++; // inc count of threads in queue;
|
||||
LWP_MutexUnlock(_lock_mutex); // unlock
|
||||
LWP_ThreadSleep(_lock_queue); // and sleep
|
||||
LWP_MutexLock(_lock_mutex); // waked up , will lock
|
||||
if(--_lock_queue_count == 0) // dec count of threads in queue;
|
||||
{
|
||||
// is the last thread in queue
|
||||
LWP_CloseQueue(_lock_queue); // close the queue
|
||||
_lock_queue = LWP_TQUEUE_NULL;
|
||||
lock(); // try lock again;
|
||||
}
|
||||
LWP_MutexUnlock(_lock_mutex)
|
||||
return;
|
||||
}
|
||||
void GuiElement::Unlock()
|
||||
{
|
||||
LWP_MutexLock(_lock_mutex);
|
||||
// only the thread was locked this element, can call unlock
|
||||
if(_lock_thread == LWP_GetSelf()) // but we check it here – safe is safe
|
||||
{
|
||||
if(--_lock_queue_count == 0) // dec count of locks;
|
||||
{
|
||||
_lock_thread = THREAD_NULL; // is the last thread in queue
|
||||
if(_lock_queue != LWP_TQUEUE_NULL) // has a queue
|
||||
LWP_ThreadSignal(_lock_queue); // wake the next thread in queue
|
||||
}
|
||||
}
|
||||
LWP_MutexUnlock(_lock_mutex)
|
||||
}
|
||||
|
||||
|
||||
#endif
|
||||
|
|
|
@ -98,7 +98,7 @@ protected:
|
|||
}
|
||||
in_ptr = chunk_start+chunk_size;
|
||||
}
|
||||
currentPos = sound;
|
||||
currentPos = pcm_start;
|
||||
}
|
||||
public:
|
||||
~GuiSoundDecoderAIFF()
|
||||
|
|
|
@ -31,6 +31,7 @@ typedef struct
|
|||
const u8 *end;
|
||||
u32 loops;
|
||||
}playlist_t;
|
||||
|
||||
class GuiSoundDecoderWAV : public GuiSoundDecoder
|
||||
{
|
||||
protected:
|
||||
|
|
Loading…
Add table
Reference in a new issue