17. OP-TEE中的中断处理(三)------系统IRQ事件的处理

2023-12-09 20:32

本文主要是介绍17. OP-TEE中的中断处理(三)------系统IRQ事件的处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   

  

IRQ事件的处理一般会用在ROS端,但是当CPU为是secure world态时,系统产生了IRQ事件,而该事件又不能被暴力的作为无用事件而轻易丢弃,系统还是需要有响应并执行相关操作的。那针对该种情况,在在OP-TEE文件当,针对这种情况的处理方式和逻辑图如下,本文将从介绍secure world态下对IRQ事件的处理逻辑:

1. OP-TEE中对IRQ事件的响应

  在系统初始化的时候,系统会调用thread_init_vbar函数来初始化secure world态的中断向量表并将中断向量的地址保存到VBAR寄存器中。所以在secure world态中产生了IRQ事件的时候,系统将会通过VBAR寄存器获取到中断向量表地址,然后命中写入的IRQ事件处理函数thread_irq_handler函数并逐步执行解析IRQ事件并处理之,整个处理过程的流程图如下图所示:

1.1 thread_irq_handler函数

  在《15. OP-TEE中的中断处理(一)------中断配置和向量表的配置》介绍了在secure world态中中断向量表的初始化,thread_vect_table即为secure world态的中断向量,当IRQ事件发生时,系统将调用thread_irq_handler函数来对IRQ事件进行处理,该函数定义在optee_os/core/arch/arm/kernel/thread_a32.S文件中,其内容如下:

LOCAL_FUNC thread_irq_handler , :
UNWIND(	.fnstart)
UNWIND(	.cantunwind)
#if defined(CFG_ARM_GICV3)native_intr_handler	irq
#elseforeign_intr_handler	irq
#endif
UNWIND(	.fnend)
END_FUNC thread_irq_handler

  由于没有使能GICV3,所以最终会调用foreign_intr_handler宏来对IRQ事件进行处理。

1.2 foreign_intr_handler宏

  foreign_intr_handler宏将suspend系统当前正在执行的thread并进行相关的设置后调用smc指令出发smc时间,将cpu状态切换到monitor态进行进一步处理。

.macro foreign_intr_handler mode:req.ifc	\mode\(),irq/** Disable FIQ if the foreign interrupt is sent as IRQ.* IRQ mode is set up to use tmp stack so FIQ has to be* disabled before touching the stack. We can also assign* SVC sp from IRQ sp to get SVC mode into the state we* need when doing the SMC below.* If it is sent as FIQ, the IRQ has already been masked by hardware*/cpsid	f.endifsub	lr, lr, #4push	{lr}push	{r12}.ifc	\mode\(),fiqbl	thread_save_state_fiq.elsebl	thread_save_state.endifmov	r0, #THREAD_FLAGS_EXIT_ON_FOREIGN_INTRmrs	r1, spsrpop	{r12}pop	{r2}blx	thread_state_suspend	//suspend当前系统中threadmov	r4, r0		/* Supply thread index *//** Switch to SVC mode and copy current stack pointer as it already* is the tmp stack.*/mov	r0, spcps	#CPSR_MODE_SVCmov	sp, r0ldr	r0, =TEESMC_OPTEED_RETURN_CALL_DONEldr	r1, =OPTEE_SMC_RETURN_RPC_FOREIGN_INTRmov	r2, #0mov	r3, #0/* r4 is already filled in above */smc	#0	//调用smc,出发smc事件将CPU状态切换到monitor执行进一步的处理b	.	/* SMC should not return */
.endm

1.3 monitor态下的smc处理

  当系统触发smc之后,cpu进入到monitor态,并进入到monitor态下的smc处理函数sm_smc_entry,当执行smc之后相当于产生了类似软中断的操作,而该为何执行smc之后CPU会执行sm_smc_entry函数请阅读《16. OP-TEE中的中断处理(二)------系统FIQ事件的处理》中的1.1章节。sm_smc_entry函数定义在optee_os/core/arch/arm/sm/sm_a32.S文件中,其内容如下:

