Blame view

arch/x86/include/asm/apic.h 15 KB
1965aae3c   H. Peter Anvin   x86: Fix ASM_X86_...
1
2
  #ifndef _ASM_X86_APIC_H
  #define _ASM_X86_APIC_H
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
3

e2780a68f   Ingo Molnar   x86, apic: merge ...
4
  #include <linux/cpumask.h>
e2780a68f   Ingo Molnar   x86, apic: merge ...
5
  #include <linux/pm.h>
593f4a788   Maciej W. Rozycki   x86: APIC: remove...
6
7
  
  #include <asm/alternative.h>
e2780a68f   Ingo Molnar   x86, apic: merge ...
8
  #include <asm/cpufeature.h>
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
9
  #include <asm/processor.h>
e2780a68f   Ingo Molnar   x86, apic: merge ...
10
  #include <asm/apicdef.h>
60063497a   Arun Sharma   atomic: use <linu...
11
  #include <linux/atomic.h>
e2780a68f   Ingo Molnar   x86, apic: merge ...
12
13
  #include <asm/fixmap.h>
  #include <asm/mpspec.h>
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
14
  #include <asm/system.h>
13c88fb58   Suresh Siddha   x64, x2apic/intr-...
15
  #include <asm/msr.h>
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
16
17
  
  #define ARCH_APICTIMER_STOPS_ON_C3	1
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
  /*
   * Debugging macros
   */
  #define APIC_QUIET   0
  #define APIC_VERBOSE 1
  #define APIC_DEBUG   2
  
  /*
   * Define the default level of output to be very little
   * This can be turned up by using apic=verbose for more
   * information and apic=debug for _lots_ of information.
   * apic_verbosity is defined in apic.c
   */
  #define apic_printk(v, s, a...) do {       \
  		if ((v) <= apic_verbosity) \
  			printk(s, ##a);    \
  	} while (0)
160d8dac1   Ingo Molnar   x86, apic: make g...
35
  #if defined(CONFIG_X86_LOCAL_APIC) && defined(CONFIG_X86_32)
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
36
  extern void generic_apic_probe(void);
160d8dac1   Ingo Molnar   x86, apic: make g...
37
38
39
40
41
  #else
  static inline void generic_apic_probe(void)
  {
  }
  #endif
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
42
43
  
  #ifdef CONFIG_X86_LOCAL_APIC
baa131884   Maciej W. Rozycki   x86: APIC: Make a...
44
  extern unsigned int apic_verbosity;
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
45
  extern int local_apic_timer_c2_ok;
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
46

3c999f142   Yinghai Lu   x86: check comman...
47
  extern int disable_apic;
1ade93efd   Jacob Pan   x86/apic: Allow u...
48
  extern unsigned int lapic_timer_frequency;
0939e4fd3   Ingo Molnar   x86, smp: elimina...
49
50
51
52
53
54
55
56
57
58
59
60
61
62
  
  #ifdef CONFIG_SMP
  extern void __inquire_remote_apic(int apicid);
  #else /* CONFIG_SMP */
  static inline void __inquire_remote_apic(int apicid)
  {
  }
  #endif /* CONFIG_SMP */
  
  static inline void default_inquire_remote_apic(int apicid)
  {
  	if (apic_verbosity >= APIC_DEBUG)
  		__inquire_remote_apic(apicid);
  }
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
63
  /*
8312136fa   Cyrill Gorcunov   x86, apic: Fix mi...
64
65
66
67
68
69
70
71
72
73
74
75
76
   * With 82489DX we can't rely on apic feature bit
   * retrieved via cpuid but still have to deal with
   * such an apic chip so we assume that SMP configuration
   * is found from MP table (64bit case uses ACPI mostly
   * which set smp presence flag as well so we are safe
   * to use this helper too).
   */
  static inline bool apic_from_smp_config(void)
  {
  	return smp_found_config && !disable_apic;
  }
  
  /*
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
77
78
79
80
   * Basic functions accessing APICs.
   */
  #ifdef CONFIG_PARAVIRT
  #include <asm/paravirt.h>
96a388de5   Thomas Gleixner   i386/x86_64: move...
81
  #endif
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
82

