x86: cpufeature: add Intel features from CPUID and AVX specs
[linux-2.6] / include / asm-x86 / asm.h
1 #ifndef _ASM_X86_ASM_H
2 #define _ASM_X86_ASM_H
3
4 #ifdef __ASSEMBLY__
5 # define __ASM_FORM(x)  x
6 # define __ASM_EX_SEC   .section __ex_table
7 #else
8 # define __ASM_FORM(x)  " " #x " "
9 # define __ASM_EX_SEC   " .section __ex_table,\"a\"\n"
10 #endif
11
12 #ifdef CONFIG_X86_32
13 # define __ASM_SEL(a,b) __ASM_FORM(a)
14 #else
15 # define __ASM_SEL(a,b) __ASM_FORM(b)
16 #endif
17
18 #define __ASM_SIZE(inst)        __ASM_SEL(inst##l, inst##q)
19 #define __ASM_REG(reg)          __ASM_SEL(e##reg, r##reg)
20
21 #define _ASM_PTR        __ASM_SEL(.long, .quad)
22 #define _ASM_ALIGN      __ASM_SEL(.balign 4, .balign 8)
23 #define _ASM_MOV_UL     __ASM_SIZE(mov)
24
25 #define _ASM_INC        __ASM_SIZE(inc)
26 #define _ASM_DEC        __ASM_SIZE(dec)
27 #define _ASM_ADD        __ASM_SIZE(add)
28 #define _ASM_SUB        __ASM_SIZE(sub)
29 #define _ASM_XADD       __ASM_SIZE(xadd)
30 #define _ASM_AX         __ASM_REG(ax)
31 #define _ASM_BX         __ASM_REG(bx)
32 #define _ASM_CX         __ASM_REG(cx)
33 #define _ASM_DX         __ASM_REG(dx)
34
35 /* Exception table entry */
36 # define _ASM_EXTABLE(from,to) \
37         __ASM_EX_SEC    \
38         _ASM_ALIGN "\n" \
39         _ASM_PTR #from "," #to "\n" \
40         " .previous\n"
41
42 #endif /* _ASM_X86_ASM_H */