LOCAL_FUNC sm_smc_entry , :
UNWIND(	.fnstart)
UNWIND(	.cantunwind)srsdb	sp!, #CPSR_MODE_MONpush	{r0-r7}clrex		/* Clear the exclusive monitor *//* Find out if we're doing an secure or non-secure entry */read_scr r1tst	r1, #SCR_NSbne	.smc_from_nsec/** As we're coming from secure world (NS bit cleared) the stack* pointer points to sm_ctx.sec.r0 at this stage. After the* instruction below the stack pointer points to sm_ctx.*/sub	sp, sp, #(SM_CTX_SEC + SM_SEC_CTX_R0)/* Save secure context */
/* 保存secure world的context */add	r0, sp, #SM_CTX_SECbl	sm_save_modes_regs/** On FIQ exit we're restoring the non-secure context unchanged, on* all other exits we're shifting r1-r4 from secure context into* r0-r3 in non-secure context.*/
/* 配置好传递到non-secure world的参数 */add	r8, sp, #(SM_CTX_SEC + SM_SEC_CTX_R0)ldm	r8, {r0-r4}mov_imm	r9, TEESMC_OPTEED_RETURN_FIQ_DONEcmp	r0, r9addne	r8, sp, #(SM_CTX_NSEC + SM_NSEC_CTX_R0)stmne	r8, {r1-r4}/* Restore non-secure context */
/* 加载non-secure world态的context */add	r0, sp, #SM_CTX_NSECbl	sm_restore_modes_regs/* 返回到non-secure world态 */
.sm_ret_to_nsec:/** Return to non-secure world*/add     r0, sp, #(SM_CTX_NSEC + SM_NSEC_CTX_R8)ldm	r0, {r8-r12}/* Update SCR */read_scr r0orr	r0, r0, #(SCR_NS | SCR_FIQ) /* Set NS and FIQ bit in SCR */write_scr r0add	sp, sp, #(SM_CTX_NSEC + SM_NSEC_CTX_R0)b	.sm_exit	//退出smc操作,切换到non-secure world态.smc_from_nsec:/** As we're coming from non-secure world (NS bit set) the stack* pointer points to sm_ctx.nsec.r0 at this stage. After the* instruction below the stack pointer points to sm_ctx.*/sub	sp, sp, #(SM_CTX_NSEC + SM_NSEC_CTX_R0)bic	r1, r1, #(SCR_NS | SCR_FIQ) /* Clear NS and FIQ bit in SCR */write_scr r1add	r0, sp, #(SM_CTX_NSEC + SM_NSEC_CTX_R8)stm	r0, {r8-r12}mov	r0, spbl	sm_from_nseccmp	r0, #0beq	.sm_ret_to_nsec/** Continue into secure world*/add	sp, sp, #(SM_CTX_SEC + SM_SEC_CTX_R0).sm_exit:pop	{r0-r7}rfefd	sp!
UNWIND(	.fnend)
END_FUNC sm_smc_entry

1.4 返回到secure world态中继续执行

  当monitor态将IRQ事件传递到了non-secure world后并将CPU的状态切换到non-secure world态之后,ROS将根据具体得到的参数执行具体的IRQ事件的处理。当完成IRQ事件处理自后,会调用smc重新切回到monitor态,然后恢复secure world中被中断的thread状态继续执行。


 




 

这篇关于17. OP-TEE中的中断处理(三)------系统IRQ事件的处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/474970

相关文章

Windows系统宽带限制如何解除?

《Windows系统宽带限制如何解除?》有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文就跟大家一起来看看Windows系统解除网络限制的操作方法吧... 有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

一文详解Java异常处理你都了解哪些知识

《一文详解Java异常处理你都了解哪些知识》:本文主要介绍Java异常处理的相关资料,包括异常的分类、捕获和处理异常的语法、常见的异常类型以及自定义异常的实现,文中通过代码介绍的非常详细,需要的朋... 目录前言一、什么是异常二、异常的分类2.1 受检异常2.2 非受检异常三、异常处理的语法3.1 try-

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http