70511134f   Ravikiran G Thirumalai   Revert "x86: don'...
83
  #ifdef CONFIG_X86_64
aa7d8e25e   Ravikiran G Thirumalai   x86: fix build br...
84
  extern int is_vsmp_box(void);
129d8bc82   Yinghai Lu   x86: don't compil...
85
86
87
88
89
90
  #else
  static inline int is_vsmp_box(void)
  {
  	return 0;
  }
  #endif
2b97df06c   Jaswinder Singh   x86: apic_XX.c de...
91
92
  extern void xapic_wait_icr_idle(void);
  extern u32 safe_xapic_wait_icr_idle(void);
2b97df06c   Jaswinder Singh   x86: apic_XX.c de...
93
94
  extern void xapic_icr_write(u32, u32);
  extern int setup_profiling_timer(unsigned int);
aa7d8e25e   Ravikiran G Thirumalai   x86: fix build br...
95

1b374e4d6   Suresh Siddha   x64, x2apic/intr-...
96
  static inline void native_apic_mem_write(u32 reg, u32 v)
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
97
  {
593f4a788   Maciej W. Rozycki   x86: APIC: remove...
98
  	volatile u32 *addr = (volatile u32 *)(APIC_BASE + reg);
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
99

593f4a788   Maciej W. Rozycki   x86: APIC: remove...
100
101
102
  	alternative_io("movl %0, %1", "xchgl %0, %1", X86_FEATURE_11AP,
  		       ASM_OUTPUT2("=r" (v), "=m" (*addr)),
  		       ASM_OUTPUT2("0" (v), "m" (*addr)));
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
103
  }
1b374e4d6   Suresh Siddha   x64, x2apic/intr-...
104
  static inline u32 native_apic_mem_read(u32 reg)
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
105
106
107
  {
  	return *((volatile u32 *)(APIC_BASE + reg));
  }
c1eeb2de4   Yinghai Lu   x86: fold apic_op...
108
109
110
111
  extern void native_apic_wait_icr_idle(void);
  extern u32 native_safe_apic_wait_icr_idle(void);
  extern void native_apic_icr_write(u32 low, u32 id);
  extern u64 native_apic_icr_read(void);
fc1edaf9e   Suresh Siddha   x86: x2apic, IR: ...
112
  extern int x2apic_mode;
b24696bc5   Fenghua Yu   Intel IOMMU Suspe...
113

d0b03bd1c   Han, Weidong   x2apic/intr-remap...
114
  #ifdef CONFIG_X86_X2APIC
ce4e240c2   Suresh Siddha   x86: add x2apic_w...
115
116
117
118
119
120
121
122
123
  /*
   * Make previous memory operations globally visible before
   * sending the IPI through x2apic wrmsr. We need a serializing instruction or
   * mfence for this.
   */
  static inline void x2apic_wrmsr_fence(void)
  {
  	asm volatile("mfence" : : : "memory");
  }
13c88fb58   Suresh Siddha   x64, x2apic/intr-...
124
125
126
127
128
129
130
131
132
133
134
  static inline void native_apic_msr_write(u32 reg, u32 v)
  {
  	if (reg == APIC_DFR || reg == APIC_ID || reg == APIC_LDR ||
  	    reg == APIC_LVR)
  		return;
  
  	wrmsr(APIC_BASE_MSR + (reg >> 4), v, 0);
  }
  
  static inline u32 native_apic_msr_read(u32 reg)
  {
0059b2436   Andi Kleen   x86: Address gcc4...
135
  	u64 msr;
13c88fb58   Suresh Siddha   x64, x2apic/intr-...
136
137
138
  
  	if (reg == APIC_DFR)
  		return -1;
0059b2436   Andi Kleen   x86: Address gcc4...
139
140
  	rdmsrl(APIC_BASE_MSR + (reg >> 4), msr);
  	return (u32)msr;
13c88fb58   Suresh Siddha   x64, x2apic/intr-...
141
  }
