diff options
author | Yinghai Lu <yhlu.kernel@gmail.com> | 2008-07-14 01:19:35 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-14 03:02:54 -0400 |
commit | 94a8c3c2437c8946f1b6c8e0b2c560a7db8ed3c6 (patch) | |
tree | 7bad615005b6047306336e8f688edcf1c6bb74dd | |
parent | f910a9dc7c865896815e2a95fe33363e9522f277 (diff) |
x86: let 32bit use apic_ops too - fix
fix for pv - clean up the namespace there too.
Signed-off-by: Yinghai Lu <yhlu.kernel@gmail.com>
Cc: Suresh Siddha <suresh.b.siddha@intel.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | arch/x86/kernel/paravirt.c | 5 | ||||
-rw-r--r-- | arch/x86/kernel/vmi_32.c | 51 | ||||
-rw-r--r-- | arch/x86/xen/enlighten.c | 19 | ||||
-rw-r--r-- | include/asm-x86/paravirt.h | 29 |
4 files changed, 57 insertions, 47 deletions
diff --git a/arch/x86/kernel/paravirt.c b/arch/x86/kernel/paravirt.c index 4f29ff847ebe..e0f139106c7e 100644 --- a/arch/x86/kernel/paravirt.c +++ b/arch/x86/kernel/paravirt.c | |||
@@ -360,11 +360,6 @@ struct pv_cpu_ops pv_cpu_ops = { | |||
360 | 360 | ||
361 | struct pv_apic_ops pv_apic_ops = { | 361 | struct pv_apic_ops pv_apic_ops = { |
362 | #ifdef CONFIG_X86_LOCAL_APIC | 362 | #ifdef CONFIG_X86_LOCAL_APIC |
363 | #ifndef CONFIG_X86_64 | ||
364 | .apic_write = native_apic_mem_write, | ||
365 | .apic_write_atomic = native_apic_mem_write_atomic, | ||
366 | .apic_read = native_apic_mem_read, | ||
367 | #endif | ||
368 | .setup_boot_clock = setup_boot_APIC_clock, | 363 | .setup_boot_clock = setup_boot_APIC_clock, |
369 | .setup_secondary_clock = setup_secondary_APIC_clock, | 364 | .setup_secondary_clock = setup_secondary_APIC_clock, |
370 | .startup_ipi_hook = paravirt_nop, | 365 | .startup_ipi_hook = paravirt_nop, |
diff --git a/arch/x86/kernel/vmi_32.c b/arch/x86/kernel/vmi_32.c index b15346092b7b..cf3074354553 100644 --- a/arch/x86/kernel/vmi_32.c +++ b/arch/x86/kernel/vmi_32.c | |||
@@ -676,6 +676,50 @@ static inline int __init probe_vmi_rom(void) | |||
676 | return 0; | 676 | return 0; |
677 | } | 677 | } |
678 | 678 | ||
679 | #ifdef CONFIG_X86_LOCAL_APIC | ||
680 | static u32 vmi_apic_read(u32 reg) | ||
681 | { | ||
682 | return 0; | ||
683 | } | ||
684 | |||
685 | static void vmi_apic_write(u32 reg, u32 val) | ||
686 | { | ||
687 | /* Warn to see if there's any stray references */ | ||
688 | WARN_ON(1); | ||
689 | } | ||
690 | |||
691 | static u64 vmi_apic_icr_read(void) | ||
692 | { | ||
693 | return 0; | ||
694 | } | ||
695 | |||
696 | static void vmi_apic_icr_write(u32 low, u32 id) | ||
697 | { | ||
698 | /* Warn to see if there's any stray references */ | ||
699 | WARN_ON(1); | ||
700 | } | ||
701 | |||
702 | static void vmi_apic_wait_icr_idle(void) | ||
703 | { | ||
704 | return; | ||
705 | } | ||
706 | |||
707 | static u32 vmi_safe_apic_wait_icr_idle(void) | ||
708 | { | ||
709 | return 0; | ||
710 | } | ||
711 | |||
712 | static struct apic_ops vmi_basic_apic_ops = { | ||
713 | .read = vmi_apic_read, | ||
714 | .write = vmi_apic_write, | ||
715 | .write_atomic = vmi_apic_write, | ||
716 | .icr_read = vmi_apic_icr_read, | ||
717 | .icr_write = vmi_apic_icr_write, | ||
718 | .wait_icr_idle = vmi_apic_wait_icr_idle, | ||
719 | .safe_wait_icr_idle = vmi_safe_apic_wait_icr_idle, | ||
720 | }; | ||
721 | #endif | ||
722 | |||
679 | /* | 723 | /* |
680 | * VMI setup common to all processors | 724 | * VMI setup common to all processors |
681 | */ | 725 | */ |
@@ -904,9 +948,10 @@ static inline int __init activate_vmi(void) | |||
904 | #endif | 948 | #endif |
905 | 949 | ||
906 | #ifdef CONFIG_X86_LOCAL_APIC | 950 | #ifdef CONFIG_X86_LOCAL_APIC |
907 | para_fill(pv_apic_ops.apic_read, APICRead); | 951 | para_fill(vmi_basic_apic_ops.read, APICRead); |
908 | para_fill(pv_apic_ops.apic_write, APICWrite); | 952 | para_fill(vmi_basic_apic_ops.write, APICWrite); |
909 | para_fill(pv_apic_ops.apic_write_atomic, APICWrite); | 953 | para_fill(vmi_basic_apic_ops.write_atomic, APICWrite); |
954 | apic_ops = &vmi_basic_apic_ops; | ||
910 | #endif | 955 | #endif |
911 | 956 | ||
912 | /* | 957 | /* |
diff --git a/arch/x86/xen/enlighten.c b/arch/x86/xen/enlighten.c index 54e255667530..d11dda7ebd7a 100644 --- a/arch/x86/xen/enlighten.c +++ b/arch/x86/xen/enlighten.c | |||
@@ -559,7 +559,6 @@ static void xen_apic_write(u32 reg, u32 val) | |||
559 | WARN_ON(1); | 559 | WARN_ON(1); |
560 | } | 560 | } |
561 | 561 | ||
562 | #ifdef CONFIG_X86_64 | ||
563 | static u64 xen_apic_icr_read(void) | 562 | static u64 xen_apic_icr_read(void) |
564 | { | 563 | { |
565 | return 0; | 564 | return 0; |
@@ -576,6 +575,11 @@ static void xen_apic_wait_icr_idle(void) | |||
576 | return; | 575 | return; |
577 | } | 576 | } |
578 | 577 | ||
578 | static u32 xen_safe_apic_wait_icr_idle(void) | ||
579 | { | ||
580 | return 0; | ||
581 | } | ||
582 | |||
579 | static struct apic_ops xen_basic_apic_ops = { | 583 | static struct apic_ops xen_basic_apic_ops = { |
580 | .read = xen_apic_read, | 584 | .read = xen_apic_read, |
581 | .write = xen_apic_write, | 585 | .write = xen_apic_write, |
@@ -583,9 +587,8 @@ static struct apic_ops xen_basic_apic_ops = { | |||
583 | .icr_read = xen_apic_icr_read, | 587 | .icr_read = xen_apic_icr_read, |
584 | .icr_write = xen_apic_icr_write, | 588 | .icr_write = xen_apic_icr_write, |
585 | .wait_icr_idle = xen_apic_wait_icr_idle, | 589 | .wait_icr_idle = xen_apic_wait_icr_idle, |
586 | .safe_wait_icr_idle = xen_apic_wait_icr_idle, | 590 | .safe_wait_icr_idle = xen_safe_apic_wait_icr_idle, |
587 | }; | 591 | }; |
588 | #endif | ||
589 | 592 | ||
590 | #endif | 593 | #endif |
591 | 594 | ||
@@ -1159,11 +1162,6 @@ static const struct pv_irq_ops xen_irq_ops __initdata = { | |||
1159 | 1162 | ||
1160 | static const struct pv_apic_ops xen_apic_ops __initdata = { | 1163 | static const struct pv_apic_ops xen_apic_ops __initdata = { |
1161 | #ifdef CONFIG_X86_LOCAL_APIC | 1164 | #ifdef CONFIG_X86_LOCAL_APIC |
1162 | #ifndef CONFIG_X86_64 | ||
1163 | .apic_write = xen_apic_write, | ||
1164 | .apic_write_atomic = xen_apic_write, | ||
1165 | .apic_read = xen_apic_read, | ||
1166 | #endif | ||
1167 | .setup_boot_clock = paravirt_nop, | 1165 | .setup_boot_clock = paravirt_nop, |
1168 | .setup_secondary_clock = paravirt_nop, | 1166 | .setup_secondary_clock = paravirt_nop, |
1169 | .startup_ipi_hook = paravirt_nop, | 1167 | .startup_ipi_hook = paravirt_nop, |
@@ -1322,9 +1320,10 @@ asmlinkage void __init xen_start_kernel(void) | |||
1322 | pv_irq_ops = xen_irq_ops; | 1320 | pv_irq_ops = xen_irq_ops; |
1323 | pv_apic_ops = xen_apic_ops; | 1321 | pv_apic_ops = xen_apic_ops; |
1324 | pv_mmu_ops = xen_mmu_ops; | 1322 | pv_mmu_ops = xen_mmu_ops; |
1325 | #ifdef CONFIG_X86_64 | 1323 | |
1324 | #ifdef CONFIG_X86_LOCAL_APIC | ||
1326 | /* | 1325 | /* |
1327 | * for 64bit, set up the basic apic ops aswell. | 1326 | * set up the basic apic ops. |
1328 | */ | 1327 | */ |
1329 | apic_ops = &xen_basic_apic_ops; | 1328 | apic_ops = &xen_basic_apic_ops; |
1330 | #endif | 1329 | #endif |
diff --git a/include/asm-x86/paravirt.h b/include/asm-x86/paravirt.h index 5e34d26aa3b5..08f89e385a92 100644 --- a/include/asm-x86/paravirt.h +++ b/include/asm-x86/paravirt.h | |||
@@ -200,15 +200,6 @@ struct pv_irq_ops { | |||
200 | 200 | ||
201 | struct pv_apic_ops { | 201 | struct pv_apic_ops { |
202 | #ifdef CONFIG_X86_LOCAL_APIC | 202 | #ifdef CONFIG_X86_LOCAL_APIC |
203 | #ifndef CONFIG_X86_64 | ||
204 | /* | ||
205 | * Direct APIC operations, principally for VMI. Ideally | ||
206 | * these shouldn't be in this interface. | ||
207 | */ | ||
208 | void (*apic_write)(u32 reg, u32 v); | ||
209 | void (*apic_write_atomic)(u32 reg, u32 v); | ||
210 | u32 (*apic_read)(u32 reg); | ||
211 | #endif | ||
212 | void (*setup_boot_clock)(void); | 203 | void (*setup_boot_clock)(void); |
213 | void (*setup_secondary_clock)(void); | 204 | void (*setup_secondary_clock)(void); |
214 | 205 | ||
@@ -890,26 +881,6 @@ static inline void slow_down_io(void) | |||
890 | } | 881 | } |
891 | 882 | ||
892 | #ifdef CONFIG_X86_LOCAL_APIC | 883 | #ifdef CONFIG_X86_LOCAL_APIC |
893 | /* | ||
894 | * Basic functions accessing APICs. | ||
895 | */ | ||
896 | #ifndef CONFIG_X86_64 | ||
897 | static inline void apic_write(u32 reg, u32 v) | ||
898 | { | ||
899 | PVOP_VCALL2(pv_apic_ops.apic_write, reg, v); | ||
900 | } | ||
901 | |||
902 | static inline void apic_write_atomic(u32 reg, u32 v) | ||
903 | { | ||
904 | PVOP_VCALL2(pv_apic_ops.apic_write_atomic, reg, v); | ||
905 | } | ||
906 | |||
907 | static inline u32 apic_read(u32 reg) | ||
908 | { | ||
909 | return PVOP_CALL1(unsigned long, pv_apic_ops.apic_read, reg); | ||
910 | } | ||
911 | #endif | ||
912 | |||
913 | static inline void setup_boot_clock(void) | 884 | static inline void setup_boot_clock(void) |
914 | { | 885 | { |
915 | PVOP_VCALL0(pv_apic_ops.setup_boot_clock); | 886 | PVOP_VCALL0(pv_apic_ops.setup_boot_clock); |