41 lines
1.5 KiB
Diff
41 lines
1.5 KiB
Diff
--- source/include/asm-alpha/compiler.h.orig 2006-09-19 20:42:06.000000000 -0700
|
|
+++ source/include/asm-alpha/compiler.h 2006-11-06 17:10:00.000000000 -0800
|
|
@@ -78,16 +78,20 @@
|
|
#else
|
|
#define __kernel_ldbu(mem) \
|
|
({ unsigned char __kir; \
|
|
- __asm__("ldbu %0,%1" : "=r"(__kir) : "m"(mem)); \
|
|
+ __asm__(".arch ev56; \
|
|
+ ldbu %0,%1" : "=r"(__kir) : "m"(mem)); \
|
|
__kir; })
|
|
#define __kernel_ldwu(mem) \
|
|
({ unsigned short __kir; \
|
|
- __asm__("ldwu %0,%1" : "=r"(__kir) : "m"(mem)); \
|
|
+ __asm__(".arch ev56; \
|
|
+ ldwu %0,%1" : "=r"(__kir) : "m"(mem)); \
|
|
__kir; })
|
|
-#define __kernel_stb(val,mem) \
|
|
- __asm__("stb %1,%0" : "=m"(mem) : "r"(val))
|
|
-#define __kernel_stw(val,mem) \
|
|
- __asm__("stw %1,%0" : "=m"(mem) : "r"(val))
|
|
+#define __kernel_stb(val,mem) \
|
|
+ __asm__(".arch ev56; \
|
|
+ stb %1,%0" : "=m"(mem) : "r"(val))
|
|
+#define __kernel_stw(val,mem) \
|
|
+ __asm__(".arch ev56; \
|
|
+ stw %1,%0" : "=m"(mem) : "r"(val))
|
|
#endif
|
|
|
|
#ifdef __KERNEL__
|
|
--- source/arch/alpha/kernel/sys_titan.c.orig 2006-11-06 23:17:50.000000000 -0800
|
|
+++ source/arch/alpha/kernel/sys_titan.c 2006-11-06 23:17:04.000000000 -0800
|
|
@@ -257,7 +257,7 @@
|
|
*/
|
|
while (mask) {
|
|
/* convert to SRM vector... priority is <63> -> <0> */
|
|
- __asm__("ctlz %1, %0" : "=r"(vector) : "r"(mask));
|
|
+ __asm__(".arch ev6; ctlz %1, %0" : "=r"(vector) : "r"(mask));
|
|
vector = 63 - vector;
|
|
mask &= ~(1UL << vector); /* clear it out */
|
|
vector = 0x900 + (vector << 4); /* convert to SRM vector */
|