c1eeb2de4   Yinghai Lu   x86: fold apic_op...
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
  static inline void native_x2apic_wait_icr_idle(void)
  {
  	/* no need to wait for icr idle in x2apic */
  	return;
  }
  
  static inline u32 native_safe_x2apic_wait_icr_idle(void)
  {
  	/* no need to wait for icr idle in x2apic */
  	return 0;
  }
  
  static inline void native_x2apic_icr_write(u32 low, u32 id)
  {
  	wrmsrl(APIC_BASE_MSR + (APIC_ICR >> 4), ((__u64) id) << 32 | low);
  }
  
  static inline u64 native_x2apic_icr_read(void)
  {
  	unsigned long val;
  
  	rdmsrl(APIC_BASE_MSR + (APIC_ICR >> 4), val);
  	return val;
  }
fc1edaf9e   Suresh Siddha   x86: x2apic, IR: ...
166
  extern int x2apic_phys;
fb209bd89   Yinghai Lu   x86, x2apic: Fall...
167
  extern int x2apic_preenabled;
6e1cb38a2   Suresh Siddha   x64, x2apic/intr-...
168
169
  extern void check_x2apic(void);
  extern void enable_x2apic(void);
6e1cb38a2   Suresh Siddha   x64, x2apic/intr-...
170
  extern void x2apic_icr_write(u32 low, u32 id);
a11b5abef   Yinghai Lu   x2apic: fix reser...
171
172
  static inline int x2apic_enabled(void)
  {
0059b2436   Andi Kleen   x86: Address gcc4...
173
  	u64 msr;
a11b5abef   Yinghai Lu   x2apic: fix reser...
174
175
176
  
  	if (!cpu_has_x2apic)
  		return 0;
0059b2436   Andi Kleen   x86: Address gcc4...
177
  	rdmsrl(MSR_IA32_APICBASE, msr);
a11b5abef   Yinghai Lu   x2apic: fix reser...
178
179
180
181
  	if (msr & X2APIC_ENABLE)
  		return 1;
  	return 0;
  }
fc1edaf9e   Suresh Siddha   x86: x2apic, IR: ...
182
183
  
  #define x2apic_supported()	(cpu_has_x2apic)
ce69a7845   Gleb Natapov   x86/apic: Enable ...
184
185
186
187
  static inline void x2apic_force_phys(void)
  {
  	x2apic_phys = 1;
  }
a11b5abef   Yinghai Lu   x2apic: fix reser...
188
  #else
fb209bd89   Yinghai Lu   x86, x2apic: Fall...
189
190
191
  static inline void disable_x2apic(void)
  {
  }
06cd9a7dc   Yinghai Lu   x86: add x2apic c...
192
193
194
195
196
197
  static inline void check_x2apic(void)
  {
  }
  static inline void enable_x2apic(void)
  {
  }
06cd9a7dc   Yinghai Lu   x86: add x2apic c...
198
199
200
201
  static inline int x2apic_enabled(void)
  {
  	return 0;
  }
ce69a7845   Gleb Natapov   x86/apic: Enable ...
202
203
204
  static inline void x2apic_force_phys(void)
  {
  }
cf6567fe4   Suresh Siddha   x86, x2apic: fix ...
205

a31bc3276   Yinghai Lu   x86, x2apic: Allo...
206
  #define	nox2apic	0
937582382   Weidong Han   x86, intr-remap: ...
207
  #define	x2apic_preenabled 0
fc1edaf9e   Suresh Siddha   x86: x2apic, IR: ...
208
  #define	x2apic_supported()	0
c535b6a1a   Yinghai Lu   x86: let 32bit us...
209
  #endif
1b374e4d6   Suresh Siddha   x64, x2apic/intr-...
210

937582382   Weidong Han   x86, intr-remap: ...
211
  extern void enable_IR_x2apic(void);
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
212
  extern int get_physical_broadcast(void);
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
213
214
215
216
217
218
219
  extern int lapic_get_maxlvt(void);
  extern void clear_local_APIC(void);
  extern void connect_bsp_APIC(void);
  extern void disconnect_bsp_APIC(int virt_wire_setup);
  extern void disable_local_APIC(void);
  extern void lapic_shutdown(void);
  extern int verify_local_APIC(void);
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
220
221
222
  extern void sync_Arb_IDs(void);
  extern void init_bsp_APIC(void);
  extern void setup_local_APIC(void);
