diff options
| author | Tejun Heo <tj@kernel.org> | 2012-04-01 15:30:01 -0400 |
|---|---|---|
| committer | Tejun Heo <tj@kernel.org> | 2012-04-01 15:55:00 -0400 |
| commit | 959d851caa48829eb85cb85aa949fd6b4c5d5bc6 (patch) | |
| tree | 3ba9c94ec346275fb44c4f0d1cd2537cdff8d811 /include/linux/bitops.h | |
| parent | a5567932fc926739e29e98487128080f40c61710 (diff) | |
| parent | 48ddbe194623ae089cc0576e60363f2d2e85662a (diff) | |
Merge branch 'for-3.5' of ../cgroup into block/for-3.5/core-merged
cgroup/for-3.5 contains the following changes which blk-cgroup needs
to proceed with the on-going cleanup.
* Dynamic addition and removal of cftypes to make config/stat file
handling modular for policies.
* cgroup removal update to not wait for css references to drain to fix
blkcg removal hang caused by cfq caching cfqgs.
Pull in cgroup/for-3.5 into block/for-3.5/core. This causes the
following conflicts in block/blk-cgroup.c.
* 761b3ef50e "cgroup: remove cgroup_subsys argument from callbacks"
conflicts with blkiocg_pre_destroy() addition and blkiocg_attach()
removal. Resolved by removing @subsys from all subsys methods.
* 676f7c8f84 "cgroup: relocate cftype and cgroup_subsys definitions in
controllers" conflicts with ->pre_destroy() and ->attach() updates
and removal of modular config. Resolved by dropping forward
declarations of the methods and applying updates to the relocated
blkio_subsys.
* 4baf6e3325 "cgroup: convert all non-memcg controllers to the new
cftype interface" builds upon the previous item. Resolved by adding
->base_cftypes to the relocated blkio_subsys.
Signed-off-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'include/linux/bitops.h')
| -rw-r--r-- | include/linux/bitops.h | 33 |
1 files changed, 32 insertions, 1 deletions
diff --git a/include/linux/bitops.h b/include/linux/bitops.h index 3c1063acb2a..a3b6b82108b 100644 --- a/include/linux/bitops.h +++ b/include/linux/bitops.h | |||
| @@ -27,11 +27,22 @@ extern unsigned long __sw_hweight64(__u64 w); | |||
| 27 | (bit) = find_next_bit((addr), (size), (bit) + 1)) | 27 | (bit) = find_next_bit((addr), (size), (bit) + 1)) |
| 28 | 28 | ||
| 29 | /* same as for_each_set_bit() but use bit as value to start with */ | 29 | /* same as for_each_set_bit() but use bit as value to start with */ |
| 30 | #define for_each_set_bit_cont(bit, addr, size) \ | 30 | #define for_each_set_bit_from(bit, addr, size) \ |
| 31 | for ((bit) = find_next_bit((addr), (size), (bit)); \ | 31 | for ((bit) = find_next_bit((addr), (size), (bit)); \ |
| 32 | (bit) < (size); \ | 32 | (bit) < (size); \ |
| 33 | (bit) = find_next_bit((addr), (size), (bit) + 1)) | 33 | (bit) = find_next_bit((addr), (size), (bit) + 1)) |
| 34 | 34 | ||
| 35 | #define for_each_clear_bit(bit, addr, size) \ | ||
| 36 | for ((bit) = find_first_zero_bit((addr), (size)); \ | ||
| 37 | (bit) < (size); \ | ||
| 38 | (bit) = find_next_zero_bit((addr), (size), (bit) + 1)) | ||
| 39 | |||
| 40 | /* same as for_each_clear_bit() but use bit as value to start with */ | ||
| 41 | #define for_each_clear_bit_from(bit, addr, size) \ | ||
| 42 | for ((bit) = find_next_zero_bit((addr), (size), (bit)); \ | ||
| 43 | (bit) < (size); \ | ||
| 44 | (bit) = find_next_zero_bit((addr), (size), (bit) + 1)) | ||
| 45 | |||
| 35 | static __inline__ int get_bitmask_order(unsigned int count) | 46 | static __inline__ int get_bitmask_order(unsigned int count) |
| 36 | { | 47 | { |
| 37 | int order; | 48 | int order; |
| @@ -56,6 +67,26 @@ static inline unsigned long hweight_long(unsigned long w) | |||
| 56 | } | 67 | } |
| 57 | 68 | ||
| 58 | /** | 69 | /** |
| 70 | * rol64 - rotate a 64-bit value left | ||
| 71 | * @word: value to rotate | ||
| 72 | * @shift: bits to roll | ||
| 73 | */ | ||
| 74 | static inline __u64 rol64(__u64 word, unsigned int shift) | ||
| 75 | { | ||
| 76 | return (word << shift) | (word >> (64 - shift)); | ||
| 77 | } | ||
| 78 | |||
| 79 | /** | ||
| 80 | * ror64 - rotate a 64-bit value right | ||
| 81 | * @word: value to rotate | ||
| 82 | * @shift: bits to roll | ||
| 83 | */ | ||
| 84 | static inline __u64 ror64(__u64 word, unsigned int shift) | ||
| 85 | { | ||
| 86 | return (word >> shift) | (word << (64 - shift)); | ||
| 87 | } | ||
| 88 | |||
| 89 | /** | ||
| 59 | * rol32 - rotate a 32-bit value left | 90 | * rol32 - rotate a 32-bit value left |
| 60 | * @word: value to rotate | 91 | * @word: value to rotate |
| 61 | * @shift: bits to roll | 92 | * @shift: bits to roll |
