2020-04-22 04:09:50 +02:00
|
|
|
/****************************************************************************
|
2020-04-26 18:35:35 +02:00
|
|
|
* arch/arm/src/armv8-m/gnu/arm_signal_handler.S
|
2020-04-22 04:09:50 +02:00
|
|
|
*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the
|
|
|
|
* License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
|
|
|
#include <arch/syscall.h>
|
|
|
|
|
|
|
|
#if defined(CONFIG_BUILD_PROTECTED) && !defined(__KERNEL__)
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* File info
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
.syntax unified
|
|
|
|
.thumb
|
|
|
|
.cpu cortex-m3
|
2020-04-26 18:35:35 +02:00
|
|
|
.file "arm_signal_handler.S"
|
2020-04-22 04:09:50 +02:00
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Private Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Public Functions
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Name: up_signal_handler
|
|
|
|
*
|
|
|
|
* Description:
|
|
|
|
* This function is the user-space, signal handler trampoline function. It
|
|
|
|
* is called from up_signal_dispatch() in user-mode.
|
|
|
|
*
|
|
|
|
* R0-R3, R11 - volatile registers need not be preserved.
|
|
|
|
* R4-R10 - static registers must be preserved
|
|
|
|
* R12-R14 - LR and SP must be preserved
|
|
|
|
*
|
|
|
|
* Input Parameters:
|
|
|
|
* R0 = sighand
|
|
|
|
* The address user-space signal handling function
|
|
|
|
* R1-R3 = signo, info, and ucontext
|
|
|
|
* Standard arguments to be passed to the signal handling function.
|
|
|
|
*
|
|
|
|
* Returned Value:
|
|
|
|
* None. This function does not return in the normal sense. It returns
|
|
|
|
* via the SYS_signal_handler_return (see svcall.h)
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
.text
|
|
|
|
.thumb_func
|
|
|
|
.globl up_signal_handler
|
|
|
|
.type up_signal_handler, function
|
|
|
|
up_signal_handler:
|
|
|
|
|
|
|
|
/* Save some register */
|
|
|
|
|
|
|
|
push {lr} /* Save LR on the stack */
|
|
|
|
|
|
|
|
/* Call the signal handler */
|
|
|
|
|
|
|
|
mov ip, r0 /* IP=sighand */
|
|
|
|
mov r0, r1 /* R0=signo */
|
|
|
|
mov r1, r2 /* R1=info */
|
|
|
|
mov r2, r3 /* R2=ucontext */
|
|
|
|
blx ip /* Call the signal handler */
|
|
|
|
|
|
|
|
/* Restore the registers */
|
|
|
|
|
|
|
|
pop {r2} /* Recover LR in R2 */
|
|
|
|
mov lr, r2 /* Restore LR */
|
|
|
|
|
|
|
|
/* Execute the SYS_signal_handler_return SVCall (will not return) */
|
|
|
|
|
|
|
|
mov r0, #SYS_signal_handler_return
|
|
|
|
svc 0
|
|
|
|
nop
|
|
|
|
|
|
|
|
.size up_signal_handler, .-up_signal_handler
|
|
|
|
.end
|
|
|
|
|
|
|
|
#endif /* CONFIG_BUILD_PROTECTED && !__KERNEL__ */
|