739f33b38   Andi Kleen   x86: untable __in...
223
  extern void end_local_APIC_setup(void);
2fb270f32   Jan Beulich   x86: Fix section ...
224
  extern void bsp_end_local_APIC_setup(void);
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
225
  extern void init_apic_mappings(void);
c0104d38a   Yinghai Lu   x86, apic: Unify ...
226
  void register_lapic_address(unsigned long address);
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
227
228
229
  extern void setup_boot_APIC_clock(void);
  extern void setup_secondary_APIC_clock(void);
  extern int APIC_init_uniprocessor(void);
a906fdaac   Thomas Gleixner   x86: dt: Cleanup ...
230
  extern int apic_force_enable(unsigned long addr);
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
231
232
233
234
235
  
  /*
   * On 32bit this is mach-xxx local
   */
  #ifdef CONFIG_X86_64
8fbbc4b45   Alok Kataria   x86: merge tsc_in...
236
237
238
239
240
241
  extern int apic_is_clustered_box(void);
  #else
  static inline int apic_is_clustered_box(void)
  {
  	return 0;
  }
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
242
  #endif
27afdf200   Robert Richter   apic, x86: Use BI...
243
  extern int setup_APIC_eilvt(u8 lvt_off, u8 vector, u8 msg_type, u8 mask);
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
244
245
246
247
  
  #else /* !CONFIG_X86_LOCAL_APIC */
  static inline void lapic_shutdown(void) { }
  #define local_apic_timer_c2_ok		1
f3294a33e   Yinghai Lu   x86: let setup_ar...
248
  static inline void init_apic_mappings(void) { }
d3ec5cae0   Ivan Vecera   x86: call machine...
249
  static inline void disable_local_APIC(void) { }
736decac6   Thomas Gleixner   x86: Move percpu ...
250
251
  # define setup_boot_APIC_clock x86_init_noop
  # define setup_secondary_APIC_clock x86_init_noop
67c5fc5c3   Thomas Gleixner   x86: merge apic_3...
252
  #endif /* !CONFIG_X86_LOCAL_APIC */
1f75ed0c1   Ingo Molnar   x86: remove mach_...
253
254
255
  #ifdef CONFIG_X86_64
  #define	SET_APIC_ID(x)		(apic->set_apic_id(x))
  #else
1f75ed0c1   Ingo Molnar   x86: remove mach_...
256
  #endif
e2780a68f   Ingo Molnar   x86, apic: merge ...
257
258
259
260
261
262
263
264
265
266
  /*
   * Copyright 2004 James Cleverdon, IBM.
   * Subject to the GNU Public License, v.2
   *
   * Generic APIC sub-arch data struct.
   *
   * Hacked for x86-64 by James Cleverdon from i386 architecture code by
   * Martin Bligh, Andi Kleen, James Bottomley, John Stultz, and
   * James Cleverdon.
   */
