1#ifndef _DOLPHIN_OSINTERRUPT_H_
2#define _DOLPHIN_OSINTERRUPT_H_
4#ifdef __REVOLUTION_SDK__
17#define __OS_INTERRUPT_MEM_0 0
18#define __OS_INTERRUPT_MEM_1 1
19#define __OS_INTERRUPT_MEM_2 2
20#define __OS_INTERRUPT_MEM_3 3
21#define __OS_INTERRUPT_MEM_ADDRESS 4
22#define __OS_INTERRUPT_DSP_AI 5
23#define __OS_INTERRUPT_DSP_ARAM 6
24#define __OS_INTERRUPT_DSP_DSP 7
25#define __OS_INTERRUPT_AI_AI 8
26#define __OS_INTERRUPT_EXI_0_EXI 9
27#define __OS_INTERRUPT_EXI_0_TC 10
28#define __OS_INTERRUPT_EXI_0_EXT 11
29#define __OS_INTERRUPT_EXI_1_EXI 12
30#define __OS_INTERRUPT_EXI_1_TC 13
31#define __OS_INTERRUPT_EXI_1_EXT 14
32#define __OS_INTERRUPT_EXI_2_EXI 15
33#define __OS_INTERRUPT_EXI_2_TC 16
34#define __OS_INTERRUPT_PI_CP 17
35#define __OS_INTERRUPT_PI_PE_TOKEN 18
36#define __OS_INTERRUPT_PI_PE_FINISH 19
37#define __OS_INTERRUPT_PI_SI 20
38#define __OS_INTERRUPT_PI_DI 21
39#define __OS_INTERRUPT_PI_RSW 22
40#define __OS_INTERRUPT_PI_ERROR 23
41#define __OS_INTERRUPT_PI_VI 24
42#define __OS_INTERRUPT_PI_DEBUG 25
43#define __OS_INTERRUPT_PI_HSP 26
44#define __OS_INTERRUPT_MAX 32
46#define OS_INTERRUPTMASK(interrupt) (0x80000000u >> (interrupt))
48#define OS_INTERRUPTMASK_MEM_0 OS_INTERRUPTMASK(__OS_INTERRUPT_MEM_0)
49#define OS_INTERRUPTMASK_MEM_1 OS_INTERRUPTMASK(__OS_INTERRUPT_MEM_1)
50#define OS_INTERRUPTMASK_MEM_2 OS_INTERRUPTMASK(__OS_INTERRUPT_MEM_2)
51#define OS_INTERRUPTMASK_MEM_3 OS_INTERRUPTMASK(__OS_INTERRUPT_MEM_3)
52#define OS_INTERRUPTMASK_MEM_ADDRESS OS_INTERRUPTMASK(__OS_INTERRUPT_MEM_ADDRESS)
53#define OS_INTERRUPTMASK_MEM_RESET \
54 (OS_INTERRUPTMASK_MEM_0 | OS_INTERRUPTMASK_MEM_1 | OS_INTERRUPTMASK_MEM_2 | \
55 OS_INTERRUPTMASK_MEM_3)
56#define OS_INTERRUPTMASK_MEM \
57 (OS_INTERRUPTMASK_MEM_0 | OS_INTERRUPTMASK_MEM_1 | OS_INTERRUPTMASK_MEM_2 | \
58 OS_INTERRUPTMASK_MEM_3 | OS_INTERRUPTMASK_MEM_ADDRESS)
59#define OS_INTERRUPTMASK_DSP_AI OS_INTERRUPTMASK(__OS_INTERRUPT_DSP_AI)
60#define OS_INTERRUPTMASK_DSP_ARAM OS_INTERRUPTMASK(__OS_INTERRUPT_DSP_ARAM)
61#define OS_INTERRUPTMASK_DSP_DSP OS_INTERRUPTMASK(__OS_INTERRUPT_DSP_DSP)
62#define OS_INTERRUPTMASK_DSP \
63 (OS_INTERRUPTMASK_DSP_AI | OS_INTERRUPTMASK_DSP_ARAM | OS_INTERRUPTMASK_DSP_DSP)
64#define OS_INTERRUPTMASK_AI_AI OS_INTERRUPTMASK(__OS_INTERRUPT_AI_AI)
65#define OS_INTERRUPTMASK_AI (OS_INTERRUPTMASK_AI_AI)
66#define OS_INTERRUPTMASK_EXI_0_EXI OS_INTERRUPTMASK(__OS_INTERRUPT_EXI_0_EXI)
67#define OS_INTERRUPTMASK_EXI_0_TC OS_INTERRUPTMASK(__OS_INTERRUPT_EXI_0_TC)
68#define OS_INTERRUPTMASK_EXI_0_EXT OS_INTERRUPTMASK(__OS_INTERRUPT_EXI_0_EXT)
69#define OS_INTERRUPTMASK_EXI_0 \
70 (OS_INTERRUPTMASK_EXI_0_EXI | OS_INTERRUPTMASK_EXI_0_TC | OS_INTERRUPTMASK_EXI_0_EXT)
71#define OS_INTERRUPTMASK_EXI_1_EXI OS_INTERRUPTMASK(__OS_INTERRUPT_EXI_1_EXI)
72#define OS_INTERRUPTMASK_EXI_1_TC OS_INTERRUPTMASK(__OS_INTERRUPT_EXI_1_TC)
73#define OS_INTERRUPTMASK_EXI_1_EXT OS_INTERRUPTMASK(__OS_INTERRUPT_EXI_1_EXT)
74#define OS_INTERRUPTMASK_EXI_1 \
75 (OS_INTERRUPTMASK_EXI_1_EXI | OS_INTERRUPTMASK_EXI_1_TC | OS_INTERRUPTMASK_EXI_1_EXT)
76#define OS_INTERRUPTMASK_EXI_2_EXI OS_INTERRUPTMASK(__OS_INTERRUPT_EXI_2_EXI)
77#define OS_INTERRUPTMASK_EXI_2_TC OS_INTERRUPTMASK(__OS_INTERRUPT_EXI_2_TC)
78#define OS_INTERRUPTMASK_EXI_2 (OS_INTERRUPTMASK_EXI_2_EXI | OS_INTERRUPTMASK_EXI_2_TC)
79#define OS_INTERRUPTMASK_EXI \
80 (OS_INTERRUPTMASK_EXI_0_EXI | OS_INTERRUPTMASK_EXI_0_TC | OS_INTERRUPTMASK_EXI_0_EXT | \
81 OS_INTERRUPTMASK_EXI_1_EXI | OS_INTERRUPTMASK_EXI_1_TC | OS_INTERRUPTMASK_EXI_1_EXT | \
82 OS_INTERRUPTMASK_EXI_2_EXI | OS_INTERRUPTMASK_EXI_2_TC)
83#define OS_INTERRUPTMASK_PI_PE_TOKEN OS_INTERRUPTMASK(__OS_INTERRUPT_PI_PE_TOKEN)
84#define OS_INTERRUPTMASK_PI_PE_FINISH OS_INTERRUPTMASK(__OS_INTERRUPT_PI_PE_FINISH)
85#define OS_INTERRUPTMASK_PI_PE (OS_INTERRUPTMASK_PI_PE_TOKEN | OS_INTERRUPTMASK_PI_PE_FINISH)
86#define OS_INTERRUPTMASK_PI_CP OS_INTERRUPTMASK(__OS_INTERRUPT_PI_CP)
87#define OS_INTERRUPTMASK_PI_SI OS_INTERRUPTMASK(__OS_INTERRUPT_PI_SI)
88#define OS_INTERRUPTMASK_PI_DI OS_INTERRUPTMASK(__OS_INTERRUPT_PI_DI)
89#define OS_INTERRUPTMASK_PI_RSW OS_INTERRUPTMASK(__OS_INTERRUPT_PI_RSW)
90#define OS_INTERRUPTMASK_PI_ERROR OS_INTERRUPTMASK(__OS_INTERRUPT_PI_ERROR)
91#define OS_INTERRUPTMASK_PI_VI OS_INTERRUPTMASK(__OS_INTERRUPT_PI_VI)
92#define OS_INTERRUPTMASK_PI_DEBUG OS_INTERRUPTMASK(__OS_INTERRUPT_PI_DEBUG)
93#define OS_INTERRUPTMASK_PI_HSP OS_INTERRUPTMASK(__OS_INTERRUPT_PI_HSP)
94#define OS_INTERRUPTMASK_PI \
95 (OS_INTERRUPTMASK_PI_CP | OS_INTERRUPTMASK_PI_SI | OS_INTERRUPTMASK_PI_DI | \
96 OS_INTERRUPTMASK_PI_RSW | OS_INTERRUPTMASK_PI_ERROR | OS_INTERRUPTMASK_PI_VI | \
97 OS_INTERRUPTMASK_PI_PE_TOKEN | OS_INTERRUPTMASK_PI_PE_FINISH | OS_INTERRUPTMASK_PI_DEBUG | \
98 OS_INTERRUPTMASK_PI_HSP)
static OSContext context
Definition JUTException.cpp:157
u8 __OSException
Definition OSException.h:34
OSInterruptMask __OSUnmaskInterrupts(OSInterruptMask mask)
Definition OSInterrupt.c:338
s16 __OSInterrupt
Definition OSInterrupt.h:14
u32 OSInterruptMask
Definition OSInterrupt.h:15
OSInterruptMask __OSMaskInterrupts(OSInterruptMask mask)
Definition OSInterrupt.c:319
s64 OSTime
Definition os.h:19
unsigned long u32
Definition types.h:12
signed short int s16
Definition types.h:9
void(* __OSInterruptHandler)(__OSInterrupt interrupt, OSContext *context)
Definition OSInterrupt.h:120
volatile u32 __OSLastInterruptSrr0
Definition OSInterrupt.c:13
__OSInterruptHandler __OSSetInterruptHandler(__OSInterrupt interrupt, __OSInterruptHandler handler)
Definition OSInterrupt.c:123
OSInterruptMask OSGetInterruptMask(void)
Definition OSInterrupt.c:297
volatile OSTime __OSLastInterruptTime
Definition OSInterrupt.c:11
OSInterruptMask OSSetInterruptMask(OSInterruptMask mask)
Definition OSInterrupt.c:301
volatile __OSInterrupt __OSLastInterrupt
Definition OSInterrupt.c:12
void __OSDispatchInterrupt(__OSException exception, OSContext *context)
Definition OSInterrupt.c:357
__OSInterruptHandler __OSGetInterruptHandler(__OSInterrupt interrupt)
Definition OSInterrupt.c:134
Definition OSContext.h:140