CPSR开关中断实现函数

某系统中对中断的打开、关闭函数如下:

static __inline int wsn_DisableInterrupt(void)
{
        register int retval, temp;

        __asm__ volatile (
                "mrs %0, cpsr\n"//将cpsr状态寄存器的值传给%0
                "\torr %1, %0, #0xC0\n"//将%0与0xC0值做orr或运算,即置位操作,并赋值给%1。CPSR的I、F位置1,关中断
                "\tmsr cpsr_c, %1\n"//将%1的值传给cpsr_c状态寄存器
                : "=r" (retval), "=r" (temp));
        barrier(0);
        return retval;
}

static __inline int wsn_EnableInterrupt(void)
{
        register int retval, temp;
        barrier(0);
        __asm__ volatile (
                "mrs %0, cpsr\n"
                "\tbic %1, %0, #0xC0\n"//将%0与0xC0值做bic清零操作,并赋值给%1。CPSR的I、F位清0,开中断
                "\tmsr cpsr_c, %1\n"
                : "=r" (retval), "=r" (temp));

        return retval;
}

以上两函数通过设置CPSR的I、F控制位设置中断。

CPSR开关中断实现函数_第1张图片

0XC0的二进制位1100 0000,对应到CPSR的控制位,即低8位。

中断禁止位I、F:置1时,禁止IRQ中断和FIQ中断。


基础指令如下:

1、状态寄存器访问指令
MRS: 状态寄存器到通用寄存器的传送指令。MRS{}, CPSR

MSR: 通用寄存器到状态寄存器的传送指令。MSR{} CPSR,

2、BIC位清零指令

BIC(Bit Clear)位清零指令,将寄存器Rn的值与第2个源操作数shifter_operand的值的反码按位做“逻辑与”操作,结果保存到Rd中。   

(1)指令的语法格式  BIC{}{S} ,,  

(2)BIC指令举例  

清除R0中的位0、1和3,保持其余的不变。

BIC R0, R0, #0x0B  

其中0x0B的二进制为0000 1011


3、ORR指令的格式为

ORR{条件}{S}  目的寄存器,操作数1,操作数2

ORR指令用于在两个操作数上进行逻辑或运算,并把结果放置到目的寄存器中。操作数1应是一 个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。该指令常用于设置操 作数1的某些位。
指令示例:
ORR R0,R0,#3          ;  3的二进制表示为”0000 0011“,该指令设置R0的0、1位,其余位保持不变。


你可能感兴趣的:(OS)