be163a159   Ingo Molnar   x86, apic: rename...
267
  struct apic {
e2780a68f   Ingo Molnar   x86, apic: merge ...
268
269
270
271
272
273
274
275
276
277
278
279
280
281
  	char *name;
  
  	int (*probe)(void);
  	int (*acpi_madt_oem_check)(char *oem_id, char *oem_table_id);
  	int (*apic_id_registered)(void);
  
  	u32 irq_delivery_mode;
  	u32 irq_dest_mode;
  
  	const struct cpumask *(*target_cpus)(void);
  
  	int disable_esr;
  
  	int dest_logical;
7abc07531   Cyrill Gorcunov   x86: apic: Do not...
282
  	unsigned long (*check_apicid_used)(physid_mask_t *map, int apicid);
e2780a68f   Ingo Molnar   x86, apic: merge ...
283
284
285
286
  	unsigned long (*check_apicid_present)(int apicid);
  
  	void (*vector_allocation_domain)(int cpu, struct cpumask *retmask);
  	void (*init_apic_ldr)(void);
7abc07531   Cyrill Gorcunov   x86: apic: Do not...
287
  	void (*ioapic_phys_id_map)(physid_mask_t *phys_map, physid_mask_t *retmap);
e2780a68f   Ingo Molnar   x86, apic: merge ...
288
289
290
  
  	void (*setup_apic_routing)(void);
  	int (*multi_timer_check)(int apic, int irq);
e2780a68f   Ingo Molnar   x86, apic: merge ...
291
  	int (*cpu_present_to_apicid)(int mps_cpu);
7abc07531   Cyrill Gorcunov   x86: apic: Do not...
292
  	void (*apicid_to_cpu_present)(int phys_apicid, physid_mask_t *retmap);
e2780a68f   Ingo Molnar   x86, apic: merge ...
293
  	void (*setup_portio_remap)(void);
e11dadabf   Thomas Gleixner   x86: apic namespa...
294
  	int (*check_phys_apicid_present)(int phys_apicid);
e2780a68f   Ingo Molnar   x86, apic: merge ...
295
296
297
298
  	void (*enable_apic_mode)(void);
  	int (*phys_pkg_id)(int cpuid_apic, int index_msb);
  
  	/*
be163a159   Ingo Molnar   x86, apic: rename...
299
  	 * When one of the next two hooks returns 1 the apic
e2780a68f   Ingo Molnar   x86, apic: merge ...
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
  	 * is switched to this. Essentially they are additional
  	 * probe functions:
  	 */
  	int (*mps_oem_check)(struct mpc_table *mpc, char *oem, char *productid);
  
  	unsigned int (*get_apic_id)(unsigned long x);
  	unsigned long (*set_apic_id)(unsigned int id);
  	unsigned long apic_id_mask;
  
  	unsigned int (*cpu_mask_to_apicid)(const struct cpumask *cpumask);
  	unsigned int (*cpu_mask_to_apicid_and)(const struct cpumask *cpumask,
  					       const struct cpumask *andmask);
  
  	/* ipi */
  	void (*send_IPI_mask)(const struct cpumask *mask, int vector);
  	void (*send_IPI_mask_allbutself)(const struct cpumask *mask,
  					 int vector);
  	void (*send_IPI_allbutself)(int vector);
  	void (*send_IPI_all)(int vector);
  	void (*send_IPI_self)(int vector);
  
  	/* wakeup_secondary_cpu */
1f5bcabf1   Ingo Molnar   x86: apic: simpli...
322
  	int (*wakeup_secondary_cpu)(int apicid, unsigned long start_eip);
e2780a68f   Ingo Molnar   x86, apic: merge ...
323
324
325
326
327
328
  
  	int trampoline_phys_low;
  	int trampoline_phys_high;
  
  	void (*wait_for_init_deassert)(atomic_t *deassert);
  	void (*smp_callin_clear_local_apic)(void);
e2780a68f   Ingo Molnar   x86, apic: merge ...
329
330
331
332
333
334
335
336
337
  	void (*inquire_remote_apic)(int apicid);
  
  	/* apic ops */
  	u32 (*read)(u32 reg);
  	void (*write)(u32 reg, u32 v);
  	u64 (*icr_read)(void);
  	void (*icr_write)(u32 low, u32 high);
  	void (*wait_icr_idle)(void);
  	u32 (*safe_wait_icr_idle)(void);
acb8bc09c   Tejun Heo   x86: Add apic->x8...
338
339
340
341
342
343
344
345
346
347
348
349
350
  
  #ifdef CONFIG_X86_32
  	/*
  	 * Called very early during boot from get_smp_config().  It should
  	 * return the logical apicid.  x86_[bios]_cpu_to_apicid is
  	 * initialized before this function is called.
  	 *
  	 * If logical apicid can't be determined that early, the function
  	 * may return BAD_APICID.  Logical apicid will be configured after
  	 * init_apic_ldr() while bringing up CPUs.  Note that NUMA affinity
  	 * won't be applied properly during early boot in this case.
  	 */
  	int (*x86_32_early_logical_apicid)(int cpu);
89e5dc218   Tejun Heo   x86: Replace apic...
351

84914ed0e   Tejun Heo   x86-32, NUMA: Mak...
352
353
354
355
356
357
  	/*
  	 * Optional method called from setup_local_APIC() after logical
  	 * apicid is guaranteed to be known to initialize apicid -> node
  	 * mapping if NUMA initialization hasn't done so already.  Don't
  	 * add new users.
  	 */
89e5dc218   Tejun Heo   x86: Replace apic...
358
  	int (*x86_32_numa_cpu_node)(int cpu);
acb8bc09c   Tejun Heo   x86: Add apic->x8...
359
  #endif
e2780a68f   Ingo Molnar   x86, apic: merge ...
360
  };
