lib: Only test atomic64_dec_if_positive on archs having it
authorLuca Barbieri <luca@luca-barbieri.com>
Fri, 26 Feb 2010 11:22:40 +0000 (12:22 +0100)
committerH. Peter Anvin <hpa@zytor.com>
Mon, 1 Mar 2010 19:37:55 +0000 (11:37 -0800)
Currently atomic64_dec_if_positive() is only supported by PowerPC,
MIPS and x86-32.

Signed-off-by: Luca Barbieri <luca@luca-barbieri.com>
LKML-Reference: <1267183361-20775-1-git-send-email-luca@luca-barbieri.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
lib/atomic64_test.c

index 4ff649e46bad24936694920112c220b70b06f013..0effcacbebda1a1ad295d4c6e4bf0d5efab358cc 100644 (file)
@@ -112,6 +112,7 @@ static __init int test_atomic64(void)
        r += one;
        BUG_ON(v.counter != r);
 
+#if defined(CONFIG_X86_32) || defined(CONFIG_MIPS) || defined(CONFIG_PPC) || defined(_ASM_GENERIC_ATOMIC64_H)
        INIT(onestwos);
        BUG_ON(atomic64_dec_if_positive(&v) != (onestwos - 1));
        r -= one;
@@ -124,6 +125,9 @@ static __init int test_atomic64(void)
        INIT(-one);
        BUG_ON(atomic64_dec_if_positive(&v) != (-one - one));
        BUG_ON(v.counter != r);
+#else
+#warning Please implement atomic64_dec_if_positive for your architecture, and add it to the IF above
+#endif
 
        INIT(onestwos);
        BUG_ON(atomic64_inc_not_zero(&v));