From: Christian Borntraeger Date: Mon, 7 Nov 2005 08:59:07 +0000 (-0800) Subject: [PATCH] s390: test_bit return value X-Git-Tag: v2.6.15-rc1~644 X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=187dfc67b461058bbb84a923a17871ed54e10f30;p=linux-2.6 [PATCH] s390: test_bit return value The test_bit function returns a non-boolean value, it returns 0,1,2,4,... instead of only 0 or 1. This causes wrongs results in the mincore system call. Check against 0 to get a proper boolean value. Signed-off-by: Christian Borntraeger Signed-off-by: Martin Schwidefsky Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds --- diff --git a/include/asm-s390/bitops.h b/include/asm-s390/bitops.h index 8651524217..b07c578b22 100644 --- a/include/asm-s390/bitops.h +++ b/include/asm-s390/bitops.h @@ -518,8 +518,8 @@ static inline int __test_bit(unsigned long nr, const volatile unsigned long *ptr static inline int __constant_test_bit(unsigned long nr, const volatile unsigned long *addr) { - return (((volatile char *) addr) - [(nr^(__BITOPS_WORDSIZE-8))>>3] & (1<<(nr&7))); + return ((((volatile char *) addr) + [(nr^(__BITOPS_WORDSIZE-8))>>3] & (1<<(nr&7)))) != 0; } #define test_bit(nr,addr) \