Commit e70ea8c0 authored by Andi Kleen's avatar Andi Kleen Committed by Andi Kleen

[PATCH] x86-64: Revert timer routing behaviour back to 2.6.16 state

By default route the 8254 over the 8259 and only disable
it on ATI boards where this causes double timer interrupts.

This should unbreak some Nvidia boards where the timer doesn't
seem to tick of it isn't enabled in the 8259. At least one
VIA board also seemed to have a little trouble with the disabled
8259.

For 2.6.20 we'll try both dynamically without black listing, but I think
for .19 this is the safer approach because it has been already well tested
in earlier kernels. This also makes the x86-64 behaviour the same
as i386.

Command line options can change all this of course.
Signed-off-by: default avatarAndi Kleen <ak@suse.de>
parent dbaab49f
...@@ -61,10 +61,11 @@ static void nvidia_bugs(void) ...@@ -61,10 +61,11 @@ static void nvidia_bugs(void)
static void ati_bugs(void) static void ati_bugs(void)
{ {
#if 1 /* for testing */ if (timer_over_8254 == 1) {
printk("ATI board detected\n"); timer_over_8254 = 0;
#endif printk(KERN_INFO
/* No bugs right now */ "ATI board detected. Disabling timer routing over 8254.\n");
}
} }
struct chipset { struct chipset {
......
...@@ -57,7 +57,7 @@ static int no_timer_check; ...@@ -57,7 +57,7 @@ static int no_timer_check;
static int disable_timer_pin_1 __initdata; static int disable_timer_pin_1 __initdata;
int timer_over_8254 __initdata = 0; int timer_over_8254 __initdata = 1;
/* Where if anywhere is the i8259 connect in external int mode */ /* Where if anywhere is the i8259 connect in external int mode */
static struct { int pin, apic; } ioapic_i8259 = { -1, -1 }; static struct { int pin, apic; } ioapic_i8259 = { -1, -1 };
......
...@@ -122,6 +122,8 @@ extern int fix_aperture; ...@@ -122,6 +122,8 @@ extern int fix_aperture;
extern int reboot_force; extern int reboot_force;
extern int notsc_setup(char *); extern int notsc_setup(char *);
extern int timer_over_8254;
extern int gsi_irq_sharing(int gsi); extern int gsi_irq_sharing(int gsi);
extern void smp_local_timer_interrupt(void); extern void smp_local_timer_interrupt(void);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment