| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 1 | #ifndef _ASM_POWERPC_ASM_COMPAT_H | 
|  | 2 | #define _ASM_POWERPC_ASM_COMPAT_H | 
|  | 3 |  | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 4 | #include <asm/types.h> | 
| Anton Blanchard | 864b9e6 | 2010-02-10 01:02:36 +0000 | [diff] [blame] | 5 | #include <asm/ppc-opcode.h> | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 6 |  | 
|  | 7 | #ifdef __ASSEMBLY__ | 
|  | 8 | #  define stringify_in_c(...)	__VA_ARGS__ | 
|  | 9 | #  define ASM_CONST(x)		x | 
|  | 10 | #else | 
|  | 11 | /* This version of stringify will deal with commas... */ | 
|  | 12 | #  define __stringify_in_c(...)	#__VA_ARGS__ | 
|  | 13 | #  define stringify_in_c(...)	__stringify_in_c(__VA_ARGS__) " " | 
|  | 14 | #  define __ASM_CONST(x)	x##UL | 
|  | 15 | #  define ASM_CONST(x)		__ASM_CONST(x) | 
|  | 16 | #endif | 
|  | 17 |  | 
| Benjamin Herrenschmidt | 0909c8c | 2006-10-20 11:47:18 +1000 | [diff] [blame] | 18 |  | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 19 | #ifdef __powerpc64__ | 
|  | 20 |  | 
|  | 21 | /* operations for longs and pointers */ | 
|  | 22 | #define PPC_LL		stringify_in_c(ld) | 
|  | 23 | #define PPC_STL		stringify_in_c(std) | 
| Alexander Graf | 56db45a | 2010-04-16 00:11:43 +0200 | [diff] [blame] | 24 | #define PPC_STLU	stringify_in_c(stdu) | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 25 | #define PPC_LCMPI	stringify_in_c(cmpdi) | 
|  | 26 | #define PPC_LONG	stringify_in_c(.llong) | 
| Michael Ellerman | 6a2a24b | 2008-07-17 17:17:51 +1000 | [diff] [blame] | 27 | #define PPC_LONG_ALIGN	stringify_in_c(.balign 8) | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 28 | #define PPC_TLNEI	stringify_in_c(tdnei) | 
| Anton Blanchard | 864b9e6 | 2010-02-10 01:02:36 +0000 | [diff] [blame] | 29 | #define PPC_LLARX(t, a, b, eh)	PPC_LDARX(t, a, b, eh) | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 30 | #define PPC_STLCX	stringify_in_c(stdcx.) | 
|  | 31 | #define PPC_CNTLZL	stringify_in_c(cntlzd) | 
| Paul Mackerras | 9eff26e | 2010-03-18 16:05:13 +1100 | [diff] [blame] | 32 | #define PPC_LR_STKOFF	16 | 
| Paul Mackerras | 0016a4c | 2010-06-15 14:48:58 +1000 | [diff] [blame] | 33 | #define PPC_MIN_STKFRM	112 | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 34 |  | 
| Olof Johansson | 3467bfd | 2007-03-22 09:34:13 -0500 | [diff] [blame] | 35 | /* Move to CR, single-entry optimized version. Only available | 
|  | 36 | * on POWER4 and later. | 
|  | 37 | */ | 
|  | 38 | #ifdef CONFIG_POWER4_ONLY | 
|  | 39 | #define PPC_MTOCRF	stringify_in_c(mtocrf) | 
|  | 40 | #else | 
|  | 41 | #define PPC_MTOCRF	stringify_in_c(mtcrf) | 
|  | 42 | #endif | 
|  | 43 |  | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 44 | #else /* 32-bit */ | 
|  | 45 |  | 
|  | 46 | /* operations for longs and pointers */ | 
|  | 47 | #define PPC_LL		stringify_in_c(lwz) | 
|  | 48 | #define PPC_STL		stringify_in_c(stw) | 
| Alexander Graf | 56db45a | 2010-04-16 00:11:43 +0200 | [diff] [blame] | 49 | #define PPC_STLU	stringify_in_c(stwu) | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 50 | #define PPC_LCMPI	stringify_in_c(cmpwi) | 
|  | 51 | #define PPC_LONG	stringify_in_c(.long) | 
| Michael Ellerman | 6a2a24b | 2008-07-17 17:17:51 +1000 | [diff] [blame] | 52 | #define PPC_LONG_ALIGN	stringify_in_c(.balign 4) | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 53 | #define PPC_TLNEI	stringify_in_c(twnei) | 
| Anton Blanchard | 864b9e6 | 2010-02-10 01:02:36 +0000 | [diff] [blame] | 54 | #define PPC_LLARX(t, a, b, eh)	PPC_LWARX(t, a, b, eh) | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 55 | #define PPC_STLCX	stringify_in_c(stwcx.) | 
|  | 56 | #define PPC_CNTLZL	stringify_in_c(cntlzw) | 
| Olof Johansson | 3467bfd | 2007-03-22 09:34:13 -0500 | [diff] [blame] | 57 | #define PPC_MTOCRF	stringify_in_c(mtcrf) | 
| Paul Mackerras | 9eff26e | 2010-03-18 16:05:13 +1100 | [diff] [blame] | 58 | #define PPC_LR_STKOFF	4 | 
| Paul Mackerras | 0016a4c | 2010-06-15 14:48:58 +1000 | [diff] [blame] | 59 | #define PPC_MIN_STKFRM	16 | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 60 |  | 
|  | 61 | #endif | 
|  | 62 |  | 
| Arnd Bergmann | 88ced03 | 2005-12-16 22:43:46 +0100 | [diff] [blame] | 63 | #ifdef __KERNEL__ | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 64 | #ifdef CONFIG_IBM405_ERR77 | 
|  | 65 | /* Erratum #77 on the 405 means we need a sync or dcbt before every | 
|  | 66 | * stwcx.  The old ATOMIC_SYNC_FIX covered some but not all of this. | 
|  | 67 | */ | 
|  | 68 | #define PPC405_ERR77(ra,rb)	stringify_in_c(dcbt	ra, rb;) | 
|  | 69 | #define	PPC405_ERR77_SYNC	stringify_in_c(sync;) | 
|  | 70 | #else | 
|  | 71 | #define PPC405_ERR77(ra,rb) | 
|  | 72 | #define PPC405_ERR77_SYNC | 
|  | 73 | #endif | 
| Arnd Bergmann | 88ced03 | 2005-12-16 22:43:46 +0100 | [diff] [blame] | 74 | #endif | 
| David Gibson | 3ddfbcf | 2005-11-10 12:56:55 +1100 | [diff] [blame] | 75 |  | 
|  | 76 | #endif /* _ASM_POWERPC_ASM_COMPAT_H */ |