Twilight Princess
Decompilation of The Legend of Zelda: Twilight Princess
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Modules Pages
os.h
Go to the documentation of this file.
1#ifndef _DOLPHIN_OS_H_
2#define _DOLPHIN_OS_H_
3
4#include <stdio.h>
5
6#include <dolphin/types.h>
8void OSReportInit(void);
10void OSVAttention(const char* fmt, va_list args);
11
12#ifdef __cplusplus
13extern "C" {
14#endif
15
16typedef s64 OSTime;
17typedef u32 OSTick;
18
19#include <dolphin/os/OSAlloc.h>
20#include <dolphin/os/OSCache.h>
23#include <dolphin/os/OSModule.h>
24#include <dolphin/os/OSThread.h>
25#include <dolphin/os/OSMutex.h>
26#include <dolphin/os/OSFont.h>
27#include <dolphin/os/OSReset.h>
29#include <dolphin/os/OSError.h>
30#include <dolphin/os/OSTime.h>
31#include <dolphin/os/OSSerial.h>
32#include <dolphin/os/OSRtc.h>
35#include <dolphin/os/OSAlarm.h>
36#include <dolphin/os/OSDC.h>
37#include <dolphin/os/OSIC.h>
38#include <dolphin/os/OSLC.h>
39#include <dolphin/os/OSL2.h>
40#include <dolphin/os/OSReboot.h>
41#include <dolphin/os/OSExec.h>
42#include <dolphin/os/OSMemory.h>
44#include <dolphin/os/OSUtf.h>
45#include <dolphin/os/OSTimer.h>
46
47// private macro, maybe shouldn't be defined here?
48#define OFFSET(addr, align) (((u32)(addr) & ((align)-1)))
49
50#define DOLPHIN_ALIGNMENT 32
51
52// Upper words of the masks, since UIMM is only 16 bits
53#define OS_CACHED_REGION_PREFIX 0x8000
54#define OS_UNCACHED_REGION_PREFIX 0xC000
55#define OS_PHYSICAL_MASK 0x3FFF
56
57#define OS_BASE_CACHED (OS_CACHED_REGION_PREFIX << 16)
58#define OS_BASE_UNCACHED (OS_UNCACHED_REGION_PREFIX << 16)
59
60#ifdef __MWERKS__
61u32 __OSPhysicalMemSize AT_ADDRESS(OS_BASE_CACHED | 0x0028);
62volatile int __OSTVMode AT_ADDRESS(OS_BASE_CACHED | 0x00CC);
63OSThreadQueue __OSActiveThreadQueue AT_ADDRESS(OS_BASE_CACHED | 0x00DC);
64OSThread* __OSCurrentThread AT_ADDRESS(OS_BASE_CACHED | 0x00E4);
65u32 __OSSimulatedMemSize AT_ADDRESS(OS_BASE_CACHED | 0x00F0);
66u32 __OSBusClock AT_ADDRESS(OS_BASE_CACHED | 0x00F8);
67u32 __OSCoreClock AT_ADDRESS(OS_BASE_CACHED | 0x00FC);
68volatile u16 __OSDeviceCode AT_ADDRESS(OS_BASE_CACHED | 0x30E6);
69u16 __OSWirelessPadFixMode AT_ADDRESS(OS_BASE_CACHED | 0x30E0);
70
71// unknowns
72OSThread* __gUnkThread1 AT_ADDRESS(OS_BASE_CACHED | 0x00D8);
73int __gUnknown800030C0[2] AT_ADDRESS(OS_BASE_CACHED | 0x30C0);
74u8 __gUnknown800030E3 AT_ADDRESS(OS_BASE_CACHED | 0x30E3);
75#else
76#define __OSBusClock (*(u32 *)(OS_BASE_CACHED | 0x00F8))
77#define __OSCoreClock (*(u32 *)(OS_BASE_CACHED | 0x00FC))
78#endif
79
80#define OS_BUS_CLOCK __OSBusClock
81#define OS_CORE_CLOCK __OSCoreClock
82#define OS_TIMER_CLOCK (OS_BUS_CLOCK/4)
83
84#define OSTicksToSeconds(ticks) ((ticks) / (OS_TIMER_CLOCK))
85#define OSTicksToMilliseconds(ticks) ((ticks) / (OS_TIMER_CLOCK/1000))
86#define OSTicksToMicroseconds(ticks) ((ticks) * 8 / (OS_TIMER_CLOCK/125000))
87#define OSSecondsToTicks(sec) ((sec) * (OS_TIMER_CLOCK))
88#define OSMillisecondsToTicks(msec) ((msec) * (OS_TIMER_CLOCK / 1000))
89#define OSNanosecondsToTicks(nsec) (((nsec) * (OS_TIMER_CLOCK / 125000)) / 8000)
90#define OSMicrosecondsToTicks(usec) (((usec) * (OS_TIMER_CLOCK / 125000)) / 8)
91
93void OSInit(void);
94void OSRegisterVersion(const char* id);
95
96void* OSGetArenaHi(void);
97void* OSGetArenaLo(void);
98void OSSetArenaHi(void* newHi);
99void OSSetArenaLo(void* newLo);
100void* OSAllocFromArenaLo(u32 size, u32 align);
101void* OSAllocFromArenaHi(u32 size, u32 align);
102
104
105void __OSPSInit(void);
106void __OSFPRInit(void);
107u32 __OSGetDIConfig(void);
108
110
111typedef struct OSCalendarTime {
112 /* 0x00 */ int sec;
113 /* 0x04 */ int min;
114 /* 0x08 */ int hour;
115 /* 0x0C */ int mday;
116 /* 0x10 */ int mon;
117 /* 0x14 */ int year;
118 /* 0x18 */ int wday;
119 /* 0x1C */ int yday;
120 /* 0x20 */ int msec;
121 /* 0x24 */ int usec;
123
124#include <dolphin/dvd.h>
136
147
148void OSInitStopwatch(OSStopwatch* sw, char* name);
154
155OSTick OSGetTick(void);
156OSTime OSGetTime(void);
162
163#define OS_CONSOLE_MASK 0xF0000000
164#define OS_CONSOLE_RETAIL 0x00000000
165#define OS_CONSOLE_DEVELOPMENT 0x10000000
166#define OS_CONSOLE_TDEV 0x20000000
167
168#define OS_CONSOLE_RETAIL4 0x00000004
169#define OS_CONSOLE_RETAIL3 0x00000003
170#define OS_CONSOLE_RETAIL2 0x00000002
171#define OS_CONSOLE_RETAIL1 0x00000001
172#define OS_CONSOLE_TDEVHW4 0x20000007
173#define OS_CONSOLE_TDEVHW3 0x20000006
174#define OS_CONSOLE_TDEVHW2 0x20000005
175#define OS_CONSOLE_TDEVHW1 0x20000004
176#define OS_CONSOLE_DEVHW4 0x10000007
177#define OS_CONSOLE_DEVHW3 0x10000006
178#define OS_CONSOLE_DEVHW2 0x10000005
179#define OS_CONSOLE_DEVHW1 0x10000004
180#define OS_CONSOLE_MINNOW 0x10000003
181#define OS_CONSOLE_ARTHUR 0x10000002
182#define OS_CONSOLE_PC_EMULATOR 0x10000001
183#define OS_CONSOLE_EMULATOR 0x10000000
184
185#define OS_SOUND_MODE_MONO 0
186#define OS_SOUND_MODE_STEREO 1
187
188u32 OSGetSoundMode(void);
190
191__declspec(weak) void OSReport(const char* msg, ...);
192__declspec(weak) void OSVReport(const char* msg, va_list list);
193__declspec(weak) void OSPanic(const char* file, int line, const char* msg, ...);
194void OSFatal(GXColor fg, GXColor bg, const char* msg);
195
196// do these belong here?
197__declspec(weak) void OSAttention(const char* msg, ...);
198__declspec(weak) void OSReport_Error(const char* fmt, ...);
199__declspec(weak) void OSReport_FatalError(const char* fmt, ...);
200__declspec(weak) void OSReport_System(const char* fmt, ...);
201__declspec(weak) void OSReport_Warning(const char* fmt, ...);
202__declspec(weak) void OSReportDisable(void);
203__declspec(weak) void OSReportEnable(void);
204__declspec(weak) void OSReportForceEnableOff(void);
205__declspec(weak) void OSReportForceEnableOn(void);
206__declspec(weak) void OSVReport(const char* format, va_list list);
207
208#ifdef DEBUG
209#define OS_REPORT(...) OSReport(__VA_ARGS__)
210#define OS_WARNING(...) OSReport_Warning(__VA_ARGS__)
211#define OS_REPORT_ERROR(...) OSReport_Error(__VA_ARGS__)
212#define OS_PANIC(line, msg) OSPanic(__FILE__, line, msg)
213#else
214#define OS_REPORT(...)
215#define OS_WARNING(...)
216#define OS_REPORT_ERROR(...)
217#define OS_PANIC(...)
218#endif
219
224extern u8 __OSReport_enable;
225
226#define OSRoundUp32B(x) (((u32)(x) + 32 - 1) & ~(32 - 1))
227#define OSRoundDown32B(x) (((u32)(x)) & ~(32 - 1))
228
229void* OSPhysicalToCached(u32 paddr);
230void* OSPhysicalToUncached(u32 paddr);
231u32 OSCachedToPhysical(void* caddr);
232u32 OSUncachedToPhysical(void* ucaddr);
233void* OSCachedToUncached(void* caddr);
234void* OSUncachedToCached(void* ucaddr);
235
236#if !DEBUG
237#define OSPhysicalToCached(paddr) ((void*) ((u32)(OS_BASE_CACHED + (u32)(paddr))))
238#define OSPhysicalToUncached(paddr) ((void*) ((u32)(OS_BASE_UNCACHED + (u32)(paddr))))
239#define OSCachedToPhysical(caddr) ((u32) ((u32)(caddr) - OS_BASE_CACHED))
240#define OSUncachedToPhysical(ucaddr) ((u32) ((u32)(ucaddr) - OS_BASE_UNCACHED))
241#define OSCachedToUncached(caddr) ((void*) ((u8*)(caddr) + (OS_BASE_UNCACHED - OS_BASE_CACHED)))
242#define OSUncachedToCached(ucaddr) ((void*) ((u8*)(ucaddr) - (OS_BASE_UNCACHED - OS_BASE_CACHED)))
243#endif
244
245// unsorted externs
246extern OSTime __OSGetSystemTime(void);
247__declspec(weak) extern int __OSIsGcam;
249extern OSTime __OSStartTime;
250extern int __OSInIPL;
251
252// helper for assert line numbers in different revisions
253#if SDK_REVISION < 1
254 #define LINE(l0, l1, l2) (l0)
255#elif SDK_REVISION < 2
256 #define LINE(l0, l1, l2) (l1)
257#else
258 #define LINE(l0, l1, l2) (l2)
259#endif
260
261#ifdef DEBUG
262#define ASSERTLINE(line, cond) \
263 ((cond) || (OSPanic(__FILE__, line, "Failed assertion " #cond), 0))
264
265#define ASSERTMSGLINE(line, cond, msg) \
266 ((cond) || (OSPanic(__FILE__, line, msg), 0))
267
268// This is dumb but we dont have a Metrowerks way to do variadic macros in the macro to make this done in a not scrubby way.
269#define ASSERTMSG1LINE(line, cond, msg, arg1) \
270 ((cond) || (OSPanic(__FILE__, line, msg, arg1), 0))
271
272#define ASSERTMSG2LINE(line, cond, msg, arg1, arg2) \
273 ((cond) || (OSPanic(__FILE__, line, msg, arg1, arg2), 0))
274
275#define ASSERTMSGLINEV(line, cond, ...) \
276 ((cond) || (OSPanic(__FILE__, line, __VA_ARGS__), 0))
277
278#else
279#define ASSERTLINE(line, cond) (void)0
280#define ASSERTMSGLINE(line, cond, msg) (void)0
281#define ASSERTMSG1LINE(line, cond, msg, arg1) (void)0
282#define ASSERTMSG2LINE(line, cond, msg, arg1, arg2) (void)0
283#define ASSERTMSGLINEV(line, cond, ...) (void)0
284#endif
285
286#define ASSERT(cond) ASSERTLINE(__LINE__, cond)
287
288inline s16 __OSf32tos16(register f32 inF) {
289 register s16 out;
290 u32 tmp;
291 register u32* tmpPtr = &tmp;
292 // clang-format off
293#ifdef __MWERKS__
294 asm {
295 psq_st inF, 0(tmpPtr), 0x1, 5
296 lha out, 0(tmpPtr)
297 }
298#endif
299 // clang-format on
300
301 return out;
302}
303
304inline void OSf32tos16(f32* f, s16* out) {
305 *out = __OSf32tos16(*f);
306}
307
308inline u8 __OSf32tou8(register f32 inF) {
309 register u8 out;
310 u32 tmp;
311 register u32* tmpPtr = &tmp;
312 // clang-format off
313#ifdef __MWERKS__
314 asm {
315 psq_st inF, 0(tmpPtr), 0x1, 2
316 lbz out, 0(tmpPtr)
317 }
318#endif
319 // clang-format on
320
321 return out;
322}
323
324inline void OSf32tou8(f32* f, u8* out) {
325 *out = __OSf32tou8(*f);
326}
327
328static inline void OSInitFastCast(void) {
329 // clang-format off
330#ifdef __MWERKS__
331 asm {
332 li r3, 4
333 oris r3, r3, 4
334 mtspr 0x392, r3
335 li r3, 5
336 oris r3, r3, 5
337 mtspr 0x393, r3
338 li r3, 6
339 oris r3, r3, 6
340 mtspr 0x394, r3
341 li r3, 7
342 oris r3, r3, 7
343 mtspr 0x395, r3
344 }
345#endif
346 // clang-format on
347}
348
349#ifdef __cplusplus
350}
351#endif
352
353#endif
u32 mode
Definition GXTev.c:56
static OSContext context
Definition JUTException.cpp:181
void OSVReport(const char *msg, va_list list)
Definition OSError.c:19
void OSPanic(const char *file, int line, const char *msg,...)
Definition OSError.c:23
void OSReport(const char *msg,...)
Definition OSError.c:12
u8 __OSException
Definition OSException.h:31
BOOL __OSIsGcam
Definition OS.c:63
unsigned int size
Definition __os.h:106
s16 name
Definition d_a_e_pz.cpp:1764
static char * tmp[5]
Definition d_a_npc_ashB.cpp:231
void OSReportForceEnableOn()
Definition m_Do_printf.cpp:58
void OSReportEnable()
Definition m_Do_printf.cpp:53
void OSReport_System(const char *fmt,...)
Definition m_Do_printf.cpp:211
void OSReport_FatalError(const char *fmt,...)
Definition m_Do_printf.cpp:163
void OSReport_Error(const char *fmt,...)
Definition m_Do_printf.cpp:179
void OSReportForceEnableOff()
Definition m_Do_printf.cpp:63
void OSAttention(const char *fmt,...)
Definition m_Do_printf.cpp:40
void OSReportDisable()
Definition m_Do_printf.cpp:48
void OSReport_Warning(const char *fmt,...)
Definition m_Do_printf.cpp:195
BOOL OSDisableInterrupts(void)
Definition OSInterrupt.c:85
void OSf32tos16(f32 *f, s16 *out)
Definition os.h:304
void OSReportInit(void)
Definition m_Do_printf.cpp:89
OSTime OSGetTime(void)
Definition OSTime.c:14
BOOL OSRestoreInterrupts(BOOL level)
void __OSPSInit(void)
Definition OS.c:605
va_list list
Definition os.h:192
u32 OSUncachedToPhysical(void *ucaddr)
Definition OSAddress.c:26
OSExecParams __OSRebootParams
Definition OS.c:43
void OSTicksToCalendarTime(OSTime ticks, OSCalendarTime *td)
Definition OSTime.c:137
u32 OSGetPhysicalMemSize(void)
Definition OSMemory.c:19
int const char * msg
Definition os.h:193
u8 __OSReport_System_disable
Definition m_Do_printf.cpp:18
struct OSCalendarTime OSCalendarTime
s64 OSTime
Definition os.h:16
void OSSetSoundMode(u32 mode)
Definition OSRtc.c:306
int line
Definition os.h:193
BOOL OSEnableInterrupts(void)
Definition OSInterrupt.c:96
int const char void OSFatal(GXColor fg, GXColor bg, const char *msg)
Definition OSFatal.c:159
OSTime __OSStartTime
Definition OS.c:57
void * OSCachedToUncached(void *caddr)
Definition OSAddress.c:31
void OSResetStopwatch(OSStopwatch *sw)
Definition OSStopwatch.c:44
void * OSAllocFromArenaHi(u32 size, u32 align)
Definition OSArena.c:42
void OSRegisterVersion(const char *id)
Definition OS.c:629
u32 OSGetSoundMode(void)
Definition OSRtc.c:298
u32 OSTick
Definition os.h:17
void * OSPhysicalToCached(u32 paddr)
Definition OSAddress.c:11
u8 __OSf32tou8(register f32 inF)
Definition os.h:308
OSTime OSCheckStopwatch(OSStopwatch *sw)
Definition OSStopwatch.c:34
u32 __OSPhysicalMemSize AT_ADDRESS(OS_BASE_CACHED|0x0028)
void OSStopStopwatch(OSStopwatch *sw)
Definition OSStopwatch.c:17
u8 __OSReport_Warning_disable
Definition m_Do_printf.cpp:16
u8 __OSReport_disable
Definition m_Do_printf.cpp:12
void * OSPhysicalToUncached(u32 paddr)
Definition OSAddress.c:16
void OSInitStopwatch(OSStopwatch *sw, char *name)
Definition OSStopwatch.c:4
void __OSFPRInit(void)
Definition OS.c:86
void OSVAttention(const char *fmt, va_list args)
Definition m_Do_printf.cpp:35
void * OSGetArenaLo(void)
Definition OSArena.c:16
__declspec(weak) void OSReport(const char *msg
u32 OSGetConsoleType(void)
Definition OS.c:181
s16 __OSf32tos16(register f32 inF)
Definition os.h:288
void OSSwitchFiberEx(u32, u32, u32, u32, u32, u32)
Definition m_Do_printf.cpp:24
void OSStartStopwatch(OSStopwatch *sw)
Definition OSStopwatch.c:12
u32 OSCachedToPhysical(void *caddr)
Definition OSAddress.c:21
struct OSBootInfo_s OSBootInfo
OSTick OSGetTick(void)
Definition OSTime.c:29
void OSSetArenaHi(void *newHi)
Definition OSArena.c:22
void * OSAllocFromArenaLo(u32 size, u32 align)
Definition OSArena.c:30
int __OSInIPL
Definition OS.c:58
void * OSGetArenaHi(void)
Definition OSArena.c:10
u8 __OSReport_enable
Definition m_Do_printf.cpp:21
OSTime OSCalendarTimeToTicks(OSCalendarTime *td)
Definition OSTime.c:173
struct OSStopwatch OSStopwatch
void OSSetArenaLo(void *newLo)
Definition OSArena.c:26
u32 __OSGetDIConfig(void)
Definition OS.c:625
OSTime __OSGetSystemTime(void)
Definition OSTime.c:59
void OSf32tou8(f32 *f, u8 *out)
Definition os.h:324
void OSDefaultExceptionHandler(__OSException exception, OSContext *context)
void OSDumpStopwatch(OSStopwatch *sw)
Definition OSStopwatch.c:48
void * OSUncachedToCached(void *ucaddr)
Definition OSAddress.c:36
static void OSInitFastCast(void)
Definition os.h:328
u8 __OSReport_Error_disable
Definition m_Do_printf.cpp:14
void OSInit(void)
Definition OS.c:230
Definition dvd.h:68
Definition os.h:125
u32 version
Definition os.h:128
u32 FSTMaxLength
Definition os.h:134
DVDDiskID DVDDiskID
Definition os.h:126
void * FSTLocation
Definition os.h:133
void * arenaHi
Definition os.h:132
u32 magic
Definition os.h:127
u32 consoleType
Definition os.h:130
u32 memorySize
Definition os.h:129
void * arenaLo
Definition os.h:131
Definition os.h:111
int msec
Definition os.h:120
int mday
Definition os.h:115
int sec
Definition os.h:112
int yday
Definition os.h:119
int mon
Definition os.h:116
int wday
Definition os.h:118
int year
Definition os.h:117
int usec
Definition os.h:121
int min
Definition os.h:113
int hour
Definition os.h:114
Definition OSContext.h:137
Definition OSExec.h:10
Definition os.h:137
OSTime min
Definition os.h:141
OSTime last
Definition os.h:143
u32 hits
Definition os.h:139
OSTime max
Definition os.h:142
char * name
Definition os.h:138
u32 _padding
Definition os.h:145
BOOL running
Definition os.h:144
OSTime total
Definition os.h:140
Definition OSThread.h:19
Definition OSThread.h:39
Definition d_menu_dmap_map.cpp:90
Definition fdlibm.h:73
int BOOL
Definition types.h:30
unsigned long u32
Definition types.h:9
signed short int s16
Definition types.h:6
signed long long int s64
Definition types.h:10
float f32
Definition types.h:22
unsigned short int u16
Definition types.h:7
unsigned char u8
Definition types.h:5