Chinaunix首页 | 论坛 | 博客
  • 博客访问: 647731
  • 博文数量: 156
  • 博客积分: 4833
  • 博客等级: 上校
  • 技术积分: 1554
  • 用 户 组: 普通用户
  • 注册时间: 2007-05-21 19:36
文章分类

全部博文(156)

文章存档

2016年(2)

2013年(1)

2012年(13)

2011年(30)

2010年(46)

2009年(29)

2008年(23)

2007年(12)

分类: LINUX

2012-04-02 21:14:06

Init hook:

trap_init:
set_except_vector(0, rollback ? rollback_handle_int : handle_int);

1)handle_level hook
arch_init_irq->init_nlm_common_irqs:
irq_set_chip_and_handler(i, &xlp_pic, handle_level_irq);
irq_set_chip_and_handler->irq_set_chip_and_handler_name->__irq_set_handler

__irq_set_handler:
desc->handle_irq = handle;

2)chip hook
irq_set_chip_and_handler(i, &xlp_pic, handle_level_irq);

3)special hook
request_irq->request_threaded_irq->__setup_irq(irq, desc, action);

__setup_irq:
/* add new interrupt at end of irq queue */
do {
    /*
     * Or all existing action->thread_mask bits,
     * so we can find the next zero bit for this
     * new action.
     */
    thread_mask |= old->thread_mask;
    old_ptr = &old->next;
    old = *old_ptr;
} while (old);

new->irq = irq;
*old_ptr = new;

Call tree:
(genex.s)handle_int->plat_irq_dispatch->do_IRQ->generic_handle_irq->(desc->handle_irq)
   
1) irqchip handle:     handle_level_irq->mask_ack_irq->(desc->irq_data.chip->irq_ack)

2) special irq handle :handle_level_irq->handle_irq_event->handle_irq_event_percpu->(action->handler)





阅读(1138) | 评论(0) | 转发(0) |
0

上一篇:bsd 9 mips interrupt call

下一篇:bsd coredump

给主人留下些什么吧!~~