ARMv8 异常处理之保存现场kernel_entry详解

本文深入探讨了ARMv8架构下异常处理的kernel_entry宏定义,主要涉及异常级别、寄存器保存、栈空间管理和任务切换等关键步骤。详细解释了kernel_entry如何保存现场,特别是对于el1_sync异常的处理,包括保存通用寄存器、清零操作、获取及设置task_struct等,确保在kernel_exit时能够恢复准确的现场。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、前言

异常发生后,处理器从对应的异常向量表入口地址开始执行,第一条指令是kernel_ventry。kernel_ventry是一个宏定义,先检查栈空间是否有溢出,然后跳转到指定的异常处理标签。

具体详情,可以查看ARMv8 异常处理之中断向量表

2.kernel_entry详解 

以el1_sync为例,最终执行代码如下:

SYM_CODE_START_LOCAL_NOALIGN(el1_sync)
	kernel_entry 1
	mov	x0, sp
	bl	el1_sync_handler
	kernel_exit 1
SYM_CODE_END(el1_sync)

el1_sync第一条指令执行kernel_entry 1。kernel_entry也是一个宏定义,首先将CPU寄存器保存到栈空间,因为这些寄存器接下来会被覆盖使用。为了保证kernel_exit时能恢复准确的现场,这里有必要对第一现场先做保存。

2.1 kernel_entry代码

	.macro	ker
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值