Chinaunix首页 | 论坛 | 博客
  • 博客访问: 809279
  • 博文数量: 106
  • 博客积分: 1250
  • 博客等级: 少尉
  • 技术积分: 1349
  • 用 户 组: 普通用户
  • 注册时间: 2012-01-09 09:38
文章分类

全部博文(106)

文章存档

2014年(1)

2013年(13)

2012年(92)

分类: LINUX

2012-04-19 10:24:30

Method #1: Disable/Enable interrupts using simple instructions. After critical section, interrupts will be enabled even if they were disabled before entering the critical section.

 

Method #2: Disable/Enable interrupts by preserving the state of interrupts. In other words, if interrupts were disabled before entering the critical section, they will be disabled when leaving the critical section.

 

Method #3: Disable/Enable interrupts by preserving the state of interrupts. Generally speaking you would store the state of the interrupt disable flag in the local variable 'cpu_sr' and then disable interrupts. 'cpu_sr' is allocated in all of uC/OS-II's functions that need to disable interrupts. You would restore the interrupt disable state by copying back 'cpu_sr' into the CPU's status register

 

1)当OS_CRITICAL_METHOD= = 1时,简单实现如下:

#define   OS_ENTER_CRITICAL()   disable_int()

#define   OS_EXIT_CRITICAL()      enable_int()

但这样有一个问题,如果禁止中断的情况下调用uC/OS-II功能函数,那么从功能函数返回时,中断可能变成允许的了,而实际上还是希望是禁止的。

 

2)当OS_CRITICAL_METHOD= = 2时,实现如下:

#define OS_ENTER_CRITICAL() asm(“PUSH PSW”); asm(“DI”);

#define OS_EXIT_CRITICAL() asm(“POP PSW”);

执行OS_ENTER_CRITICAL()时,先将中断状态保存到堆栈,然后关中断;执行OS_EXIT_CRITICAL()时,再从堆栈中恢复原来的中断开/关状态。这种方法不会改变中断状态,避免前面的问题。

 

3)当OS_CRITICAL_METHOD= = 3时,实现如下:

#define OS_ENTER_CRITICAL() cpu_sr = get_processor_psw(); disable_interrupts();

#define OS_EXIT_CRITICAL() set_ processor_psw(cpu_sr);

将处理器状态字保存在局部变量中。

阅读(3445) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~