这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » MCU » 请教ARM堆栈问题

共5条 1/1 1 跳转至

请教ARM堆栈问题

菜鸟
2005-05-21 16:22:02     打赏

在一般的CPU中,只有一个堆栈,当程序进入中断,就把现场压入堆栈,当更高级的中段到来,则当前中断的现场也被压入堆栈。然后中断处理结束后的次序是逐步返回,依次出栈。也就是说,不同的中断只要一个堆栈就可以完成。但在ARM中有7个异常(从大的范围看可以视为中断),每个异常有自己的堆栈,这是为什么?有必要吗?谁能够回答我?

请你不要式图从操作系统用户模式来解释此问题!因为80x86只有一个堆栈,照样支持多用户操作系统.




关键词: 请教     堆栈     问题    

菜鸟
2005-05-25 02:27:00     打赏
2楼
ARM没有说过异常可以视为中断;实际上,它更接近于一种处理器模式。你理解的那种可以层层嵌套的中断,只是引发IRQ异常或FIQ异常的原因。至于多任务就更与此无关了。

菜鸟
2005-05-25 06:38:00     打赏
3楼
我觉得是出于速度的考虑.例如FIQ,处理速度会比IRQ快.

菜鸟
2005-05-25 17:25:00     打赏
4楼
传统的计算机系统结构? x86也有ring 0到ring 3的。。。

菜鸟
2005-05-25 17:35:00     打赏
5楼

对异常处理更快,结构简单

各种异常处理互相不影响


共5条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]