码迷,mamicode.com
首页 > 其他好文 > 详细

开关中断与cpsid/cpsie指令

时间:2014-09-22 23:57:33      阅读:4272      评论:0      收藏:0      [点我收藏+]

标签:arm   gic   中断   

在汇编代码中,CPSID   CPSIE  用于快速的开关中断。

CPSID

I

;PRIMASK=1,

;关中断

CPSIE

I

;PRIMASK=0,

;开中断

CPSID 

CPSIE

F

F

;FAULTMASK=1,

;FAULTMASK=0

;关异常

;开异常


I:IRQ中断;    F:FIQ中断

最常见的这两个命令的使用处是在关中断、开中断的实现中,我们经常用的local_irq_save和local_irq_restore最终都是调用了以下两个实现,即关/开中断只是操作了CPSR中的中断标志位而已,并没有去对GIC做操作,只是简单的不让CPU响应中断,具体实现在arch/arm/include/asm/irqflags.h文件中。

static inline void arch_local_irq_enable(void)
{
	asm volatile(
		"	cpsie i			@ arch_local_irq_enable"
		:
		:
		: "memory", "cc");
}
static inline void arch_local_irq_disable(void)
{
	asm volatile(
		"	cpsid i			@ arch_local_irq_disable"
		:
		:
		: "memory", "cc");
}
#define local_fiq_enable()  __asm__("cpsie f	@ __stf" : : : "memory", "cc")
#define local_fiq_disable() __asm__("cpsid f	@ __clf" : : : "memory", "cc")
http://dirlt.com/gcc-asm.html

开关中断与cpsid/cpsie指令

标签:arm   gic   中断   

原文地址:http://blog.csdn.net/lixiaojie1012/article/details/39480599

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!