aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-x86
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2008-01-30 07:30:15 -0500
committerIngo Molnar <mingo@elte.hu>2008-01-30 07:30:15 -0500
commit42e0a9aa5d467188687c6b705412578e53c14af6 (patch)
tree9c9a64a576a4072b816babf0bb81aa5924d2a667 /include/asm-x86
parent3c6bb07ac1b4174318606a26f0de8ceb9f6d8133 (diff)
x86: use u32 for some lapic functions
Use u32 so 32 and 64bit have the same interface. Andrew Morton: xen, lguest build fixes Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'include/asm-x86')
-rw-r--r--include/asm-x86/apic_32.h16
-rw-r--r--include/asm-x86/apic_64.h6
-rw-r--r--include/asm-x86/paravirt.h12
3 files changed, 16 insertions, 18 deletions
diff --git a/include/asm-x86/apic_32.h b/include/asm-x86/apic_32.h
index f909e2daf226..649e9a6f6683 100644
--- a/include/asm-x86/apic_32.h
+++ b/include/asm-x86/apic_32.h
@@ -51,25 +51,23 @@ extern int local_apic_timer_disabled;
51#define setup_secondary_clock setup_secondary_APIC_clock 51#define setup_secondary_clock setup_secondary_APIC_clock
52#endif 52#endif
53 53
54static __inline fastcall void native_apic_write(unsigned long reg, 54static __inline fastcall void native_apic_write(unsigned long reg, u32 v)
55 unsigned long v)
56{ 55{
57 *((volatile unsigned long *)(APIC_BASE+reg)) = v; 56 *((volatile u32 *)(APIC_BASE + reg)) = v;
58} 57}
59 58
60static __inline fastcall void native_apic_write_atomic(unsigned long reg, 59static __inline fastcall void native_apic_write_atomic(unsigned long reg, u32 v)
61 unsigned long v)
62{ 60{
63 xchg((volatile unsigned long *)(APIC_BASE+reg), v); 61 (void) xchg((u32 *)(APIC_BASE + reg), v);
64} 62}
65 63
66static __inline fastcall unsigned long native_apic_read(unsigned long reg) 64static __inline fastcall u32 native_apic_read(unsigned long reg)
67{ 65{
68 return *((volatile unsigned long *)(APIC_BASE+reg)); 66 return *((volatile u32 *)(APIC_BASE + reg));
69} 67}
70 68
71extern void apic_wait_icr_idle(void); 69extern void apic_wait_icr_idle(void);
72extern unsigned long safe_apic_wait_icr_idle(void); 70extern u32 safe_apic_wait_icr_idle(void);
73extern int get_physical_broadcast(void); 71extern int get_physical_broadcast(void);
74 72
75#ifdef CONFIG_X86_GOOD_APIC 73#ifdef CONFIG_X86_GOOD_APIC
diff --git a/include/asm-x86/apic_64.h b/include/asm-x86/apic_64.h
index 7bfad0224178..9d0c06c4df91 100644
--- a/include/asm-x86/apic_64.h
+++ b/include/asm-x86/apic_64.h
@@ -38,14 +38,14 @@ struct pt_regs;
38 * Basic functions accessing APICs. 38 * Basic functions accessing APICs.
39 */ 39 */
40 40
41static __inline void apic_write(unsigned long reg, unsigned int v) 41static __inline void apic_write(unsigned long reg, u32 v)
42{ 42{
43 *((volatile unsigned int *)(APIC_BASE+reg)) = v; 43 *((volatile unsigned int *)(APIC_BASE+reg)) = v;
44} 44}
45 45
46static __inline unsigned int apic_read(unsigned long reg) 46static __inline u32 apic_read(unsigned long reg)
47{ 47{
48 return *((volatile unsigned int *)(APIC_BASE+reg)); 48 return *((volatile u32 *)(APIC_BASE+reg));
49} 49}
50 50
51extern void apic_wait_icr_idle(void); 51extern void apic_wait_icr_idle(void);
diff --git a/include/asm-x86/paravirt.h b/include/asm-x86/paravirt.h
index f59d370c5df4..19fd3e67b08c 100644
--- a/include/asm-x86/paravirt.h
+++ b/include/asm-x86/paravirt.h
@@ -150,9 +150,9 @@ struct pv_apic_ops {
150 * Direct APIC operations, principally for VMI. Ideally 150 * Direct APIC operations, principally for VMI. Ideally
151 * these shouldn't be in this interface. 151 * these shouldn't be in this interface.
152 */ 152 */
153 void (*apic_write)(unsigned long reg, unsigned long v); 153 void (*apic_write)(unsigned long reg, u32 v);
154 void (*apic_write_atomic)(unsigned long reg, unsigned long v); 154 void (*apic_write_atomic)(unsigned long reg, u32 v);
155 unsigned long (*apic_read)(unsigned long reg); 155 u32 (*apic_read)(unsigned long reg);
156 void (*setup_boot_clock)(void); 156 void (*setup_boot_clock)(void);
157 void (*setup_secondary_clock)(void); 157 void (*setup_secondary_clock)(void);
158 158
@@ -690,17 +690,17 @@ static inline void slow_down_io(void) {
690/* 690/*
691 * Basic functions accessing APICs. 691 * Basic functions accessing APICs.
692 */ 692 */
693static inline void apic_write(unsigned long reg, unsigned long v) 693static inline void apic_write(unsigned long reg, u32 v)
694{ 694{
695 PVOP_VCALL2(pv_apic_ops.apic_write, reg, v); 695 PVOP_VCALL2(pv_apic_ops.apic_write, reg, v);
696} 696}
697 697
698static inline void apic_write_atomic(unsigned long reg, unsigned long v) 698static inline void apic_write_atomic(unsigned long reg, u32 v)
699{ 699{
700 PVOP_VCALL2(pv_apic_ops.apic_write_atomic, reg, v); 700 PVOP_VCALL2(pv_apic_ops.apic_write_atomic, reg, v);
701} 701}
702 702
703static inline unsigned long apic_read(unsigned long reg) 703static inline u32 apic_read(unsigned long reg)
704{ 704{
705 return PVOP_CALL1(unsigned long, pv_apic_ops.apic_read, reg); 705 return PVOP_CALL1(unsigned long, pv_apic_ops.apic_read, reg);
706} 706}