0917c01f8   Ingo Molnar   x86: remove updat...
361
362
363
364
365
  /*
   * Pointer to the local APIC driver in use on this system (there's
   * always just one such driver in use - the kernel decides via an
   * early probing process which one it picks - and then sticks to it):
   */
be163a159   Ingo Molnar   x86, apic: rename...
366
  extern struct apic *apic;
0917c01f8   Ingo Molnar   x86: remove updat...
367
368
  
  /*
107e0e0cd   Suresh Siddha   x86, apic: Introd...
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
   * APIC drivers are probed based on how they are listed in the .apicdrivers
   * section. So the order is important and enforced by the ordering
   * of different apic driver files in the Makefile.
   *
   * For the files having two apic drivers, we use apic_drivers()
   * to enforce the order with in them.
   */
  #define apic_driver(sym)					\
  	static struct apic *__apicdrivers_##sym __used		\
  	__aligned(sizeof(struct apic *))			\
  	__section(.apicdrivers) = { &sym }
  
  #define apic_drivers(sym1, sym2)					\
  	static struct apic *__apicdrivers_##sym1##sym2[2] __used	\
  	__aligned(sizeof(struct apic *))				\
  	__section(.apicdrivers) = { &sym1, &sym2 }
  
  extern struct apic *__apicdrivers[], *__apicdrivers_end[];
  
  /*
0917c01f8   Ingo Molnar   x86: remove updat...
389
390
391
   * APIC functionality to boot other CPUs - only used on SMP:
   */
  #ifdef CONFIG_SMP
2b6163bf5   Yinghai Lu   x86: remove updat...
392
393
  extern atomic_t init_deasserted;
  extern int wakeup_secondary_cpu_via_nmi(int apicid, unsigned long start_eip);
0917c01f8   Ingo Molnar   x86: remove updat...
394
  #endif
e2780a68f   Ingo Molnar   x86, apic: merge ...
395

d674cd196   Cyrill Gorcunov   x86, apic: Allow ...
396
  #ifdef CONFIG_X86_LOCAL_APIC
346b46be5   Fernando Luis Vázquez Cao   x86: Add per-cpu ...
397

e2780a68f   Ingo Molnar   x86, apic: merge ...
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
  static inline u32 apic_read(u32 reg)
  {
  	return apic->read(reg);
  }
  
  static inline void apic_write(u32 reg, u32 val)
  {
  	apic->write(reg, val);
  }
  
  static inline u64 apic_icr_read(void)
  {
  	return apic->icr_read();
  }
  
  static inline void apic_icr_write(u32 low, u32 high)
  {
  	apic->icr_write(low, high);
  }
  
  static inline void apic_wait_icr_idle(void)
  {
  	apic->wait_icr_idle();
  }
  
  static inline u32 safe_apic_wait_icr_idle(void)
  {
  	return apic->safe_wait_icr_idle();
  }
d674cd196   Cyrill Gorcunov   x86, apic: Allow ...
427
428
429
430
431
432
433
434
435
436
  #else /* CONFIG_X86_LOCAL_APIC */
  
  static inline u32 apic_read(u32 reg) { return 0; }
  static inline void apic_write(u32 reg, u32 val) { }
  static inline u64 apic_icr_read(void) { return 0; }
  static inline void apic_icr_write(u32 low, u32 high) { }
  static inline void apic_wait_icr_idle(void) { }
  static inline u32 safe_apic_wait_icr_idle(void) { return 0; }
  
  #endif /* CONFIG_X86_LOCAL_APIC */
