ardix/arch/at91sam3x8e/irq_svc.S

50 lines
1.1 KiB
ArmAsm

/* See the end of this file for copyright, license, and warranty information. */
.include "asm.S"
.text
.extern arch_enter
/* void irq_svc(void); */
func_begin irq_svc
/*
* Syscalls on Cortex-M use the following parameter calling convention:
*
* number: r7
* rval: r0
* arg1: r0
* arg2: r1
* arg3: r2
* arg4: r3
* arg5: r4
* arg6: r5
*/
/*
* like in irq_pend_sv, we save everything on the stack to make early
* process switching possible in case the syscall is blocking.
*/
push {r3-r11,lr} /* r4-r7 */
mov r0, sp
bl arch_enter /* arch_enter(sp); */
pop {r3-r11,lr}
bx lr
func_end irq_svc
/*
* This file is part of Ardix.
* Copyright (c) 2020, 2021 Felix Kopp <owo@fef.moe>.
*
* Ardix is non-violent software: you may only use, redistribute,
* and/or modify it under the terms of the CNPLv6+ as found in
* the LICENSE file in the source code root directory or at
* <https://git.pixie.town/thufie/CNPL>.
*
* Ardix comes with ABSOLUTELY NO WARRANTY, to the extent
* permitted by applicable law. See the CNPLv6+ for details.
*/