mini/irq_asm.S

55 lines
976 B
ArmAsm
Raw Normal View History

2009-04-13 22:13:45 +02:00
/*
mini - a Free Software replacement for the Nintendo/BroadOn IOS.
2009-04-13 23:00:22 +02:00
IRQ support
2009-04-13 22:13:45 +02:00
Copyright (C) 2008, 2009 Hector Martin "marcan" <marcan@marcansoft.com>
2009-05-11 07:53:16 +02:00
# This code is licensed to you under the terms of the GNU GPL, version 2;
# see file COPYING or http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt
2009-04-13 22:13:45 +02:00
*/
2009-05-11 07:53:16 +02:00
2009-01-08 23:27:22 +01:00
#include "hollywood.h"
#include "irq.h"
.globl v_irq
.globl irq_setup_stack
.globl irq_kill
.globl irq_restore
.extern __irqstack_addr
.extern irq_handler
irq_setup_stack:
@ Switch to IRQ mode
mrs r0, cpsr
2009-01-16 08:47:49 +01:00
msr cpsr_c, #0xd2
2009-01-08 23:27:22 +01:00
@ Setup interrupt stack
2009-01-16 08:47:49 +01:00
ldr sp, =__irqstack_addr
2009-01-08 23:27:22 +01:00
@ Restore mode
2009-01-16 08:47:49 +01:00
msr cpsr_c, r0
2009-01-08 23:27:22 +01:00
bx lr
v_irq:
push {r0-r3, r9, r12, lr}
blx irq_handler
pop {r0-r3, r9, r12, lr}
subs pc, lr, #4
irq_kill:
mrs r1, cpsr
and r0, r1, #(CPSR_IRQDIS|CPSR_FIQDIS)
orr r1, r1, #(CPSR_IRQDIS|CPSR_FIQDIS)
2009-01-16 08:47:49 +01:00
msr cpsr_c, r1
2009-01-08 23:27:22 +01:00
bx lr
irq_restore:
mrs r1, cpsr
bic r1, r1, #(CPSR_IRQDIS|CPSR_FIQDIS)
orr r1, r1, r0
2009-01-16 08:47:49 +01:00
msr cpsr_c, r1
2009-01-08 23:27:22 +01:00
bx lr
2009-04-13 22:13:45 +02:00