e2780a68f   Ingo Molnar   x86, apic: merge ...
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
  
  static inline void ack_APIC_irq(void)
  {
  	/*
  	 * ack_APIC_irq() actually gets compiled as a single instruction
  	 * ... yummie.
  	 */
  
  	/* Docs say use 0 for future compatibility */
  	apic_write(APIC_EOI, 0);
  }
  
  static inline unsigned default_get_apic_id(unsigned long x)
  {
  	unsigned int ver = GET_APIC_VERSION(apic_read(APIC_LVR));
42937e81a   Andreas Herrmann   x86: Detect use o...
452
  	if (APIC_XAPIC(ver) || boot_cpu_has(X86_FEATURE_EXTD_APICID))
e2780a68f   Ingo Molnar   x86, apic: merge ...
453
454
455
456
457
458
459
460
461
462
  		return (x >> 24) & 0xFF;
  	else
  		return (x >> 24) & 0x0F;
  }
  
  /*
   * Warm reset vector default position:
   */
  #define DEFAULT_TRAMPOLINE_PHYS_LOW		0x467
  #define DEFAULT_TRAMPOLINE_PHYS_HIGH		0x469
2b6163bf5   Yinghai Lu   x86: remove updat...
463
  #ifdef CONFIG_X86_64
e2780a68f   Ingo Molnar   x86, apic: merge ...
464
465
466
  extern int default_acpi_madt_oem_check(char *, char *);
  
  extern void apic_send_IPI_self(int vector);
e2780a68f   Ingo Molnar   x86, apic: merge ...
467
468
469
  DECLARE_PER_CPU(int, x2apic_extra_bits);
  
  extern int default_cpu_present_to_apicid(int mps_cpu);
e11dadabf   Thomas Gleixner   x86: apic namespa...
470
  extern int default_check_phys_apicid_present(int phys_apicid);
e2780a68f   Ingo Molnar   x86, apic: merge ...
471
472
473
474
475
476
477
478
  #endif
  
  static inline void default_wait_for_init_deassert(atomic_t *deassert)
  {
  	while (!atomic_read(deassert))
  		cpu_relax();
  	return;
  }
838312be4   Jan Beulich   apic, i386/bigsmp...
479
  extern void generic_bigsmp_probe(void);
e2780a68f   Ingo Molnar   x86, apic: merge ...
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
  
  
  #ifdef CONFIG_X86_LOCAL_APIC
  
  #include <asm/smp.h>
  
  #define APIC_DFR_VALUE	(APIC_DFR_FLAT)
  
  static inline const struct cpumask *default_target_cpus(void)
  {
  #ifdef CONFIG_SMP
  	return cpu_online_mask;
  #else
  	return cpumask_of(0);
  #endif
  }
  
  DECLARE_EARLY_PER_CPU(u16, x86_bios_cpu_apicid);
  
  
  static inline unsigned int read_apic_id(void)
  {
  	unsigned int reg;
  
  	reg = apic_read(APIC_ID);
  
  	return apic->get_apic_id(reg);
  }
  
  extern void default_setup_apic_routing(void);
9844ab11c   Cyrill Gorcunov   x86, apic: Introd...
510
  extern struct apic apic_noop;
e2780a68f   Ingo Molnar   x86, apic: merge ...
511
  #ifdef CONFIG_X86_32
2c1b284e4   Jaswinder Singh Rajput   x86: clean up dec...
512

acb8bc09c   Tejun Heo   x86: Add apic->x8...
513
514
515
516
  static inline int noop_x86_32_early_logical_apicid(int cpu)
  {
  	return BAD_APICID;
  }
e2780a68f   Ingo Molnar   x86, apic: merge ...
517
518
519
520
521
522
523
524
525
526
527
528
529
  /*
   * Set up the logical destination ID.
   *
   * Intel recommends to set DFR, LDR and TPR before enabling
   * an APIC.  See e.g. "AP-388 82489DX User's Manual" (Intel
   * document number 292116).  So here it goes...
   */
  extern void default_init_apic_ldr(void);
  
  static inline int default_apic_id_registered(void)
  {
  	return physid_isset(read_apic_id(), phys_cpu_present_map);
  }
f56e50341   Yinghai Lu   x86: use default_...
530
531
532
533
  static inline int default_phys_pkg_id(int cpuid_apic, int index_msb)
  {
  	return cpuid_apic >> index_msb;
  }
f56e50341   Yinghai Lu   x86: use default_...
534
  #endif
