blob: 329e696e77516c8511ec0a04972aeefafabf16d3 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/* $Id: bitops.h,v 1.67 2001/11/19 18:36:34 davem Exp $
2 * bitops.h: Bit string operations on the Sparc.
3 *
4 * Copyright 1995 David S. Miller (davem@caip.rutgers.edu)
5 * Copyright 1996 Eddie C. Dost (ecd@skynet.be)
6 * Copyright 2001 Anton Blanchard (anton@samba.org)
7 */
8
9#ifndef _SPARC_BITOPS_H
10#define _SPARC_BITOPS_H
11
12#include <linux/compiler.h>
13#include <asm/byteorder.h>
14
15#ifdef __KERNEL__
16
David S. Miller8a8b8362006-12-17 16:18:47 -080017extern unsigned long ___set_bit(unsigned long *addr, unsigned long mask);
18extern unsigned long ___clear_bit(unsigned long *addr, unsigned long mask);
19extern unsigned long ___change_bit(unsigned long *addr, unsigned long mask);
20
Linus Torvalds1da177e2005-04-16 15:20:36 -070021/*
22 * Set bit 'nr' in 32-bit quantity at address 'addr' where bit '0'
23 * is in the highest of the four bytes and bit '31' is the high bit
24 * within the first byte. Sparc is BIG-Endian. Unless noted otherwise
25 * all bit-ops return 0 if bit was previously clear and != 0 otherwise.
26 */
27static inline int test_and_set_bit(unsigned long nr, volatile unsigned long *addr)
28{
David S. Miller8a8b8362006-12-17 16:18:47 -080029 unsigned long *ADDR, mask;
Linus Torvalds1da177e2005-04-16 15:20:36 -070030
31 ADDR = ((unsigned long *) addr) + (nr >> 5);
32 mask = 1 << (nr & 31);
33
David S. Miller8a8b8362006-12-17 16:18:47 -080034 return ___set_bit(ADDR, mask) != 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070035}
36
37static inline void set_bit(unsigned long nr, volatile unsigned long *addr)
38{
David S. Miller8a8b8362006-12-17 16:18:47 -080039 unsigned long *ADDR, mask;
Linus Torvalds1da177e2005-04-16 15:20:36 -070040
41 ADDR = ((unsigned long *) addr) + (nr >> 5);
42 mask = 1 << (nr & 31);
43
David S. Miller8a8b8362006-12-17 16:18:47 -080044 (void) ___set_bit(ADDR, mask);
Linus Torvalds1da177e2005-04-16 15:20:36 -070045}
46
47static inline int test_and_clear_bit(unsigned long nr, volatile unsigned long *addr)
48{
David S. Miller8a8b8362006-12-17 16:18:47 -080049 unsigned long *ADDR, mask;
Linus Torvalds1da177e2005-04-16 15:20:36 -070050
51 ADDR = ((unsigned long *) addr) + (nr >> 5);
52 mask = 1 << (nr & 31);
53
David S. Miller8a8b8362006-12-17 16:18:47 -080054 return ___clear_bit(ADDR, mask) != 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070055}
56
57static inline void clear_bit(unsigned long nr, volatile unsigned long *addr)
58{
David S. Miller8a8b8362006-12-17 16:18:47 -080059 unsigned long *ADDR, mask;
Linus Torvalds1da177e2005-04-16 15:20:36 -070060
61 ADDR = ((unsigned long *) addr) + (nr >> 5);
62 mask = 1 << (nr & 31);
63
David S. Miller8a8b8362006-12-17 16:18:47 -080064 (void) ___clear_bit(ADDR, mask);
Linus Torvalds1da177e2005-04-16 15:20:36 -070065}
66
67static inline int test_and_change_bit(unsigned long nr, volatile unsigned long *addr)
68{
David S. Miller8a8b8362006-12-17 16:18:47 -080069 unsigned long *ADDR, mask;
Linus Torvalds1da177e2005-04-16 15:20:36 -070070
71 ADDR = ((unsigned long *) addr) + (nr >> 5);
72 mask = 1 << (nr & 31);
73
David S. Miller8a8b8362006-12-17 16:18:47 -080074 return ___change_bit(ADDR, mask) != 0;
Linus Torvalds1da177e2005-04-16 15:20:36 -070075}
76
77static inline void change_bit(unsigned long nr, volatile unsigned long *addr)
78{
David S. Miller8a8b8362006-12-17 16:18:47 -080079 unsigned long *ADDR, mask;
Linus Torvalds1da177e2005-04-16 15:20:36 -070080
81 ADDR = ((unsigned long *) addr) + (nr >> 5);
82 mask = 1 << (nr & 31);
83
David S. Miller8a8b8362006-12-17 16:18:47 -080084 (void) ___change_bit(ADDR, mask);
Linus Torvalds1da177e2005-04-16 15:20:36 -070085}
86
Akinobu Mitad59288b2006-03-26 01:39:39 -080087#include <asm-generic/bitops/non-atomic.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070088
89#define smp_mb__before_clear_bit() do { } while(0)
90#define smp_mb__after_clear_bit() do { } while(0)
91
Akinobu Mitad59288b2006-03-26 01:39:39 -080092#include <asm-generic/bitops/ffz.h>
93#include <asm-generic/bitops/__ffs.h>
94#include <asm-generic/bitops/sched.h>
95#include <asm-generic/bitops/ffs.h>
96#include <asm-generic/bitops/fls.h>
97#include <asm-generic/bitops/fls64.h>
98#include <asm-generic/bitops/hweight.h>
99#include <asm-generic/bitops/find.h>
100#include <asm-generic/bitops/ext2-non-atomic.h>
101#include <asm-generic/bitops/ext2-atomic.h>
102#include <asm-generic/bitops/minix.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -0700103
104#endif /* __KERNEL__ */
105
106#endif /* defined(_SPARC_BITOPS_H) */