- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Atmel AT91SAM7S 微 Controller ,看起来 IRQ 处理程序应该在主管模式下执行,而主循环代码在系统模式下执行。另外,我应该保留一部分 RAM 以供主管模式代码用作堆栈。我从演示程序中得到的启动汇编代码默认保留128字节。
为什么我要为supervisor模式预留单独的栈空间;为什么它不能只使用与系统模式(主)相同的堆栈?具有与主循环代码完全不同的堆栈的中断处理代码有什么好处?我看到当前用于 IRQ 处理的汇编代码在跳转到中断处理程序之前从 IRQ 模式切换到主管模式。在用户模式下执行中断处理程序是否合适?如果是这样,我有什么需要注意的吗?
我问是因为如果中断有自己的堆栈,我需要估计在最坏情况下中断将使用多少堆栈空间的上限。如果中断使用与 main 相同的堆栈,则没有必要这样做,只要实际上有足够的 RAM 可用(当然,我不会使用那么多)。
我唯一能想到的是,如果您要实现具有某种内存保护的操作系统,那么拥有一个单独的堆栈会很有用;但既然我不这样做,这有关系吗?
附言我熟悉 AVR 及其中断处理。
澄清
当 CPU 跳转到地址 0x18 时,中断处理似乎开始了,其中包含一条到 AT91F_Irq_Handler
的分支指令。 ,下面。据我所知,处理器自动进入中断模式;该程序集在分支到 (C) 功能之前切换到监控模式,具体取决于触发的中断线。它从高级中断 Controller (AIC) 获取分支地址。
AT91F_Irq_Handler:
/* Manage Exception Entry */
/* Adjust and save LR_irq in IRQ stack */
sub lr, lr, #4
stmfd sp!, {lr}
/* Save r0 and SPSR (need to be saved for nested interrupt) */
mrs r14, SPSR
stmfd sp!, {r0,r14}
/* Write in the IVR to support Protect Mode */
/* No effect in Normal Mode */
/* De-assert the NIRQ and clear the source in Protect Mode */
ldr r14, =AT91C_BASE_AIC
ldr r0 , [r14, #AIC_IVR]
str r14, [r14, #AIC_IVR]
/* Enable Interrupt and Switch in Supervisor Mode */
msr CPSR_c, #ARM_MODE_SVC
/* Save scratch/used registers and LR in User Stack */
stmfd sp!, { r1-r3, r12, r14}
/* Branch to the routine pointed by the AIC_IVR */
mov r14, pc
bx r0
/* Manage Exception Exit */
/* Restore scratch/used registers and LR from User Stack */
ldmia sp!, { r1-r3, r12, r14}
/* Disable Interrupt and switch back in IRQ mode */
msr CPSR_c, #I_BIT | ARM_MODE_IRQ
/* Mark the End of Interrupt on the AIC */
ldr r14, =AT91C_BASE_AIC
str r14, [r14, #AIC_EOICR]
/* Restore SPSR_irq and r0 from IRQ stack */
ldmia sp!, {r0,r14}
msr SPSR_cxsf, r14
/* Restore adjusted LR_irq from IRQ stack directly in the PC */
ldmia sp!, {pc}^
最佳答案
您不必将主管 r13 用作 堆栈 .您可以将其用作通用寄存器来保存某些内容,然后转换到系统模式并在该模式下运行 ISR 的其余部分。它很灵活,如果您愿意,您可以拥有不同的堆栈;你不像其他架构那样被铐上手铐。您可以使用一些保存区域指针或通常指向当前正在执行的任务的指针(或双指针)来填充主管 r13。您需要保存 lr
, spsr
,以及如果您希望 ISR 返回将被破坏的任何其他寄存器。我认为最初,正常的 ARM 将处于中断模式;也许您还有其他一些处理程序已经转换到主管模式?通常系统模式有一个内核堆栈/任务控制块,它在多任务系统中切换。监督模式是一种常见的异常处理模式。
如果您只有一个任务并且想使用它的堆栈,则可以使用以下方法。在主管中保存上下文后,转换到系统模式并执行 ISR 的其余部分。只需恢复包括 lr
在内的寄存器和 cpsr
返回正确的模式、程序计数器和条件代码。
你当然有 选项 将管理器 r13 用作异常堆栈,许多人可能喜欢它具有有限的行为和更快的 IRQ 延迟,因为堆栈已预设并准备好供主 ISR 主体使用。
关于assembly - 为什么 ARM 管理模式有自己的堆栈?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18924177/
将 ARM 处理器模式与 x86 操作模式(ring0 到 ring 3)进行比较,用户模式看起来就像 ring3,用户空间程序在其中运行。 但是,我无法将 ring0 与系统模式或主管模式联系起来。
为什么我们在 ARM 架构中有暂存寄存器?处理器如何使用它,我的意思是这个寄存器的用途是什么? 最佳答案 来自 Procedure Call Standard for the Arm Architec
我了解弱内存模型和强内存模型的基本区别。但是没有确切的弱定义,它取决于体系结构(这里是 ARM)。 我已经阅读了有关 ARM 信息中心的文档,但仍有很多内容不清楚。有人可以列出 - ARM 保证哪些内
我想在 arm 9 上分析我的代码,是否有任何分析器可以给我函数调用时间和每个函数占用的总周期?我更喜欢任何免费的分析器。我喜欢在 Linux 中使用 kcachegrind。 最佳答案 我不知道有什
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this qu
众所周知,对于X86架构:按下电源按钮后,机器开始执行0xFFFFFFF0处的代码,然后开始执行BIOS中的代码以进行硬件初始化。 BIOS 执行后,它使用引导加载程序将操作系统镜像加载到内存中。最后
我有 rootfs 和 klibc 文件系统。我正在创建 make 规则,而一些开发人员的编译器较旧,但没有联网。note1 我正在尝试验证所有文件都是使用 arm 仅当检测到某个版本的编译器时。我已
在部署实际应用程序之前,我们使用 ARM 模板部署 Azure 资源,作为构建过程的一部分。 到目前为止,我们所有的应用程序资源都自包含在资源组中。例如需要 SQL Server 和存储帐户的 Web
为什么 ARM Controller 在发生异常时要从 THUMB 状态返回到 ARM 状态? 最佳答案 一种解释可能是 ARM 模式是 CPU 的“ native ”操作模式,与有限的 Thumb
我正在尝试反转 128 位向量 (uint16x8) 的顺序。 例如,如果我有 a b c d e f g h 我想获得 h g f e d c b a 有没有一种简单的方法可以使用 NEON 内在函
有很多关于内存屏障的信息。大多数信息是指多核或多处理器架构。 Stackoverflow 上的某个地方还指出,单核处理器不需要内存屏障。 到目前为止,我找不到任何明确的解释,为什么单核 CPU 上不需
我想在 ARM Cortex A8 处理器上移植一小段代码。 L1 缓存和 L2 缓存都非常有限。我的程序中有 3 个数组。其中两个是顺序访问的(大小> 数组 A:6MB 和数组 B:3MB),第三个
我无法弄清楚这个 ARM 指令是做什么的: strd.w r0, r1, [r2] 我知道这是一个存储指令,它在 *r2 中存储了一些东西。但我不完全确定是什么。为什么有两个源寄存器
我很好奇为什么有些 ARM 指令(如 MUL 和 ADD)不使用桶形移位器。我想知道极限背后的理性。谢谢! 最佳答案 并不是没有使用桶形移位器;这是您无法指定它在非常具体的指令(数据处理和加载/存储)
我需要计算与 SSE 相同的操作: __m128i result1=_mm_avg_epu8 (upper, lower); 使用 NEON,我执行以下操作: uint8x16_t result1=v
我正在尝试使用 PLD 指令。我面临的问题如下: int32_t addr[10]; asm ("PLD [addr,#5]"); 我收到以下错误: Error: ARM register expec
根据 ARM 手册,应该可以访问特定 CPU 模式的存储寄存器,例如“r13_svc”。当我尝试执行此操作时,gcc 对我大喊大叫,并显示以下错误: 立即表达式需要 # 前缀 -- `mov r2,s
我正在使用 mbxxx 目标开发 Contiki 2.7。在构建我的代码时,链接器提示 .ARM.exidx 和 .data 部分的重叠 .在修改了链接器脚本 contiki-2.7/cpu/stm3
如何确定给定 ARM 处理器上是否存在 NEON 引擎?可以为此目的查询任何状态/标志寄存器吗? 最佳答案 我相信unixsmurf's answer如果使用具有特权内核的操作系统,这将与您获得的一样
如何在设备上分析我的 ARM 代码。 这是涉及 USB 和 SDH 处理的裸机代码,我看到了这个 Code Profiler for ARM但似乎很 slim ,我很熟悉DS5但如果您使用基于 lin
我是一名优秀的程序员,十分优秀!