| 
									
										
										
										
											2008-10-22 22:26:29 -07:00
										 |  |  | #ifndef _ASM_X86_ASM_H
 | 
					
						
							|  |  |  | #define _ASM_X86_ASM_H
 | 
					
						
							| 
									
										
										
										
											2008-01-30 13:30:06 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-16 16:08:17 -07:00
										 |  |  | #ifdef __ASSEMBLY__
 | 
					
						
							|  |  |  | # define __ASM_FORM(x)	x
 | 
					
						
							| 
									
										
										
										
											2011-07-19 13:00:45 +01:00
										 |  |  | # define __ASM_FORM_COMMA(x) x,
 | 
					
						
							| 
									
										
										
										
											2008-06-16 16:08:17 -07:00
										 |  |  | #else
 | 
					
						
							|  |  |  | # define __ASM_FORM(x)	" " #x " "
 | 
					
						
							| 
									
										
										
										
											2011-07-19 13:00:45 +01:00
										 |  |  | # define __ASM_FORM_COMMA(x) " " #x ","
 | 
					
						
							| 
									
										
										
										
											2008-06-16 16:08:17 -07:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-01-30 13:31:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-16 16:08:17 -07:00
										 |  |  | #ifdef CONFIG_X86_32
 | 
					
						
							|  |  |  | # define __ASM_SEL(a,b) __ASM_FORM(a)
 | 
					
						
							| 
									
										
										
										
											2008-01-30 13:30:06 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2008-06-16 16:08:17 -07:00
										 |  |  | # define __ASM_SEL(a,b) __ASM_FORM(b)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-01-30 13:30:06 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-19 12:59:51 +01:00
										 |  |  | #define __ASM_SIZE(inst, ...)	__ASM_SEL(inst##l##__VA_ARGS__, \
 | 
					
						
							|  |  |  | 					  inst##q##__VA_ARGS__) | 
					
						
							| 
									
										
										
										
											2008-06-24 11:37:57 -03:00
										 |  |  | #define __ASM_REG(reg)		__ASM_SEL(e##reg, r##reg)
 | 
					
						
							| 
									
										
										
										
											2008-01-30 13:30:06 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-16 16:08:17 -07:00
										 |  |  | #define _ASM_PTR	__ASM_SEL(.long, .quad)
 | 
					
						
							|  |  |  | #define _ASM_ALIGN	__ASM_SEL(.balign 4, .balign 8)
 | 
					
						
							| 
									
										
										
										
											2008-01-30 13:31:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-18 18:13:33 -07:00
										 |  |  | #define _ASM_MOV	__ASM_SIZE(mov)
 | 
					
						
							| 
									
										
										
										
											2008-06-16 16:08:17 -07:00
										 |  |  | #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)
 | 
					
						
							| 
									
										
										
										
											2008-08-18 18:13:33 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-24 11:37:57 -03:00
										 |  |  | #define _ASM_AX		__ASM_REG(ax)
 | 
					
						
							| 
									
										
										
										
											2008-06-24 17:36:31 -03:00
										 |  |  | #define _ASM_BX		__ASM_REG(bx)
 | 
					
						
							|  |  |  | #define _ASM_CX		__ASM_REG(cx)
 | 
					
						
							| 
									
										
										
										
											2008-06-24 11:37:57 -03:00
										 |  |  | #define _ASM_DX		__ASM_REG(dx)
 | 
					
						
							| 
									
										
										
										
											2008-08-18 18:13:33 -07:00
										 |  |  | #define _ASM_SP		__ASM_REG(sp)
 | 
					
						
							|  |  |  | #define _ASM_BP		__ASM_REG(bp)
 | 
					
						
							|  |  |  | #define _ASM_SI		__ASM_REG(si)
 | 
					
						
							|  |  |  | #define _ASM_DI		__ASM_REG(di)
 | 
					
						
							| 
									
										
										
										
											2008-01-30 13:30:06 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-04 16:47:56 +01:00
										 |  |  | /* Exception table entry */ | 
					
						
							| 
									
										
										
										
											2009-08-31 11:57:20 -07:00
										 |  |  | #ifdef __ASSEMBLY__
 | 
					
						
							| 
									
										
										
										
											2012-04-20 16:57:35 -07:00
										 |  |  | # define _ASM_EXTABLE(from,to)					\
 | 
					
						
							|  |  |  | 	.pushsection "__ex_table","a" ;				\ | 
					
						
							| 
									
										
										
										
											2012-04-20 17:12:48 -07:00
										 |  |  | 	.balign 8 ;						\ | 
					
						
							|  |  |  | 	.long (from) - . ;					\ | 
					
						
							|  |  |  | 	.long (to) - . ;					\ | 
					
						
							| 
									
										
										
										
											2012-04-20 16:57:35 -07:00
										 |  |  | 	.popsection | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # define _ASM_EXTABLE_EX(from,to)				\
 | 
					
						
							|  |  |  | 	.pushsection "__ex_table","a" ;				\ | 
					
						
							| 
									
										
										
										
											2012-04-20 17:12:48 -07:00
										 |  |  | 	.balign 8 ;						\ | 
					
						
							|  |  |  | 	.long (from) - . ;					\ | 
					
						
							|  |  |  | 	.long (to) - . + 0x7ffffff0 ;				\ | 
					
						
							| 
									
										
										
										
											2012-04-20 12:12:27 -07:00
										 |  |  | 	.popsection | 
					
						
							| 
									
										
										
										
											2009-08-31 11:57:20 -07:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2012-04-20 16:57:35 -07:00
										 |  |  | # define _ASM_EXTABLE(from,to)					\
 | 
					
						
							|  |  |  | 	" .pushsection \"__ex_table\",\"a\"\n"			\ | 
					
						
							| 
									
										
										
										
											2012-04-20 17:12:48 -07:00
										 |  |  | 	" .balign 8\n"						\ | 
					
						
							|  |  |  | 	" .long (" #from ") - .\n"				\ | 
					
						
							|  |  |  | 	" .long (" #to ") - .\n"				\ | 
					
						
							| 
									
										
										
										
											2012-04-20 16:57:35 -07:00
										 |  |  | 	" .popsection\n" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # define _ASM_EXTABLE_EX(from,to)				\
 | 
					
						
							|  |  |  | 	" .pushsection \"__ex_table\",\"a\"\n"			\ | 
					
						
							| 
									
										
										
										
											2012-04-20 17:12:48 -07:00
										 |  |  | 	" .balign 8\n"						\ | 
					
						
							|  |  |  | 	" .long (" #from ") - .\n"				\ | 
					
						
							|  |  |  | 	" .long (" #to ") - . + 0x7ffffff0\n"			\ | 
					
						
							| 
									
										
										
										
											2012-04-20 12:12:27 -07:00
										 |  |  | 	" .popsection\n" | 
					
						
							| 
									
										
										
										
											2009-08-31 11:57:20 -07:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-02-04 16:47:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-10-22 22:26:29 -07:00
										 |  |  | #endif /* _ASM_X86_ASM_H */
 |