提交 88ed39b0 编写于 作者: I Ivan Kokshaysky 提交者: Linus Torvalds

alpha: build fixes - force architecture

Override compiler .arch directive for generic kernel build.
Signed-off-by: NIvan Kokshaysky <ink@jurassic.park.msu.ru>
Signed-off-by: NRichard Henderson <rth@twiddle.net>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 7fc1a1ab
...@@ -257,8 +257,7 @@ titan_dispatch_irqs(u64 mask) ...@@ -257,8 +257,7 @@ titan_dispatch_irqs(u64 mask)
*/ */
while (mask) { while (mask) {
/* convert to SRM vector... priority is <63> -> <0> */ /* convert to SRM vector... priority is <63> -> <0> */
__asm__("ctlz %1, %0" : "=r"(vector) : "r"(mask)); vector = 63 - __kernel_ctlz(mask);
vector = 63 - vector;
mask &= ~(1UL << vector); /* clear it out */ mask &= ~(1UL << vector); /* clear it out */
vector = 0x900 + (vector << 4); /* convert to SRM vector */ vector = 0x900 + (vector << 4); /* convert to SRM vector */
......
...@@ -17,9 +17,6 @@ ...@@ -17,9 +17,6 @@
# define __kernel_extbl(val, shift) __builtin_alpha_extbl(val, shift) # define __kernel_extbl(val, shift) __builtin_alpha_extbl(val, shift)
# define __kernel_extwl(val, shift) __builtin_alpha_extwl(val, shift) # define __kernel_extwl(val, shift) __builtin_alpha_extwl(val, shift)
# define __kernel_cmpbge(a, b) __builtin_alpha_cmpbge(a, b) # define __kernel_cmpbge(a, b) __builtin_alpha_cmpbge(a, b)
# define __kernel_cttz(x) __builtin_ctzl(x)
# define __kernel_ctlz(x) __builtin_clzl(x)
# define __kernel_ctpop(x) __builtin_popcountl(x)
#else #else
# define __kernel_insbl(val, shift) \ # define __kernel_insbl(val, shift) \
({ unsigned long __kir; \ ({ unsigned long __kir; \
...@@ -49,17 +46,39 @@ ...@@ -49,17 +46,39 @@
({ unsigned long __kir; \ ({ unsigned long __kir; \
__asm__("cmpbge %r2,%1,%0" : "=r"(__kir) : "rI"(b), "rJ"(a)); \ __asm__("cmpbge %r2,%1,%0" : "=r"(__kir) : "rI"(b), "rJ"(a)); \
__kir; }) __kir; })
#endif
#ifdef __alpha_cix__
# if __GNUC__ == 3 && __GNUC_MINOR__ >= 4 || __GNUC__ > 3
# define __kernel_cttz(x) __builtin_ctzl(x)
# define __kernel_ctlz(x) __builtin_clzl(x)
# define __kernel_ctpop(x) __builtin_popcountl(x)
# else
# define __kernel_cttz(x) \
({ unsigned long __kir; \
__asm__("cttz %1,%0" : "=r"(__kir) : "r"(x)); \
__kir; })
# define __kernel_ctlz(x) \
({ unsigned long __kir; \
__asm__("ctlz %1,%0" : "=r"(__kir) : "r"(x)); \
__kir; })
# define __kernel_ctpop(x) \
({ unsigned long __kir; \
__asm__("ctpop %1,%0" : "=r"(__kir) : "r"(x)); \
__kir; })
# endif
#else
# define __kernel_cttz(x) \ # define __kernel_cttz(x) \
({ unsigned long __kir; \ ({ unsigned long __kir; \
__asm__("cttz %1,%0" : "=r"(__kir) : "r"(x)); \ __asm__(".arch ev67; cttz %1,%0" : "=r"(__kir) : "r"(x)); \
__kir; }) __kir; })
# define __kernel_ctlz(x) \ # define __kernel_ctlz(x) \
({ unsigned long __kir; \ ({ unsigned long __kir; \
__asm__("ctlz %1,%0" : "=r"(__kir) : "r"(x)); \ __asm__(".arch ev67; ctlz %1,%0" : "=r"(__kir) : "r"(x)); \
__kir; }) __kir; })
# define __kernel_ctpop(x) \ # define __kernel_ctpop(x) \
({ unsigned long __kir; \ ({ unsigned long __kir; \
__asm__("ctpop %1,%0" : "=r"(__kir) : "r"(x)); \ __asm__(".arch ev67; ctpop %1,%0" : "=r"(__kir) : "r"(x)); \
__kir; }) __kir; })
#endif #endif
...@@ -78,16 +97,20 @@ ...@@ -78,16 +97,20 @@
#else #else
#define __kernel_ldbu(mem) \ #define __kernel_ldbu(mem) \
({ unsigned char __kir; \ ({ unsigned char __kir; \
__asm__("ldbu %0,%1" : "=r"(__kir) : "m"(mem)); \ __asm__(".arch ev56; \
ldbu %0,%1" : "=r"(__kir) : "m"(mem)); \
__kir; }) __kir; })
#define __kernel_ldwu(mem) \ #define __kernel_ldwu(mem) \
({ unsigned short __kir; \ ({ unsigned short __kir; \
__asm__("ldwu %0,%1" : "=r"(__kir) : "m"(mem)); \ __asm__(".arch ev56; \
ldwu %0,%1" : "=r"(__kir) : "m"(mem)); \
__kir; }) __kir; })
#define __kernel_stb(val,mem) \ #define __kernel_stb(val,mem) \
__asm__("stb %1,%0" : "=m"(mem) : "r"(val)) __asm__(".arch ev56; \
#define __kernel_stw(val,mem) \ stb %1,%0" : "=m"(mem) : "r"(val))
__asm__("stw %1,%0" : "=m"(mem) : "r"(val)) #define __kernel_stw(val,mem) \
__asm__(".arch ev56; \
stw %1,%0" : "=m"(mem) : "r"(val))
#endif #endif
#ifdef __KERNEL__ #ifdef __KERNEL__
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册