diff options
author | Russ Anderson <(rja@sgi.com)> | 2005-05-09 15:03:00 -0700 |
---|---|---|
committer | Tony Luck <tony.luck@intel.com> | 2005-05-17 12:52:43 -0700 |
commit | bb68c12b40c3c745381d7ce61d7b2e371f157505 (patch) | |
tree | 5ff0f0f266601f5eebe82744dee9302e746c936f /arch | |
parent | 056b5033fb8d16095fb074fc910fad90186374f3 (diff) | |
download | kernel_samsung_smdk4412-bb68c12b40c3c745381d7ce61d7b2e371f157505.zip kernel_samsung_smdk4412-bb68c12b40c3c745381d7ce61d7b2e371f157505.tar.gz kernel_samsung_smdk4412-bb68c12b40c3c745381d7ce61d7b2e371f157505.tar.bz2 |
[IA64-SGI] cpe interrupts are not being enabled.
acpi_request_vector() is called in ia64_mca_init() to get the cpe_vector.
The problem is that acpi_request_vector() looks in platform_intr_list[] to
get the vector, but platform_intr_list[] is not initialized with a valid
vector until later (in sn_setup()). Without a valid vector the code
defaults to polling mode.
This patch moves the call to acpi_request_vector() from ia64_mca_init()
to ia64_mca_late_init(), which is after platform_intr_list[] is initialized.
Signed-off-by: Russ Anderson (rja@sgi.com)
Signed-off-by: Tony Luck <tony.luck@intel.com>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/ia64/kernel/mca.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/ia64/kernel/mca.c b/arch/ia64/kernel/mca.c index 4d6c7b8f..2c75741 100644 --- a/arch/ia64/kernel/mca.c +++ b/arch/ia64/kernel/mca.c @@ -1390,8 +1390,7 @@ ia64_mca_init(void) register_percpu_irq(IA64_MCA_WAKEUP_VECTOR, &mca_wkup_irqaction); #ifdef CONFIG_ACPI - /* Setup the CPEI/P vector and handler */ - cpe_vector = acpi_request_vector(ACPI_INTERRUPT_CPEI); + /* Setup the CPEI/P handler */ register_percpu_irq(IA64_CPEP_VECTOR, &mca_cpep_irqaction); #endif @@ -1436,6 +1435,7 @@ ia64_mca_late_init(void) #ifdef CONFIG_ACPI /* Setup the CPEI/P vector and handler */ + cpe_vector = acpi_request_vector(ACPI_INTERRUPT_CPEI); init_timer(&cpe_poll_timer); cpe_poll_timer.function = ia64_mca_cpe_poll; |