/* 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 . * * 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 * . * * Ardix comes with ABSOLUTELY NO WARRANTY, to the extent * permitted by applicable law. See the CNPLv6+ for details. */