e2780a68f   Ingo Molnar   x86, apic: merge ...
535
536
537
  static inline unsigned int
  default_cpu_mask_to_apicid(const struct cpumask *cpumask)
  {
f56e50341   Yinghai Lu   x86: use default_...
538
  	return cpumask_bits(cpumask)[0] & APIC_ALL_CPUS;
e2780a68f   Ingo Molnar   x86, apic: merge ...
539
540
541
542
543
544
545
546
547
548
549
550
  }
  
  static inline unsigned int
  default_cpu_mask_to_apicid_and(const struct cpumask *cpumask,
  			       const struct cpumask *andmask)
  {
  	unsigned long mask1 = cpumask_bits(cpumask)[0];
  	unsigned long mask2 = cpumask_bits(andmask)[0];
  	unsigned long mask3 = cpumask_bits(cpu_online_mask)[0];
  
  	return (unsigned int)(mask1 & mask2 & mask3);
  }
7abc07531   Cyrill Gorcunov   x86: apic: Do not...
551
  static inline unsigned long default_check_apicid_used(physid_mask_t *map, int apicid)
e2780a68f   Ingo Molnar   x86, apic: merge ...
552
  {
7abc07531   Cyrill Gorcunov   x86: apic: Do not...
553
  	return physid_isset(apicid, *map);
e2780a68f   Ingo Molnar   x86, apic: merge ...
554
555
556
557
558
559
  }
  
  static inline unsigned long default_check_apicid_present(int bit)
  {
  	return physid_isset(bit, phys_cpu_present_map);
  }
7abc07531   Cyrill Gorcunov   x86: apic: Do not...
560
  static inline void default_ioapic_phys_id_map(physid_mask_t *phys_map, physid_mask_t *retmap)
e2780a68f   Ingo Molnar   x86, apic: merge ...
561
  {
7abc07531   Cyrill Gorcunov   x86: apic: Do not...
562
  	*retmap = *phys_map;
e2780a68f   Ingo Molnar   x86, apic: merge ...
563
  }
e2780a68f   Ingo Molnar   x86, apic: merge ...
564
565
566
567
568
569
570
571
572
  static inline int __default_cpu_present_to_apicid(int mps_cpu)
  {
  	if (mps_cpu < nr_cpu_ids && cpu_present(mps_cpu))
  		return (int)per_cpu(x86_bios_cpu_apicid, mps_cpu);
  	else
  		return BAD_APICID;
  }
  
  static inline int
e11dadabf   Thomas Gleixner   x86: apic namespa...
573
  __default_check_phys_apicid_present(int phys_apicid)
e2780a68f   Ingo Molnar   x86, apic: merge ...
574
  {
e11dadabf   Thomas Gleixner   x86: apic namespa...
575
  	return physid_isset(phys_apicid, phys_cpu_present_map);
e2780a68f   Ingo Molnar   x86, apic: merge ...
576
577
578
579
580
581
582
583
584
  }
  
  #ifdef CONFIG_X86_32
  static inline int default_cpu_present_to_apicid(int mps_cpu)
  {
  	return __default_cpu_present_to_apicid(mps_cpu);
  }
  
  static inline int
e11dadabf   Thomas Gleixner   x86: apic namespa...
585
  default_check_phys_apicid_present(int phys_apicid)
e2780a68f   Ingo Molnar   x86, apic: merge ...
586
  {
e11dadabf   Thomas Gleixner   x86: apic namespa...
587
  	return __default_check_phys_apicid_present(phys_apicid);
e2780a68f   Ingo Molnar   x86, apic: merge ...
588
589
590
  }
  #else
  extern int default_cpu_present_to_apicid(int mps_cpu);
e11dadabf   Thomas Gleixner   x86: apic namespa...
591
  extern int default_check_phys_apicid_present(int phys_apicid);
e2780a68f   Ingo Molnar   x86, apic: merge ...
592
  #endif
e2780a68f   Ingo Molnar   x86, apic: merge ...
593
  #endif /* CONFIG_X86_LOCAL_APIC */
1965aae3c   H. Peter Anvin   x86: Fix ASM_X86_...
594
  #endif /* _ASM_X86_APIC_H */