aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-x86/system.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/asm-x86/system.h')
-rw-r--r--include/asm-x86/system.h69
1 files changed, 69 insertions, 0 deletions
diff --git a/include/asm-x86/system.h b/include/asm-x86/system.h
index 692562b48f2a..d0803f8c70c4 100644
--- a/include/asm-x86/system.h
+++ b/include/asm-x86/system.h
@@ -1,5 +1,74 @@
1#ifndef _ASM_X86_SYSTEM_H_
2#define _ASM_X86_SYSTEM_H_
3
4#include <asm/asm.h>
5
1#ifdef CONFIG_X86_32 6#ifdef CONFIG_X86_32
2# include "system_32.h" 7# include "system_32.h"
3#else 8#else
4# include "system_64.h" 9# include "system_64.h"
5#endif 10#endif
11
12#ifdef __KERNEL__
13#define _set_base(addr, base) do { unsigned long __pr; \
14__asm__ __volatile__ ("movw %%dx,%1\n\t" \
15 "rorl $16,%%edx\n\t" \
16 "movb %%dl,%2\n\t" \
17 "movb %%dh,%3" \
18 :"=&d" (__pr) \
19 :"m" (*((addr)+2)), \
20 "m" (*((addr)+4)), \
21 "m" (*((addr)+7)), \
22 "0" (base) \
23 ); } while (0)
24
25#define _set_limit(addr, limit) do { unsigned long __lr; \
26__asm__ __volatile__ ("movw %%dx,%1\n\t" \
27 "rorl $16,%%edx\n\t" \
28 "movb %2,%%dh\n\t" \
29 "andb $0xf0,%%dh\n\t" \
30 "orb %%dh,%%dl\n\t" \
31 "movb %%dl,%2" \
32 :"=&d" (__lr) \
33 :"m" (*(addr)), \
34 "m" (*((addr)+6)), \
35 "0" (limit) \
36 ); } while (0)
37
38#define set_base(ldt, base) _set_base(((char *)&(ldt)) , (base))
39#define set_limit(ldt, limit) _set_limit(((char *)&(ldt)) , ((limit)-1))
40
41/*
42 * Save a segment register away
43 */
44#define savesegment(seg, value) \
45 asm volatile("mov %%" #seg ",%0":"=rm" (value))
46
47static inline unsigned long get_limit(unsigned long segment)
48{
49 unsigned long __limit;
50 __asm__("lsll %1,%0"
51 :"=r" (__limit):"r" (segment));
52 return __limit+1;
53}
54#endif /* __KERNEL__ */
55
56static inline void clflush(void *__p)
57{
58 asm volatile("clflush %0" : "+m" (*(char __force *)__p));
59}
60
61#define nop() __asm__ __volatile__ ("nop")
62
63void disable_hlt(void);
64void enable_hlt(void);
65
66extern int es7000_plat;
67void cpu_idle_wait(void);
68
69extern unsigned long arch_align_stack(unsigned long sp);
70extern void free_init_pages(char *what, unsigned long begin, unsigned long end);
71
72void default_idle(void);
73
74#endif