Isaku Yamahata
9bcfc7daab
ioapic: when switches to level trigger mode, interrupts raised repeatedly.
- the trigger mode is edge at first
- During initializatoin, the interrupt is raised as edge which is masked.
The corresponding bit of irr is set.
- Then the mode is switched to level and it's unmasked.
- the bit of irr is set, so the interrupt is raised repeatedly by
ioapic_service().
- OS considers that the irq line is broken and falls back to polling mode.
This patch fixes the issues.
After raising edige, clear the bit of irr.
> Bringing up interface eth0:
> Determining IP information for eth0...irq 18: nobody cared (try booting with the "irqpoll" option)
> Pid: 4126, comm: ip Not tainted 2.6.38-rc7 #1
> Call Trace:
> <IRQ> [<ffffffff8105b009>] ? __report_bad_irq+0x38/0x87
> [<ffffffff8105b177>] ? note_interrupt+0x11f/0x188
> [<ffffffff8105bacf>] ? handle_fasteoi_irq+0xa7/0xd1
> [<ffffffff810046ff>] ? handle_irq+0x83/0x8c
> [<ffffffff81003eb9>] ? do_IRQ+0x48/0xaf
> [<ffffffff81300513>] ? ret_from_intr+0x0/0xe
> [<ffffffff81031ab8>] ? __do_softirq+0x4f/0x114
> [<ffffffff81002d6c>] ? call_softirq+0x1c/0x28
> [<ffffffff81004647>] ? do_softirq+0x33/0x68
> [<ffffffff810316fb>] ? irq_exit+0x36/0x38
> [<ffffffff81015f2c>] ? smp_apic_timer_interrupt+0x88/0x96
> [<ffffffff81002853>] ? apic_timer_interrupt+0x13/0x20
> <EOI> [<ffffffff810177ed>] ? __ioapic_set_affinity+0x68/0x7c
> [<ffffffff813000f0>] ? _raw_spin_unlock_irqrestore+0x8/0xa
> [<ffffffff8105a84f>] ? __setup_irq+0x224/0x2cb
> [<ffffffff8120e3c5>] ? e1000_intr+0x0/0x103
> [<ffffffff8105a9c7>] ? request_threaded_irq+0xd1/0x114
> [<ffffffff8120e396>] ? e1000_request_irq+0x34/0x63
> [<ffffffff8121237d>] ? e1000_open+0x81/0x11f
> [<ffffffff8129097c>] ? call_netdevice_notifiers+0x45/0x4a
> [<ffffffff81290d8d>] ? __dev_open+0x97/0xc4
> [<ffffffff8128e9c5>] ? __dev_change_flags+0xb9/0x13d
> [<ffffffff81290cc1>] ? dev_change_flags+0x1c/0x51
> [<ffffffff812d0542>] ? devinet_ioctl+0x26e/0x594
> [<ffffffff812d174c>] ? inet_ioctl+0x92/0xaa
> [<ffffffff81281d75>] ? T.1003+0x13/0x32
> [<ffffffff81282152>] ? sock_ioctl+0x1f2/0x1ff
> [<ffffffff810ae2d3>] ? do_vfs_ioctl+0x498/0x4e7
> [<ffffffff81281203>] ? sock_alloc_file+0xb3/0x115
> [<ffffffff8109f79f>] ? fd_install+0x31/0x5d
> [<ffffffff810ae364>] ? sys_ioctl+0x42/0x65
> [<ffffffff81001f3b>] ? system_call_fastpath+0x16/0x1b
> handlers:
> [<ffffffff8120e3c5>] (e1000_intr+0x0/0x103)
> Disabling IRQ #18
Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
2011-04-03 21:52:57 +02:00
..
2011-03-21 21:28:38 +01:00
2011-04-01 22:08:04 +02:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-22 07:42:08 +01:00
2011-03-06 23:37:19 +01:00
2011-03-06 23:37:17 +01:00
2011-03-21 21:28:38 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-04-01 19:07:49 -05:00
2011-04-01 19:07:48 -05:00
2011-04-01 19:07:48 -05:00
2011-02-14 12:39:47 -02:00
2011-03-21 09:23:23 +01:00
2011-01-31 11:59:24 +01:00
2011-03-21 09:23:23 +01:00
2011-03-28 18:34:23 +02:00
2011-01-29 13:25:22 +01:00
2011-01-29 15:07:19 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-02-20 09:34:06 +00:00
2011-01-23 16:21:20 +00:00
2011-01-29 13:25:22 +01:00
2011-03-13 13:35:21 +00:00
2011-03-06 20:10:58 +01:00
2011-01-24 20:54:34 +00:00
2011-01-24 20:54:33 +00:00
2011-01-24 20:54:34 +00:00
2011-01-24 20:54:34 +00:00
2011-03-06 20:10:58 +01:00
2011-01-29 14:06:07 +01:00
2011-03-21 09:23:23 +01:00
2011-03-10 16:12:26 -06:00
2011-02-11 23:31:17 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-01-31 10:42:42 +01:00
2011-03-21 09:23:23 +01:00
2011-04-03 21:52:57 +02:00
2011-02-04 06:33:26 -06:00
2011-03-06 19:01:31 +01:00
2011-03-06 19:01:31 +01:00
2011-02-21 15:46:53 +01:00
2011-02-21 15:46:53 +01:00
2011-02-14 12:43:09 -02:00
2011-02-14 12:43:09 -02:00
2011-03-21 09:23:23 +01:00
2011-02-01 17:01:41 +00:00
2011-03-07 13:42:37 +01:00
2011-03-07 13:42:37 +01:00
2011-03-07 13:42:36 +01:00
2011-03-07 13:42:36 +01:00
2011-03-07 13:42:36 +01:00
2011-03-07 13:42:36 +01:00
2011-03-07 13:42:37 +01:00
2011-03-07 13:42:36 +01:00
2011-03-07 13:42:36 +01:00
2011-03-07 13:42:36 +01:00
2011-03-21 09:23:23 +01:00
2011-04-01 22:14:37 +02:00
2011-03-21 09:23:23 +01:00
2011-03-10 03:38:13 +01:00
2011-02-11 23:31:17 +01:00
2011-03-21 09:23:23 +01:00
2011-02-20 09:35:06 +00:00
2011-02-20 09:35:06 +00:00
2011-02-21 15:46:53 +01:00
2011-02-20 09:35:06 +00:00
2011-03-21 09:23:23 +01:00
2011-01-23 16:21:20 +00:00
2011-03-21 09:23:23 +01:00
2011-01-20 15:33:18 +02:00
2011-01-20 15:33:34 +02:00
2011-03-10 03:38:13 +01:00
2011-01-23 22:44:13 +01:00
2011-02-20 09:32:26 +00:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-01-29 13:25:22 +01:00
2011-02-20 09:31:21 +00:00
2011-02-21 15:46:53 +01:00
2011-03-22 07:44:15 +01:00
2011-02-20 09:35:06 +00:00
2011-03-28 18:34:22 +02:00
2011-03-28 18:34:22 +02:00
2011-03-28 18:34:22 +02:00
2011-03-28 18:34:22 +02:00
2011-03-28 18:34:22 +02:00
2011-03-03 14:54:50 +01:00
2011-03-28 18:34:22 +02:00
2011-04-01 22:35:25 +02:00
2011-03-21 09:23:23 +01:00
2011-03-19 08:43:22 +00:00
2011-03-11 15:24:37 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-01-20 12:37:21 +01:00
2011-03-06 19:01:30 +01:00
2011-01-20 12:37:21 +01:00
2011-01-20 12:37:21 +01:00
2011-03-06 19:01:29 +01:00
2011-01-20 17:20:18 +01:00
2011-02-20 18:23:07 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-04-01 18:34:57 +02:00
2011-04-01 18:34:55 +02:00
2011-04-01 18:34:55 +02:00
2011-03-06 19:01:30 +01:00
2011-02-21 15:41:12 +01:00
2011-03-21 09:23:23 +01:00
2011-03-03 15:06:03 +01:00
2011-02-25 12:13:38 +01:00
2011-02-20 19:53:23 +01:00
2011-01-20 12:37:21 +01:00
2011-03-03 15:04:51 +01:00
2011-03-10 03:11:47 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-03 15:13:42 +01:00
2011-03-21 16:57:13 +05:30
2011-02-12 08:27:55 +00:00
2011-02-12 08:27:55 +00:00
2011-01-24 15:15:15 +01:00
2011-01-24 15:13:54 +01:00
2011-01-20 12:37:21 +01:00
2011-03-21 09:23:23 +01:00
2011-04-01 22:42:25 +02:00
2011-03-26 11:11:02 +00:00
2011-01-23 16:21:20 +00:00
2011-02-20 18:23:07 +01:00
2011-03-21 09:23:23 +01:00
2011-01-24 21:39:22 +01:00
2011-02-14 12:39:46 -02:00
2011-01-31 10:42:42 +01:00
2011-03-06 20:02:40 +01:00
2011-03-21 09:23:23 +01:00
2011-01-26 14:30:24 +01:00
2011-01-20 12:37:21 +01:00
2011-01-20 12:37:20 +01:00
2011-01-29 13:23:13 +01:00
2011-02-01 17:02:15 +00:00
2011-01-21 17:56:32 +01:00
2011-01-20 12:37:21 +01:00
2011-03-21 09:23:23 +01:00
2011-04-01 18:34:57 +02:00
2011-04-01 18:34:56 +02:00
2011-04-01 18:34:57 +02:00
2011-04-01 18:34:57 +02:00
2011-04-01 18:34:57 +02:00
2011-04-01 18:34:57 +02:00
2011-04-01 18:34:56 +02:00
2011-04-01 18:34:57 +02:00
2011-04-01 18:34:56 +02:00
2011-03-21 09:23:23 +01:00
2011-04-01 18:34:57 +02:00
2011-01-31 10:24:11 +01:00
2011-03-21 09:23:23 +01:00
2011-03-13 14:44:21 +00:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-02-12 09:45:03 +00:00
2011-02-12 09:45:03 +00:00
2011-02-11 23:31:16 +01:00
2011-02-11 23:31:16 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-06 20:10:58 +01:00
2011-01-24 17:23:17 +01:00
2011-04-01 19:07:48 -05:00
2011-03-21 09:23:23 +01:00
2011-01-24 17:21:34 +01:00
2011-02-01 16:50:44 -06:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-01-24 17:21:34 +01:00
2011-04-01 22:42:25 +02:00
2011-04-03 18:04:36 +02:00
2011-02-20 09:34:31 +00:00
2011-02-20 09:34:31 +00:00
2011-03-21 09:23:23 +01:00
2011-02-01 16:50:44 -06:00
2011-02-01 16:50:44 -06:00
2011-03-28 18:34:23 +02:00
2011-02-01 16:50:44 -06:00
2011-01-23 16:21:20 +00:00
2011-01-23 16:21:20 +00:00
2011-02-14 12:39:46 -02:00
2011-03-21 16:56:55 +05:30
2011-03-21 09:23:23 +01:00
2011-03-28 18:34:23 +02:00
2011-03-28 18:34:23 +02:00
2011-03-21 16:55:11 +05:30
2011-03-28 18:34:23 +02:00
2011-03-22 07:44:15 +01:00
2011-02-17 19:34:52 +00:00
2011-02-12 08:27:53 +00:00
2011-02-12 08:28:22 +00:00
2011-03-21 09:23:23 +01:00
2011-02-14 12:39:46 -02:00
2011-01-23 16:21:20 +00:00
2011-03-21 09:23:23 +01:00
2011-03-21 09:23:23 +01:00
2011-03-15 13:21:14 +01:00
2011-03-21 09:23:23 +01:00
2011-04-01 18:34:56 +02:00
2011-04-01 18:34:56 +02:00
2011-03-16 15:18:58 +01:00
2011-03-16 15:18:58 +01:00
2011-03-16 15:18:58 +01:00
2011-03-10 09:16:52 +01:00
2011-03-16 15:18:58 +01:00
2011-02-11 23:31:16 +01:00