1
0
Fork 0
forked from len0rd/rockbox

Fix some stuff for no priority and

thread_queue_wake() doesn't need the 2nd parameter. The original purpose
for it never came to be.

Non priority version mrsw_writer_wakeup_readers was left improperly
finished. Get that back into line.

Change-Id: Ic613a2479f3cc14dc7c761517670eb15178da9f5
This commit is contained in:
Michael Sevakis 2014-08-06 02:10:14 -04:00
parent e7e302f255
commit 81ffd9bfee
5 changed files with 14 additions and 20 deletions

View file

@ -1527,10 +1527,8 @@ void block_thread(struct thread_entry *current, int timeout)
* INTERNAL: Intended for use by kernel objects and not for programs.
*---------------------------------------------------------------------------
*/
unsigned int thread_queue_wake(struct thread_entry **list,
volatile int *count)
unsigned int thread_queue_wake(struct thread_entry **list)
{
int num = 0;
unsigned result = THREAD_NONE;
for (;;)
@ -1541,12 +1539,8 @@ unsigned int thread_queue_wake(struct thread_entry **list,
break; /* No more threads */
result |= rc;
num++;
}
if (count)
*count = num;
return result;
}
@ -1821,7 +1815,7 @@ static inline void thread_final_exit(struct thread_entry *current)
* execution except the slot itself. */
/* Signal this thread */
thread_queue_wake(&current->queue, NULL);
thread_queue_wake(&current->queue);
corelock_unlock(&current->waiter_cl);
switch_thread();
/* This should never and must never be reached - if it is, the