asm.h 1.4 KB
Newer Older
H
H. Peter Anvin 已提交
1 2
#ifndef _ASM_X86_ASM_H
#define _ASM_X86_ASM_H
H
H. Peter Anvin 已提交
3

4 5
#ifdef __ASSEMBLY__
# define __ASM_FORM(x)	x
6
# define __ASM_FORM_COMMA(x) x,
7
# define __ASM_EX_SEC	.section __ex_table, "a"
8 9
#else
# define __ASM_FORM(x)	" " #x " "
10
# define __ASM_FORM_COMMA(x) " " #x ","
11
# define __ASM_EX_SEC	" .section __ex_table,\"a\"\n"
12
#endif
13

14 15
#ifdef CONFIG_X86_32
# define __ASM_SEL(a,b) __ASM_FORM(a)
H
H. Peter Anvin 已提交
16
#else
17 18
# define __ASM_SEL(a,b) __ASM_FORM(b)
#endif
H
H. Peter Anvin 已提交
19

20 21
#define __ASM_SIZE(inst, ...)	__ASM_SEL(inst##l##__VA_ARGS__, \
					  inst##q##__VA_ARGS__)
G
Glauber Costa 已提交
22
#define __ASM_REG(reg)		__ASM_SEL(e##reg, r##reg)
H
H. Peter Anvin 已提交
23

24 25
#define _ASM_PTR	__ASM_SEL(.long, .quad)
#define _ASM_ALIGN	__ASM_SEL(.balign 4, .balign 8)
26

27
#define _ASM_MOV	__ASM_SIZE(mov)
28 29 30 31 32
#define _ASM_INC	__ASM_SIZE(inc)
#define _ASM_DEC	__ASM_SIZE(dec)
#define _ASM_ADD	__ASM_SIZE(add)
#define _ASM_SUB	__ASM_SIZE(sub)
#define _ASM_XADD	__ASM_SIZE(xadd)
33

G
Glauber Costa 已提交
34
#define _ASM_AX		__ASM_REG(ax)
G
Glauber Costa 已提交
35 36
#define _ASM_BX		__ASM_REG(bx)
#define _ASM_CX		__ASM_REG(cx)
G
Glauber Costa 已提交
37
#define _ASM_DX		__ASM_REG(dx)
38 39 40 41
#define _ASM_SP		__ASM_REG(sp)
#define _ASM_BP		__ASM_REG(bp)
#define _ASM_SI		__ASM_REG(si)
#define _ASM_DI		__ASM_REG(di)
H
H. Peter Anvin 已提交
42

43
/* Exception table entry */
44 45 46 47 48 49 50
#ifdef __ASSEMBLY__
# define _ASM_EXTABLE(from,to)	    \
	__ASM_EX_SEC ;		    \
	_ASM_ALIGN ;		    \
	_ASM_PTR from , to ;	    \
	.previous
#else
51
# define _ASM_EXTABLE(from,to) \
52
	__ASM_EX_SEC	\
53 54 55
	_ASM_ALIGN "\n" \
	_ASM_PTR #from "," #to "\n" \
	" .previous\n"
56
#endif
57

H
H. Peter Anvin 已提交
58
#endif /* _ASM_X86_ASM_H */