fix build regression on ARM for ISA levels less than v5
authorRich Felker <dalias@aerifal.cx>
Wed, 25 Oct 2017 15:54:16 +0000 (11:54 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 25 Oct 2017 15:54:16 +0000 (11:54 -0400)
commit 06fbefd10046a0fae7e588b7c6d25fb51811b931 (first included in
release 1.1.17) introduced this regression.

patch by Adrian Bunk. it fixes the regression in all cases, but
spuriously prevents use of the clz instruction on very old compiler
versions that don't define __ARM_ARCH. this may be fixed in a more
general way at some point in the future. it also omits thumb1 logic
since building as thumb1 code is currently not supported.

arch/arm/atomic_arch.h

index a121010f4a208b28a7ce27aec9242e433094add3..c5c56f81214930bbec8cc59d8adb82eb4feee259 100644 (file)
@@ -82,9 +82,13 @@ static inline void a_crash()
                : : : "memory");
 }
 
+#if __ARM_ARCH >= 5
+
 #define a_clz_32 a_clz_32
 static inline int a_clz_32(uint32_t x)
 {
        __asm__ ("clz %0, %1" : "=r"(x) : "r"(x));
        return x;
 }
+
+#endif