7138f340b2
This patch focuses on the ARM64 general context handling code. The modifications are aimed at enhancing performance by simplifying context save/restore operations. Changes include: - Adjusted stack alignment in `arch_set_thread_context` function. - Updated `lwp_gcc.S` to reset frame pointer and link register. - Refined `rt_hw_backtrace_frame_unwind` to handle user space address checks. - Added `GET_THREAD_SELF` macro in `asm-generic.h`. - Simplified context saving/restoring in `context_gcc.h` and related files. - Optimized `rt_hw_context_switch_interrupt` and related assembly routines. Signed-off-by: Shell <smokewood@qq.com>
61 lines
1.4 KiB
C
61 lines
1.4 KiB
C
/*
|
|
* Copyright (c) 2006-2024, RT-Thread Development Team
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*
|
|
* Change Logs:
|
|
* Date Author Notes
|
|
* 2024-03-25 Shell Trimming unecessary ops and
|
|
* improve the performance of ctx switch
|
|
*/
|
|
|
|
#ifndef __ARM64_CONTEXT_H__
|
|
#define __ARM64_CONTEXT_H__
|
|
|
|
#include "../include/context_gcc.h"
|
|
|
|
#include <rtconfig.h>
|
|
#include <asm-generic.h>
|
|
#include <asm-fpu.h>
|
|
#include <armv8.h>
|
|
|
|
.macro RESTORE_CONTEXT_SWITCH
|
|
_RESTORE_CONTEXT_SWITCH
|
|
.endm
|
|
|
|
.macro RESTORE_IRQ_CONTEXT
|
|
ldp x2, x3, [sp], #0x10 /* SPSR and ELR. */
|
|
|
|
tst x3, #0x1f
|
|
msr spsr_el1, x3
|
|
msr elr_el1, x2
|
|
|
|
ldp x29, x30, [sp], #0x10
|
|
msr sp_el0, x29
|
|
ldp x28, x29, [sp], #0x10
|
|
msr fpcr, x28
|
|
msr fpsr, x29
|
|
ldp x28, x29, [sp], #0x10
|
|
ldp x26, x27, [sp], #0x10
|
|
ldp x24, x25, [sp], #0x10
|
|
ldp x22, x23, [sp], #0x10
|
|
ldp x20, x21, [sp], #0x10
|
|
ldp x18, x19, [sp], #0x10
|
|
ldp x16, x17, [sp], #0x10
|
|
ldp x14, x15, [sp], #0x10
|
|
ldp x12, x13, [sp], #0x10
|
|
ldp x10, x11, [sp], #0x10
|
|
ldp x8, x9, [sp], #0x10
|
|
ldp x6, x7, [sp], #0x10
|
|
ldp x4, x5, [sp], #0x10
|
|
ldp x2, x3, [sp], #0x10
|
|
ldp x0, x1, [sp], #0x10
|
|
RESTORE_FPU sp
|
|
#ifdef RT_USING_SMART
|
|
beq arch_ret_to_user
|
|
#endif
|
|
eret
|
|
.endm
|
|
|
|
#endif /* __ARM64_CONTEXT_H__ */
|