单处理器上保护软中断使用的数据结构需要禁用本地软中断吗?
问:请教各位大侠:
《深入理解linux内核》中,内核同步章节有这样一段话
保护可延迟函数(软中断)所访问的数据结构应采取的措施:
单处理器上:在单处理器上不存在竞争条件,这是因为可延迟函数(软中断)的执行总是在一个CPU上串行执行--也就是说,一个可延迟函数不会被另一个可延迟函数中断。因此,根本不需要同步原语。  
我觉得不太对啊,一个软中断虽然不会被另一个软中断“中断”,但是可能被硬中断“中断”,而硬中断最后还是要执行到软中断,因此还是会形成对资源的临界区访问。我觉得在保护软中断时,应该关闭本地软中断,比如用local_bh_disable
不知道这样理解对不对?
答:开始处理软中断的情况主要是
1、中断退出执行的irq_exit
2、内核线程ksoftirqd
3、local_bh_enable  
而
 
1: asmlinkage void do_softirq(void)
   2:  {3: unsigned long flags;
4: struct thread_info *curctx;
   5:          union irq_ctx *irqctx;   6:          u32 *isp;    7:   8: if (in_interrupt())
9: return;
  10:  ....  11:  }
可以看到,in_interrupt 判断,当前若是从硬件中断退出后执行的irq_exit进入的do_softirq,则立即返回,可以避免你说的情况
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号