In memory of Ben “bushing” Byer, who passed away on Monday, February 8th, 2016.

Difference between revisions of "IOP OS"

From WiiBrew
Jump to navigation Jump to search
(added info on mutexes)
(→‎Toggling interrupts: confirmed that the IOS scheduler doesn't perfectly simulate disabling interrupts, but the ROS scheduler does)
Line 2: Line 2:
  
 
== Toggling interrupts ==
 
== Toggling interrupts ==
Disabling interrupts is simulated by locking a mutex (but not an <code>OSMutex</code>) implemented as a message queue and changing the current thread priority to 0x38. While this does not completely prevent concurrent execution within the module,{{check}} it is enough for most uses of <code>OSDisableInterrupts</code>.
+
Disabling interrupts is simulated by locking a mutex (but not an <code>OSMutex</code>) implemented as a message queue and changing the current thread priority to 0x38 (higher than other threads in the process). While this does not completely prevent concurrent execution within the module, it is enough for most uses of <code>OSDisableInterrupts</code>. Despite this, the design used may be a mistake when porting the code to IOS, since lower priority Revolution OS threads can starve from being blocked by higher priority threads, which would achieve this goal.
  
 
== Threads ==
 
== Threads ==

Revision as of 04:19, 22 June 2022

IOP OS is a set of functions in IOS's networking code that convert Revolution OS calls to IOS syscalls; for example, OSAlloc is implemented as a call to IOS_Alloc.

Toggling interrupts

Disabling interrupts is simulated by locking a mutex (but not an OSMutex) implemented as a message queue and changing the current thread priority to 0x38 (higher than other threads in the process). While this does not completely prevent concurrent execution within the module, it is enough for most uses of OSDisableInterrupts. Despite this, the design used may be a mistake when porting the code to IOS, since lower priority Revolution OS threads can starve from being blocked by higher priority threads, which would achieve this goal.

Threads

Threads are implemented as a proxy to IOS threads. Because of this, OSThreadQueue is only used for suspended queues.

struct OSThread {
	int threadId;
	int priority;
	void *threadSpecific;
	struct OSThread *next;
}

struct OSThreadQueue {
	struct OSThread *head;
	struct OSThread *tail;
}

Mutexes

Mutexes are implemented as message queues that are read from to lock the mutex and sent to to unlock the mutex.

struct OSMutex {
	int mqid;
	int mq;
	int count;
	int owner; // thread id
}