首 页 | 模 板 | 学 院 | 源 码 | 书 籍 | 壁 纸 | 字 体 | JS脚本 | FLASH源码 | 软 件 | 矢 量 | 服务器软件 | 素 材 | 其 它 |
设为主页
加入收藏
联系站长
平面设计 | 网页制作 | 程序编写 | 数 据 库 | 媒体动画 | 网络冲浪 | 服务器相关 | 站长乐园 | 业界动态 |
当前在线
Linux操作系统下的软中断问题分析
2006-11-25 14:44:29  作者:模板天下收集整理  来源:未知 网友评论 0 条 论坛
      前几天把硬中断完成了,这几天在做软中断的事情。现在对linux2.6.12的软中断机制有了一个基本的认识。在此把它的软中断的一些问题做一个记录。

  系统中有一个softirq_action结构,它定义在中,是一个通用结构,还有一个很重要的结构在中申明,这个结构是cpu相关的,比如在i386中这个结构为

typedef struct { 
unsigned int __softirq_pending; 
unsigned long idle_timestamp; 
unsigned int __nmi_count; /* arch dependent */ 
unsigned int apic_timer_irqs; /* arch dependent */ 
} ____cacheline_aligned irq_cpustat_t;

  在arm中这个结构为

typedef struct { 
unsigned int __softirq_pending; 
} ____cacheline_aligned irq_cpustat_t;

  以上两个结构均再中。

  在中有几个很不好理解的函数:

1:local_softirq_pending()

  下面是这个函数的定义

CODE:#ifndef __ARCH_IRQ_STAT 
extern irq_cpustat_t irq_stat[]; /* defined in asm/hardirq.h */ 
#define __IRQ_STAT(cpu, member) (irq_stat[cpu].member) 
#endif 

/* arch independent irq_stat fields */ 
#define local_softirq_pending() \ 
__IRQ_STAT(smp_processor_id(), __softirq_pending)

  其中的smp_processor_id()如果追下去会很复杂,其实它最后只是一个数字:cpu的号码,单cpu中为0.

2.#define __raise_softirq_irqoff(nr) do  
{ local_softirq_pending() |= 1UL << (nr); } while (0)

  这个函数实际上是把irq_stat[cpu_id](kernel/softirq.c中)结构中的pending的第nr为置位,表示这个cpu有几号软中断要处理,在do_softirq()中有对irq_stat[]的pending的相应检查及处理,详细的处理过程参见源代码及《Linux Kernel Development》第7章。

 

共分1页  [1] 

>> 相关文章

关于网站 | 客服中心 | 服务条款 | 友情链接 | 广告联系 | 本站历程 | 网站导航

吉ICP备05000107号