diff options
-rw-r--r-- | fs/btrfs/extent_io.c | 49 | ||||
-rw-r--r-- | fs/btrfs/extent_io.h | 23 | ||||
-rw-r--r-- | fs/btrfs/inode.c | 5 |
3 files changed, 40 insertions, 37 deletions
diff --git a/fs/btrfs/extent_io.c b/fs/btrfs/extent_io.c index 9b93e8076162..d2ac518f90e4 100644 --- a/fs/btrfs/extent_io.c +++ b/fs/btrfs/extent_io.c | |||
@@ -322,21 +322,21 @@ static void merge_state(struct extent_io_tree *tree, | |||
322 | } | 322 | } |
323 | 323 | ||
324 | static void set_state_cb(struct extent_io_tree *tree, | 324 | static void set_state_cb(struct extent_io_tree *tree, |
325 | struct extent_state *state, int *bits) | 325 | struct extent_state *state, unsigned long *bits) |
326 | { | 326 | { |
327 | if (tree->ops && tree->ops->set_bit_hook) | 327 | if (tree->ops && tree->ops->set_bit_hook) |
328 | tree->ops->set_bit_hook(tree->mapping->host, state, bits); | 328 | tree->ops->set_bit_hook(tree->mapping->host, state, bits); |
329 | } | 329 | } |
330 | 330 | ||
331 | static void clear_state_cb(struct extent_io_tree *tree, | 331 | static void clear_state_cb(struct extent_io_tree *tree, |
332 | struct extent_state *state, int *bits) | 332 | struct extent_state *state, unsigned long *bits) |
333 | { | 333 | { |
334 | if (tree->ops && tree->ops->clear_bit_hook) | 334 | if (tree->ops && tree->ops->clear_bit_hook) |
335 | tree->ops->clear_bit_hook(tree->mapping->host, state, bits); | 335 | tree->ops->clear_bit_hook(tree->mapping->host, state, bits); |
336 | } | 336 | } |
337 | 337 | ||
338 | static void set_state_bits(struct extent_io_tree *tree, | 338 | static void set_state_bits(struct extent_io_tree *tree, |
339 | struct extent_state *state, int *bits); | 339 | struct extent_state *state, unsigned long *bits); |
340 | 340 | ||
341 | /* | 341 | /* |
342 | * insert an extent_state struct into the tree. 'bits' are set on the | 342 | * insert an extent_state struct into the tree. 'bits' are set on the |
@@ -350,7 +350,7 @@ static void set_state_bits(struct extent_io_tree *tree, | |||
350 | */ | 350 | */ |
351 | static int insert_state(struct extent_io_tree *tree, | 351 | static int insert_state(struct extent_io_tree *tree, |
352 | struct extent_state *state, u64 start, u64 end, | 352 | struct extent_state *state, u64 start, u64 end, |
353 | int *bits) | 353 | unsigned long *bits) |
354 | { | 354 | { |
355 | struct rb_node *node; | 355 | struct rb_node *node; |
356 | 356 | ||
@@ -438,10 +438,10 @@ static struct extent_state *next_state(struct extent_state *state) | |||
438 | */ | 438 | */ |
439 | static struct extent_state *clear_state_bit(struct extent_io_tree *tree, | 439 | static struct extent_state *clear_state_bit(struct extent_io_tree *tree, |
440 | struct extent_state *state, | 440 | struct extent_state *state, |
441 | int *bits, int wake) | 441 | unsigned long *bits, int wake) |
442 | { | 442 | { |
443 | struct extent_state *next; | 443 | struct extent_state *next; |
444 | int bits_to_clear = *bits & ~EXTENT_CTLBITS; | 444 | unsigned long bits_to_clear = *bits & ~EXTENT_CTLBITS; |
445 | 445 | ||
446 | if ((bits_to_clear & EXTENT_DIRTY) && (state->state & EXTENT_DIRTY)) { | 446 | if ((bits_to_clear & EXTENT_DIRTY) && (state->state & EXTENT_DIRTY)) { |
447 | u64 range = state->end - state->start + 1; | 447 | u64 range = state->end - state->start + 1; |
@@ -497,7 +497,7 @@ static void extent_io_tree_panic(struct extent_io_tree *tree, int err) | |||
497 | * This takes the tree lock, and returns 0 on success and < 0 on error. | 497 | * This takes the tree lock, and returns 0 on success and < 0 on error. |
498 | */ | 498 | */ |
499 | int clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, | 499 | int clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, |
500 | int bits, int wake, int delete, | 500 | unsigned long bits, int wake, int delete, |
501 | struct extent_state **cached_state, | 501 | struct extent_state **cached_state, |
502 | gfp_t mask) | 502 | gfp_t mask) |
503 | { | 503 | { |
@@ -658,8 +658,8 @@ static void wait_on_state(struct extent_io_tree *tree, | |||
658 | * The range [start, end] is inclusive. | 658 | * The range [start, end] is inclusive. |
659 | * The tree lock is taken by this function | 659 | * The tree lock is taken by this function |
660 | */ | 660 | */ |
661 | static void wait_extent_bit(struct extent_io_tree *tree, u64 start, | 661 | static void wait_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, |
662 | u64 end, int bits) | 662 | unsigned long bits) |
663 | { | 663 | { |
664 | struct extent_state *state; | 664 | struct extent_state *state; |
665 | struct rb_node *node; | 665 | struct rb_node *node; |
@@ -700,9 +700,9 @@ out: | |||
700 | 700 | ||
701 | static void set_state_bits(struct extent_io_tree *tree, | 701 | static void set_state_bits(struct extent_io_tree *tree, |
702 | struct extent_state *state, | 702 | struct extent_state *state, |
703 | int *bits) | 703 | unsigned long *bits) |
704 | { | 704 | { |
705 | int bits_to_set = *bits & ~EXTENT_CTLBITS; | 705 | unsigned long bits_to_set = *bits & ~EXTENT_CTLBITS; |
706 | 706 | ||
707 | set_state_cb(tree, state, bits); | 707 | set_state_cb(tree, state, bits); |
708 | if ((bits_to_set & EXTENT_DIRTY) && !(state->state & EXTENT_DIRTY)) { | 708 | if ((bits_to_set & EXTENT_DIRTY) && !(state->state & EXTENT_DIRTY)) { |
@@ -745,8 +745,9 @@ static void uncache_state(struct extent_state **cached_ptr) | |||
745 | 745 | ||
746 | static int __must_check | 746 | static int __must_check |
747 | __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, | 747 | __set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, |
748 | int bits, int exclusive_bits, u64 *failed_start, | 748 | unsigned long bits, unsigned long exclusive_bits, |
749 | struct extent_state **cached_state, gfp_t mask) | 749 | u64 *failed_start, struct extent_state **cached_state, |
750 | gfp_t mask) | ||
750 | { | 751 | { |
751 | struct extent_state *state; | 752 | struct extent_state *state; |
752 | struct extent_state *prealloc = NULL; | 753 | struct extent_state *prealloc = NULL; |
@@ -938,9 +939,9 @@ search_again: | |||
938 | goto again; | 939 | goto again; |
939 | } | 940 | } |
940 | 941 | ||
941 | int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, int bits, | 942 | int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, |
942 | u64 *failed_start, struct extent_state **cached_state, | 943 | unsigned long bits, u64 * failed_start, |
943 | gfp_t mask) | 944 | struct extent_state **cached_state, gfp_t mask) |
944 | { | 945 | { |
945 | return __set_extent_bit(tree, start, end, bits, 0, failed_start, | 946 | return __set_extent_bit(tree, start, end, bits, 0, failed_start, |
946 | cached_state, mask); | 947 | cached_state, mask); |
@@ -965,7 +966,7 @@ int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, int bits, | |||
965 | * boundary bits like LOCK. | 966 | * boundary bits like LOCK. |
966 | */ | 967 | */ |
967 | int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, | 968 | int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, |
968 | int bits, int clear_bits, | 969 | unsigned long bits, unsigned long clear_bits, |
969 | struct extent_state **cached_state, gfp_t mask) | 970 | struct extent_state **cached_state, gfp_t mask) |
970 | { | 971 | { |
971 | struct extent_state *state; | 972 | struct extent_state *state; |
@@ -1158,14 +1159,14 @@ int set_extent_dirty(struct extent_io_tree *tree, u64 start, u64 end, | |||
1158 | } | 1159 | } |
1159 | 1160 | ||
1160 | int set_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, | 1161 | int set_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, |
1161 | int bits, gfp_t mask) | 1162 | unsigned long bits, gfp_t mask) |
1162 | { | 1163 | { |
1163 | return set_extent_bit(tree, start, end, bits, NULL, | 1164 | return set_extent_bit(tree, start, end, bits, NULL, |
1164 | NULL, mask); | 1165 | NULL, mask); |
1165 | } | 1166 | } |
1166 | 1167 | ||
1167 | int clear_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, | 1168 | int clear_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, |
1168 | int bits, gfp_t mask) | 1169 | unsigned long bits, gfp_t mask) |
1169 | { | 1170 | { |
1170 | return clear_extent_bit(tree, start, end, bits, 0, 0, NULL, mask); | 1171 | return clear_extent_bit(tree, start, end, bits, 0, 0, NULL, mask); |
1171 | } | 1172 | } |
@@ -1220,7 +1221,7 @@ int clear_extent_uptodate(struct extent_io_tree *tree, u64 start, u64 end, | |||
1220 | * us if waiting is desired. | 1221 | * us if waiting is desired. |
1221 | */ | 1222 | */ |
1222 | int lock_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, | 1223 | int lock_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, |
1223 | int bits, struct extent_state **cached_state) | 1224 | unsigned long bits, struct extent_state **cached_state) |
1224 | { | 1225 | { |
1225 | int err; | 1226 | int err; |
1226 | u64 failed_start; | 1227 | u64 failed_start; |
@@ -1330,7 +1331,7 @@ static int set_range_writeback(struct extent_io_tree *tree, u64 start, u64 end) | |||
1330 | */ | 1331 | */ |
1331 | static struct extent_state * | 1332 | static struct extent_state * |
1332 | find_first_extent_bit_state(struct extent_io_tree *tree, | 1333 | find_first_extent_bit_state(struct extent_io_tree *tree, |
1333 | u64 start, int bits) | 1334 | u64 start, unsigned long bits) |
1334 | { | 1335 | { |
1335 | struct rb_node *node; | 1336 | struct rb_node *node; |
1336 | struct extent_state *state; | 1337 | struct extent_state *state; |
@@ -1364,7 +1365,7 @@ out: | |||
1364 | * If nothing was found, 1 is returned. If found something, return 0. | 1365 | * If nothing was found, 1 is returned. If found something, return 0. |
1365 | */ | 1366 | */ |
1366 | int find_first_extent_bit(struct extent_io_tree *tree, u64 start, | 1367 | int find_first_extent_bit(struct extent_io_tree *tree, u64 start, |
1367 | u64 *start_ret, u64 *end_ret, int bits, | 1368 | u64 *start_ret, u64 *end_ret, unsigned long bits, |
1368 | struct extent_state **cached_state) | 1369 | struct extent_state **cached_state) |
1369 | { | 1370 | { |
1370 | struct extent_state *state; | 1371 | struct extent_state *state; |
@@ -1654,7 +1655,7 @@ int extent_clear_unlock_delalloc(struct inode *inode, | |||
1654 | unsigned long end_index = end >> PAGE_CACHE_SHIFT; | 1655 | unsigned long end_index = end >> PAGE_CACHE_SHIFT; |
1655 | unsigned long nr_pages = end_index - index + 1; | 1656 | unsigned long nr_pages = end_index - index + 1; |
1656 | int i; | 1657 | int i; |
1657 | int clear_bits = 0; | 1658 | unsigned long clear_bits = 0; |
1658 | 1659 | ||
1659 | if (op & EXTENT_CLEAR_UNLOCK) | 1660 | if (op & EXTENT_CLEAR_UNLOCK) |
1660 | clear_bits |= EXTENT_LOCKED; | 1661 | clear_bits |= EXTENT_LOCKED; |
@@ -1885,7 +1886,7 @@ out: | |||
1885 | * range is found set. | 1886 | * range is found set. |
1886 | */ | 1887 | */ |
1887 | int test_range_bit(struct extent_io_tree *tree, u64 start, u64 end, | 1888 | int test_range_bit(struct extent_io_tree *tree, u64 start, u64 end, |
1888 | int bits, int filled, struct extent_state *cached) | 1889 | unsigned long bits, int filled, struct extent_state *cached) |
1889 | { | 1890 | { |
1890 | struct extent_state *state = NULL; | 1891 | struct extent_state *state = NULL; |
1891 | struct rb_node *node; | 1892 | struct rb_node *node; |
diff --git a/fs/btrfs/extent_io.h b/fs/btrfs/extent_io.h index 3af58bf55ddc..a2c03a175009 100644 --- a/fs/btrfs/extent_io.h +++ b/fs/btrfs/extent_io.h | |||
@@ -81,9 +81,9 @@ struct extent_io_ops { | |||
81 | int (*writepage_end_io_hook)(struct page *page, u64 start, u64 end, | 81 | int (*writepage_end_io_hook)(struct page *page, u64 start, u64 end, |
82 | struct extent_state *state, int uptodate); | 82 | struct extent_state *state, int uptodate); |
83 | void (*set_bit_hook)(struct inode *inode, struct extent_state *state, | 83 | void (*set_bit_hook)(struct inode *inode, struct extent_state *state, |
84 | int *bits); | 84 | unsigned long *bits); |
85 | void (*clear_bit_hook)(struct inode *inode, struct extent_state *state, | 85 | void (*clear_bit_hook)(struct inode *inode, struct extent_state *state, |
86 | int *bits); | 86 | unsigned long *bits); |
87 | void (*merge_extent_hook)(struct inode *inode, | 87 | void (*merge_extent_hook)(struct inode *inode, |
88 | struct extent_state *new, | 88 | struct extent_state *new, |
89 | struct extent_state *other); | 89 | struct extent_state *other); |
@@ -192,7 +192,7 @@ int try_release_extent_mapping(struct extent_map_tree *map, | |||
192 | int try_release_extent_buffer(struct page *page); | 192 | int try_release_extent_buffer(struct page *page); |
193 | int lock_extent(struct extent_io_tree *tree, u64 start, u64 end); | 193 | int lock_extent(struct extent_io_tree *tree, u64 start, u64 end); |
194 | int lock_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, | 194 | int lock_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, |
195 | int bits, struct extent_state **cached); | 195 | unsigned long bits, struct extent_state **cached); |
196 | int unlock_extent(struct extent_io_tree *tree, u64 start, u64 end); | 196 | int unlock_extent(struct extent_io_tree *tree, u64 start, u64 end); |
197 | int unlock_extent_cached(struct extent_io_tree *tree, u64 start, u64 end, | 197 | int unlock_extent_cached(struct extent_io_tree *tree, u64 start, u64 end, |
198 | struct extent_state **cached, gfp_t mask); | 198 | struct extent_state **cached, gfp_t mask); |
@@ -208,16 +208,17 @@ u64 count_range_bits(struct extent_io_tree *tree, | |||
208 | 208 | ||
209 | void free_extent_state(struct extent_state *state); | 209 | void free_extent_state(struct extent_state *state); |
210 | int test_range_bit(struct extent_io_tree *tree, u64 start, u64 end, | 210 | int test_range_bit(struct extent_io_tree *tree, u64 start, u64 end, |
211 | int bits, int filled, struct extent_state *cached_state); | 211 | unsigned long bits, int filled, |
212 | struct extent_state *cached_state); | ||
212 | int clear_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, | 213 | int clear_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, |
213 | int bits, gfp_t mask); | 214 | unsigned long bits, gfp_t mask); |
214 | int clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, | 215 | int clear_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, |
215 | int bits, int wake, int delete, struct extent_state **cached, | 216 | unsigned long bits, int wake, int delete, |
216 | gfp_t mask); | 217 | struct extent_state **cached, gfp_t mask); |
217 | int set_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, | 218 | int set_extent_bits(struct extent_io_tree *tree, u64 start, u64 end, |
218 | int bits, gfp_t mask); | 219 | unsigned long bits, gfp_t mask); |
219 | int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, | 220 | int set_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, |
220 | int bits, u64 *failed_start, | 221 | unsigned long bits, u64 *failed_start, |
221 | struct extent_state **cached_state, gfp_t mask); | 222 | struct extent_state **cached_state, gfp_t mask); |
222 | int set_extent_uptodate(struct extent_io_tree *tree, u64 start, u64 end, | 223 | int set_extent_uptodate(struct extent_io_tree *tree, u64 start, u64 end, |
223 | struct extent_state **cached_state, gfp_t mask); | 224 | struct extent_state **cached_state, gfp_t mask); |
@@ -230,14 +231,14 @@ int set_extent_dirty(struct extent_io_tree *tree, u64 start, u64 end, | |||
230 | int clear_extent_dirty(struct extent_io_tree *tree, u64 start, u64 end, | 231 | int clear_extent_dirty(struct extent_io_tree *tree, u64 start, u64 end, |
231 | gfp_t mask); | 232 | gfp_t mask); |
232 | int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, | 233 | int convert_extent_bit(struct extent_io_tree *tree, u64 start, u64 end, |
233 | int bits, int clear_bits, | 234 | unsigned long bits, unsigned long clear_bits, |
234 | struct extent_state **cached_state, gfp_t mask); | 235 | struct extent_state **cached_state, gfp_t mask); |
235 | int set_extent_delalloc(struct extent_io_tree *tree, u64 start, u64 end, | 236 | int set_extent_delalloc(struct extent_io_tree *tree, u64 start, u64 end, |
236 | struct extent_state **cached_state, gfp_t mask); | 237 | struct extent_state **cached_state, gfp_t mask); |
237 | int set_extent_defrag(struct extent_io_tree *tree, u64 start, u64 end, | 238 | int set_extent_defrag(struct extent_io_tree *tree, u64 start, u64 end, |
238 | struct extent_state **cached_state, gfp_t mask); | 239 | struct extent_state **cached_state, gfp_t mask); |
239 | int find_first_extent_bit(struct extent_io_tree *tree, u64 start, | 240 | int find_first_extent_bit(struct extent_io_tree *tree, u64 start, |
240 | u64 *start_ret, u64 *end_ret, int bits, | 241 | u64 *start_ret, u64 *end_ret, unsigned long bits, |
241 | struct extent_state **cached_state); | 242 | struct extent_state **cached_state); |
242 | int extent_invalidatepage(struct extent_io_tree *tree, | 243 | int extent_invalidatepage(struct extent_io_tree *tree, |
243 | struct page *page, unsigned long offset); | 244 | struct page *page, unsigned long offset); |
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c index ec63d7af3460..1669c3b4be2f 100644 --- a/fs/btrfs/inode.c +++ b/fs/btrfs/inode.c | |||
@@ -1530,7 +1530,7 @@ static void btrfs_merge_extent_hook(struct inode *inode, | |||
1530 | * have pending delalloc work to be done. | 1530 | * have pending delalloc work to be done. |
1531 | */ | 1531 | */ |
1532 | static void btrfs_set_bit_hook(struct inode *inode, | 1532 | static void btrfs_set_bit_hook(struct inode *inode, |
1533 | struct extent_state *state, int *bits) | 1533 | struct extent_state *state, unsigned long *bits) |
1534 | { | 1534 | { |
1535 | 1535 | ||
1536 | /* | 1536 | /* |
@@ -1574,7 +1574,8 @@ static void btrfs_set_bit_hook(struct inode *inode, | |||
1574 | * extent_io.c clear_bit_hook, see set_bit_hook for why | 1574 | * extent_io.c clear_bit_hook, see set_bit_hook for why |
1575 | */ | 1575 | */ |
1576 | static void btrfs_clear_bit_hook(struct inode *inode, | 1576 | static void btrfs_clear_bit_hook(struct inode *inode, |
1577 | struct extent_state *state, int *bits) | 1577 | struct extent_state *state, |
1578 | unsigned long *bits) | ||
1578 | { | 1579 | { |
1579 | /* | 1580 | /* |
1580 | * set_bit and clear bit hooks normally require _irqsave/restore | 1581 | * set_bit and clear bit hooks normally require _irqsave/restore |