wut
1.0.0-beta8
Wii U Toolchain
|
Manage and run threads on each of the system's cores. More...
Data Structures | |
struct | OSMutexQueue |
struct | OSFastMutexQueue |
Macros | |
#define | OS_THREAD_TAG 0x74487244u |
Typedefs | |
typedef struct OSFastMutex | OSFastMutex |
typedef struct OSFastMutexQueue | OSFastMutexQueue |
typedef struct OSMutex | OSMutex |
typedef struct OSMutexQueue | OSMutexQueue |
typedef struct OSThread | OSThread |
typedef uint8_t | OSThreadState |
A value from enum OS_THREAD_STATE. More... | |
typedef uint32_t | OSThreadRequest |
A value from enum OS_THREAD_REQUEST. More... | |
typedef uint8_t | OSThreadAttributes |
A bitfield of enum OS_THREAD_ATTRIB. More... | |
typedef int(* | OSThreadEntryPointFn) (int argc, const char **argv) |
typedef void(* | OSThreadCleanupCallbackFn) (OSThread *thread, void *stack) |
typedef void(* | OSThreadDeallocatorFn) (OSThread *thread, void *stack) |
Enumerations | |
enum | OS_THREAD_STATE { OS_THREAD_STATE_NONE = 0, OS_THREAD_STATE_READY = 1 << 0, OS_THREAD_STATE_RUNNING = 1 << 1, OS_THREAD_STATE_WAITING = 1 << 2, OS_THREAD_STATE_MORIBUND = 1 << 3 } |
enum | OS_THREAD_REQUEST { OS_THREAD_REQUEST_NONE = 0, OS_THREAD_REQUEST_SUSPEND = 1, OS_THREAD_REQUEST_CANCEL = 2 } |
enum | OS_THREAD_ATTRIB { OS_THREAD_ATTRIB_AFFINITY_CPU0 = 1 << 0, OS_THREAD_ATTRIB_AFFINITY_CPU1 = 1 << 1, OS_THREAD_ATTRIB_AFFINITY_CPU2 = 1 << 2, OS_THREAD_ATTRIB_AFFINITY_ANY = ((1 << 0) | (1 << 1) | (1 << 2)), OS_THREAD_ATTRIB_DETACHED = 1 << 3, OS_THREAD_ATTRIB_STACK_USAGE = 1 << 5 } |
Functions | |
struct | WUT_ALIGNAS (8) OSThread |
void | OSCancelThread (OSThread *thread) |
Cancels a thread. More... | |
int32_t | OSCheckActiveThreads () |
Returns the count of active threads. More... | |
int32_t | OSCheckThreadStackUsage (OSThread *thread) |
Get the maximum amount of stack the thread has used. More... | |
void | OSClearThreadStackUsage (OSThread *thread) |
Disable tracking of thread stack usage. More... | |
void | OSContinueThread (OSThread *thread) |
Clears a thread's suspend counter and resumes it. More... | |
BOOL | OSCreateThread (OSThread *thread, OSThreadEntryPointFn entry, int32_t argc, char *argv, void *stack, uint32_t stackSize, int32_t priority, OSThreadAttributes attributes) |
Create a new thread. More... | |
void | OSDetachThread (OSThread *thread) |
Detach thread. More... | |
void | OSExitThread (int32_t result) |
Exit the current thread with a exit code. More... | |
void | OSGetActiveThreadLink (OSThread *thread, OSThreadLink *link) |
Get the next and previous thread in the thread's active queue. More... | |
OSThread * | OSGetCurrentThread () |
Return pointer to OSThread object for the current thread. More... | |
OSThread * | OSGetDefaultThread (uint32_t coreID) |
Returns the default thread for a specific core. More... | |
uint32_t | OSGetStackPointer () |
Return current stack pointer, value of r1 register. More... | |
uint32_t | OSGetThreadAffinity (OSThread *thread) |
Get a thread's affinity. More... | |
const char * | OSGetThreadName (OSThread *thread) |
Get a thread's name. More... | |
int32_t | OSGetThreadPriority (OSThread *thread) |
Get a thread's base priority. More... | |
void * | OSGetThreadSpecific (uint32_t id) |
Get a thread's specific value set by OSSetThreadSpecific. More... | |
BOOL | OSIsThreadSuspended (OSThread *thread) |
Returns TRUE if a thread is suspended. More... | |
BOOL | OSIsThreadTerminated (OSThread *thread) |
Returns TRUE if a thread is terminated. More... | |
BOOL | OSJoinThread (OSThread *thread, int *threadResult) |
Wait until thread is terminated. More... | |
int32_t | OSResumeThread (OSThread *thread) |
Resumes a thread. More... | |
BOOL | OSRunThread (OSThread *thread, OSThreadEntryPointFn entry, int argc, const char **argv) |
Run a function on an already created thread. More... | |
BOOL | OSSetThreadAffinity (OSThread *thread, uint32_t affinity) |
Set a thread's affinity. More... | |
BOOL | OSSetThreadCancelState (BOOL state) |
Set a thread's cancellation state. More... | |
OSThreadCleanupCallbackFn | OSSetThreadCleanupCallback (OSThread *thread, OSThreadCleanupCallbackFn callback) |
Set the callback to be called just before a thread is terminated. More... | |
OSThreadDeallocatorFn | OSSetThreadDeallocator (OSThread *thread, OSThreadDeallocatorFn deallocator) |
Set the callback to be called just after a thread is terminated. More... | |
void | OSSetThreadName (OSThread *thread, const char *name) |
Set a thread's name. More... | |
BOOL | OSSetThreadPriority (OSThread *thread, int32_t priority) |
Set a thread's priority. More... | |
BOOL | OSSetThreadRunQuantum (OSThread *thread, uint32_t quantum) |
Set a thread's run quantum. More... | |
void | OSSetThreadSpecific (uint32_t id, void *value) |
Set a thread specific value. More... | |
BOOL | OSSetThreadStackUsage (OSThread *thread) |
Set thread stack usage tracking. More... | |
void | OSSleepThread (OSThreadQueue *queue) |
Sleep the current thread and add it to a thread queue. More... | |
void | OSSleepTicks (OSTime ticks) |
Sleep the current thread for a period of time. More... | |
uint32_t | OSSuspendThread (OSThread *thread) |
Suspend a thread. More... | |
void | OSTestThreadCancel () |
Check to see if the current thread should be cancelled or suspended. More... | |
void | OSWakeupThread (OSThreadQueue *queue) |
Wake up all threads in queue. More... | |
void | OSYieldThread () |
Yield execution to waiting threads with same priority. More... | |
Manage and run threads on each of the system's cores.
The thread scheduler in the Wii U uses co-operative scheduling, this is different to the usual pre-emptive scheduling that most operating systems use (such as Windows, Linux, etc). In co-operative scheduling threads must voluntarily yield execution to other threads. In pre-emptive threads are switched by the operating system after an amount of time.
With the Wii U's scheduling model the thread with the highest priority which is in a non-waiting state will always be running (where 0 is the highest priority and 31 is the lowest). Execution will only switch to other threads once this thread has been forced to wait, such as when waiting to acquire a mutex, or when the thread voluntarily yields execution to other threads which have the same priority using OSYieldThread. OSYieldThread will never yield to a thread with lower priority than the current thread.
struct OSMutexQueue |
struct OSFastMutexQueue |
Data Fields | ||
---|---|---|
OSFastMutex * | head | |
OSFastMutex * | tail |
typedef struct OSFastMutex OSFastMutex |
typedef struct OSFastMutexQueue OSFastMutexQueue |
typedef struct OSMutexQueue OSMutexQueue |
typedef uint8_t OSThreadState |
typedef uint32_t OSThreadRequest |
typedef uint8_t OSThreadAttributes |
typedef int(* OSThreadEntryPointFn) (int argc, const char **argv) |
typedef void(* OSThreadCleanupCallbackFn) (OSThread *thread, void *stack) |
typedef void(* OSThreadDeallocatorFn) (OSThread *thread, void *stack) |
enum OS_THREAD_STATE |
enum OS_THREAD_REQUEST |
enum OS_THREAD_ATTRIB |
struct WUT_ALIGNAS | ( | 8 | ) |
Should always be set to the value OS_THREAD_TAG.
Bitfield of OS_THREAD_STATE
Bitfield of OS_THREAD_ATTRIB
Unique thread ID
Suspend count (increased by OSSuspendThread).
Actual priority of thread.
Base priority of thread, 0 is highest priority, 31 is lowest priority.
Exit value
Queue the thread is currently waiting on
Link used for thread queue
Queue of threads waiting to join this thread
Mutex this thread is waiting to lock
Queue of mutexes this thread owns
Link for global active thread queue
Stack start (top, highest address)
Stack end (bottom, lowest address)
Thread entry point
Thread specific values, accessed with OSSetThreadSpecific and OSGetThreadSpecific.
Thread name, accessed with OSSetThreadName and OSGetThreadName.
The stack pointer passed in OSCreateThread.
Called just before thread is terminated, set with OSSetThreadCleanupCallback
Called just after a thread is terminated, set with OSSetThreadDeallocator
If TRUE then a thread can be cancelled or suspended, set with OSSetThreadCancelState
Current thread request, used for cancelleing and suspending the thread.
Pending suspend request count
Result of thread suspend
Queue of threads waiting for a thread to be suspended.
void OSCancelThread | ( | OSThread * | thread | ) |
Cancels a thread.
This sets the threads requestFlag to OS_THREAD_REQUEST_CANCEL, the thread will be terminated next time OSTestThreadCancel is called.
int32_t OSCheckActiveThreads | ( | ) |
Returns the count of active threads.
int32_t OSCheckThreadStackUsage | ( | OSThread * | thread | ) |
Get the maximum amount of stack the thread has used.
void OSClearThreadStackUsage | ( | OSThread * | thread | ) |
Disable tracking of thread stack usage.
void OSContinueThread | ( | OSThread * | thread | ) |
Clears a thread's suspend counter and resumes it.
BOOL OSCreateThread | ( | OSThread * | thread, |
OSThreadEntryPointFn | entry, | ||
int32_t | argc, | ||
char * | argv, | ||
void * | stack, | ||
uint32_t | stackSize, | ||
int32_t | priority, | ||
OSThreadAttributes | attributes | ||
) |
Create a new thread.
thread | Thread to initialise. |
entry | Thread entry point. |
argc | argc argument passed to entry point. |
argv | argv argument passed to entry point. |
stack | Top of stack (highest address). |
stackSize | Size of stack. |
priority | Thread priority, 0 is highest priorty, 31 is lowest. |
attributes | Thread attributes, see OSThreadAttributes. |
void OSDetachThread | ( | OSThread * | thread | ) |
Detach thread.
void OSExitThread | ( | int32_t | result | ) |
Exit the current thread with a exit code.
This function is implicitly called when the thread entry point returns.
void OSGetActiveThreadLink | ( | OSThread * | thread, |
OSThreadLink * | link | ||
) |
Get the next and previous thread in the thread's active queue.
OSThread* OSGetCurrentThread | ( | ) |
Return pointer to OSThread object for the current thread.
OSThread* OSGetDefaultThread | ( | uint32_t | coreID | ) |
Returns the default thread for a specific core.
Each core has 1 default thread created before the game boots. The default thread for core 1 calls the RPX entry point, the default threads for core 0 and 2 are suspended and can be used with OSRunThread.
uint32_t OSGetStackPointer | ( | ) |
Return current stack pointer, value of r1 register.
uint32_t OSGetThreadAffinity | ( | OSThread * | thread | ) |
Get a thread's affinity.
const char* OSGetThreadName | ( | OSThread * | thread | ) |
Get a thread's name.
int32_t OSGetThreadPriority | ( | OSThread * | thread | ) |
Get a thread's base priority.
void* OSGetThreadSpecific | ( | uint32_t | id | ) |
Get a thread's specific value set by OSSetThreadSpecific.
Wait until thread is terminated.
If the target thread is detached, returns FALSE.
thread | Thread to wait for |
threadResult | Pointer to store thread exit value in. |
int32_t OSResumeThread | ( | OSThread * | thread | ) |
Resumes a thread.
Decrements the thread's suspend counter, if the counter reaches 0 the thread is resumed.
BOOL OSRunThread | ( | OSThread * | thread, |
OSThreadEntryPointFn | entry, | ||
int | argc, | ||
const char ** | argv | ||
) |
Run a function on an already created thread.
Can only be used on idle threads.
Set a thread's cancellation state.
If the state is TRUE then the thread can be suspended or cancelled when OSTestThreadCancel is called.
OSThreadCleanupCallbackFn OSSetThreadCleanupCallback | ( | OSThread * | thread, |
OSThreadCleanupCallbackFn | callback | ||
) |
Set the callback to be called just before a thread is terminated.
OSThreadDeallocatorFn OSSetThreadDeallocator | ( | OSThread * | thread, |
OSThreadDeallocatorFn | deallocator | ||
) |
Set the callback to be called just after a thread is terminated.
void OSSetThreadName | ( | OSThread * | thread, |
const char * | name | ||
) |
Set a thread's name.
Set a thread's run quantum.
This is the maximum amount of time the thread can run for before being forced to yield.
void OSSetThreadSpecific | ( | uint32_t | id, |
void * | value | ||
) |
Set a thread specific value.
Can be read with OSGetThreadSpecific.
void OSSleepThread | ( | OSThreadQueue * | queue | ) |
Sleep the current thread and add it to a thread queue.
Will sleep until the thread queue is woken with OSWakeupThread.
void OSSleepTicks | ( | OSTime | ticks | ) |
Sleep the current thread for a period of time.
uint32_t OSSuspendThread | ( | OSThread * | thread | ) |
Suspend a thread.
Increases a thread's suspend counter, if the counter is >0 then the thread is suspended.
void OSTestThreadCancel | ( | ) |
Check to see if the current thread should be cancelled or suspended.
This is implicitly called in:
void OSWakeupThread | ( | OSThreadQueue * | queue | ) |
Wake up all threads in queue.
Clears the thread queue.
void OSYieldThread | ( | ) |
Yield execution to waiting threads with same priority.
This will never switch to a thread with a lower priority than the current thread.