diff options
author | red031000 <rubenru09@aol.com> | 2020-06-12 18:08:19 +0100 |
---|---|---|
committer | red031000 <rubenru09@aol.com> | 2020-06-12 18:08:19 +0100 |
commit | 5c34c97254b35f93d9254e63265446f9f7d50817 (patch) | |
tree | 5c124f89c7770a34c20a968cf05456e75d36cae1 /arm7 | |
parent | e672765bfe4b9272e91309872b01730dc3b6d3f7 (diff) |
arm7 OS_reset
Diffstat (limited to 'arm7')
-rw-r--r-- | arm7/asm/OS_reset.s | 100 | ||||
-rw-r--r-- | arm7/lib/include/OS_init.h | 2 | ||||
-rw-r--r-- | arm7/lib/include/OS_interrupt.h | 6 | ||||
-rw-r--r-- | arm7/lib/include/OS_reset.h | 14 | ||||
-rw-r--r-- | arm7/lib/include/PXI_fifo.h | 6 | ||||
-rw-r--r-- | arm7/lib/src/OS_init.c | 1 | ||||
-rw-r--r-- | arm7/lib/src/OS_reset.c | 59 |
7 files changed, 87 insertions, 101 deletions
diff --git a/arm7/asm/OS_reset.s b/arm7/asm/OS_reset.s deleted file mode 100644 index b2a8ffe6..00000000 --- a/arm7/asm/OS_reset.s +++ /dev/null @@ -1,100 +0,0 @@ - .include "asm/macros.inc" - .include "global.inc" - - .section .bss - - .global _03807950 -_03807950: ;0x03807950 - .space 0x03807954 - 0x03807950 - - .global _03807954 -_03807954: ;0x03807954 - .space 0x03807958 - 0x03807954 - - .section .text - - arm_func_start OS_ResetSystem -OS_ResetSystem: ; 0x037FB0E0 - stmfd sp!, {lr} - sub sp, sp, #4 - mov r0, #0 - bl MI_StopDma - mov r0, #1 - bl MI_StopDma - mov r0, #2 - bl MI_StopDma - mov r0, #3 - bl MI_StopDma - mov r0, #262144 ; 0x40000 - bl OS_SetIrqMask - mvn r0, #0 - bl OS_ResetRequestIrqMask - bl SND_Shutdown - mov r0, #16 - bl OSi_SendToPxi - bl FUN_038073EC - add sp, sp, #4 - ldmia sp!, {lr} - bx lr - - arm_func_start OSi_SendToPxi -OSi_SendToPxi: ; 0x037FB134 - stmdb sp!, {r4, r5, r6, lr} - mov r6, r0, lsl #8 - mov r5, #12 - mov r4, #0 -_037FB144: - mov r0, r5 - mov r1, r6 - mov r2, r4 - bl PXI_SendWordByFifo - cmp r0, #0 - bne _037FB144 - ldmia sp!, {r4, r5, r6, lr} - bx lr - - arm_func_start OSi_CommonCallback -OSi_CommonCallback: ; 0x037FB164 - stmfd sp!, {lr} - sub sp, sp, #4 - and r0, r1, #32512 ; 0x7f00 - mov r0, r0, lsl #8 - mov r0, r0, lsr #16 - cmp r0, #16 - moveq r1, #1 - ldreq r0, _037FB19C ; =_03807954 - streqh r1, [r0] - beq _037FB190 - bl OS_Terminate -_037FB190: - add sp, sp, #4 - ldmia sp!, {lr} - bx lr -_037FB19C: .word _03807954 - - arm_func_start OS_IsResetOccurred -OS_IsResetOccurred: ; 0x037FB1A0 - ldr r0, _037FB1AC ; =_03807954 - ldrh r0, [r0] - bx lr -_037FB1AC: .word _03807954 - - arm_func_start OS_InitReset -OS_InitReset: ; 0x037FB1B0 - stmfd sp!, {lr} - sub sp, sp, #4 - ldr r0, _037FB1E8 ; =_03807950 - ldrh r1, [r0] - cmp r1, #0 - bne _037FB1DC - mov r1, #1 - strh r1, [r0] - mov r0, #12 - ldr r1, _037FB1EC ; =OSi_CommonCallback - bl PXI_SetFifoRecvCallback -_037FB1DC: - add sp, sp, #4 - ldmia sp!, {lr} - bx lr -_037FB1E8: .word _03807950 -_037FB1EC: .word OSi_CommonCallback diff --git a/arm7/lib/include/OS_init.h b/arm7/lib/include/OS_init.h index 9c9b1f93..c90740c2 100644 --- a/arm7/lib/include/OS_init.h +++ b/arm7/lib/include/OS_init.h @@ -4,6 +4,8 @@ #include "nitro/types.h" #include "OS_system.h" #include "OS_arena.h" +#include "OS_alloc.h" +#include "OS_reset.h" void OS_Init(void); diff --git a/arm7/lib/include/OS_interrupt.h b/arm7/lib/include/OS_interrupt.h new file mode 100644 index 00000000..afcb9b5f --- /dev/null +++ b/arm7/lib/include/OS_interrupt.h @@ -0,0 +1,6 @@ +#ifndef POKEDIAMOND_ARM7_OS_INTERRUPT_H +#define POKEDIAMOND_ARM7_OS_INTERRUPT_H + +#include "nitro/OS_interrupt_shared.h" + +#endif //POKEDIAMOND_ARM7_OS_INTERRUPT_H diff --git a/arm7/lib/include/OS_reset.h b/arm7/lib/include/OS_reset.h new file mode 100644 index 00000000..f643dd58 --- /dev/null +++ b/arm7/lib/include/OS_reset.h @@ -0,0 +1,14 @@ +#ifndef POKEDIAMOND_ARM7_OS_RESET_H +#define POKEDIAMOND_ARM7_OS_RESET_H + +#include "nitro/types.h" +#include "nitro/OS_reset_shared.h" +#include "PXI_fifo.h" + +void OS_InitReset(void); +BOOL OS_IsResetOccurred(void); +static void OSi_CommonCallback(PXIFifoTag tag, u32 data, BOOL err); +static void OSi_SendToPxi(u16 data); +void OS_ResetSystem(void); + +#endif //POKEDIAMOND_ARM7_OS_RESET_H diff --git a/arm7/lib/include/PXI_fifo.h b/arm7/lib/include/PXI_fifo.h new file mode 100644 index 00000000..6d634f72 --- /dev/null +++ b/arm7/lib/include/PXI_fifo.h @@ -0,0 +1,6 @@ +#ifndef POKEDIAMOND_ARM7_PXI_FIFO_H +#define POKEDIAMOND_ARM7_PXI_FIFO_H + +#include "nitro/PXI_fifo_shared.h" + +#endif //POKEDIAMOND_ARM7_PXI_FIFO_H diff --git a/arm7/lib/src/OS_init.c b/arm7/lib/src/OS_init.c index f4972638..583bb75e 100644 --- a/arm7/lib/src/OS_init.c +++ b/arm7/lib/src/OS_init.c @@ -7,7 +7,6 @@ extern void OS_InitIrqTable(void); extern void OS_InitTick(void); extern void OS_InitAlarm(void); extern void OS_InitThread(void); -extern void OS_InitReset(void); extern void CTRDG_Init(void); ARM_FUNC void OS_Init(void) diff --git a/arm7/lib/src/OS_reset.c b/arm7/lib/src/OS_reset.c new file mode 100644 index 00000000..c40fcff3 --- /dev/null +++ b/arm7/lib/src/OS_reset.c @@ -0,0 +1,59 @@ +#include "function_target.h" +#include "OS_reset.h" +#include "OS_interrupt.h" + +static u16 OSi_IsInitReset = 0; +vu16 OSi_IsResetOccurred = 0; + +extern void MI_StopDma(u32 dma); +extern OSIrqMask OS_SetIrqMask(OSIrqMask mask); +extern OSIrqMask OS_ResetRequestIrqMask(OSIrqMask mask); +extern void SND_Shutdown(void); +extern void PXI_SetFifoRecvCallback(u32 param1, void* callback); +extern void OS_Terminate(void); +extern u32 PXI_SendWordByFifo(u32 param1, u32 data, u32 param2); +extern void FUN_038073EC(void); //OSi_DoResetSystem, in wram + +ARM_FUNC void OS_InitReset(void) +{ + if (OSi_IsInitReset) + return; + OSi_IsInitReset = TRUE; + + PXI_SetFifoRecvCallback(PXI_FIFO_TAG_OS, OSi_CommonCallback); +} + +ARM_FUNC BOOL OS_IsResetOccurred(void) +{ + return OSi_IsResetOccurred; +} + +ARM_FUNC static void OSi_CommonCallback(PXIFifoTag tag, u32 data, BOOL err) +{ +#pragma unused(tag, err) + u16 command = (u16)((data & OS_PXI_COMMAND_MASK) >> OS_PXI_COMMAND_SHIFT); + if (command == OS_PXI_COMMAND_RESET) + { + OSi_IsResetOccurred = TRUE; + return; + } + OS_Terminate(); +} + +ARM_FUNC static void OSi_SendToPxi(u16 data) +{ + while (PXI_SendWordByFifo(PXI_FIFO_TAG_OS, (u32) data << 0x8, FALSE)) {} +} + +ARM_FUNC void OS_ResetSystem(void) { + MI_StopDma(0); + MI_StopDma(1); + MI_StopDma(2); + MI_StopDma(3); + + (void)OS_SetIrqMask(0x40000); + (void)OS_ResetRequestIrqMask((u32)~0); + SND_Shutdown(); + OSi_SendToPxi(OS_PXI_COMMAND_RESET); + FUN_038073EC(); //OSi_DoResetSystem, in wram +} |