diff options
author | Chris Mason <chris.mason@oracle.com> | 2009-09-02 15:11:07 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@oracle.com> | 2009-09-11 13:31:06 -0400 |
commit | d5550c6315fe0647b7ac21a6a736bf4a42620eac (patch) | |
tree | d1aeeee5ef7b04915dd6eb1c220b3e137ce4d9b3 | |
parent | 2c64c53d8d30d43d0670482503a3914dfd3d6d46 (diff) |
Btrfs: don't lock bits in the extent tree during writepage
At writepage time, we have the page locked and we have the
extent_map entry for this extent pinned in the extent_map tree.
So, the page can't go away and its mapping can't change.
There is no need for the extra extent_state lock bits during writepage.
Signed-off-by: Chris Mason <chris.mason@oracle.com>
-rw-r--r-- | fs/btrfs/extent_io.c | 21 |
1 files changed, 0 insertions, 21 deletions
diff --git a/fs/btrfs/extent_io.c b/fs/btrfs/extent_io.c index c7a5e860fe21..04fafc3cffc0 100644 --- a/fs/btrfs/extent_io.c +++ b/fs/btrfs/extent_io.c | |||
@@ -2219,16 +2219,10 @@ static int __extent_writepage(struct page *page, struct writeback_control *wbc, | |||
2219 | goto done_unlocked; | 2219 | goto done_unlocked; |
2220 | } | 2220 | } |
2221 | } | 2221 | } |
2222 | lock_extent_bits(tree, start, page_end, 0, &cached_state, GFP_NOFS); | ||
2223 | |||
2224 | unlock_start = start; | ||
2225 | |||
2226 | if (tree->ops && tree->ops->writepage_start_hook) { | 2222 | if (tree->ops && tree->ops->writepage_start_hook) { |
2227 | ret = tree->ops->writepage_start_hook(page, start, | 2223 | ret = tree->ops->writepage_start_hook(page, start, |
2228 | page_end); | 2224 | page_end); |
2229 | if (ret == -EAGAIN) { | 2225 | if (ret == -EAGAIN) { |
2230 | unlock_extent_cached(tree, start, page_end, | ||
2231 | &cached_state, GFP_NOFS); | ||
2232 | redirty_page_for_writepage(wbc, page); | 2226 | redirty_page_for_writepage(wbc, page); |
2233 | update_nr_written(page, wbc, nr_written); | 2227 | update_nr_written(page, wbc, nr_written); |
2234 | unlock_page(page); | 2228 | unlock_page(page); |
@@ -2244,13 +2238,7 @@ static int __extent_writepage(struct page *page, struct writeback_control *wbc, | |||
2244 | update_nr_written(page, wbc, nr_written + 1); | 2238 | update_nr_written(page, wbc, nr_written + 1); |
2245 | 2239 | ||
2246 | end = page_end; | 2240 | end = page_end; |
2247 | if (test_range_bit(tree, start, page_end, EXTENT_DELALLOC, 0)) | ||
2248 | printk(KERN_ERR "btrfs delalloc bits after lock_extent\n"); | ||
2249 | |||
2250 | if (last_byte <= start) { | 2241 | if (last_byte <= start) { |
2251 | clear_extent_bit(tree, start, page_end, | ||
2252 | EXTENT_LOCKED | EXTENT_DIRTY, | ||
2253 | 1, 0, NULL, GFP_NOFS); | ||
2254 | if (tree->ops && tree->ops->writepage_end_io_hook) | 2242 | if (tree->ops && tree->ops->writepage_end_io_hook) |
2255 | tree->ops->writepage_end_io_hook(page, start, | 2243 | tree->ops->writepage_end_io_hook(page, start, |
2256 | page_end, NULL, 1); | 2244 | page_end, NULL, 1); |
@@ -2262,8 +2250,6 @@ static int __extent_writepage(struct page *page, struct writeback_control *wbc, | |||
2262 | 2250 | ||
2263 | while (cur <= end) { | 2251 | while (cur <= end) { |
2264 | if (cur >= last_byte) { | 2252 | if (cur >= last_byte) { |
2265 | unlock_extent_cached(tree, unlock_start, page_end, | ||
2266 | &cached_state, GFP_NOFS); | ||
2267 | if (tree->ops && tree->ops->writepage_end_io_hook) | 2253 | if (tree->ops && tree->ops->writepage_end_io_hook) |
2268 | tree->ops->writepage_end_io_hook(page, cur, | 2254 | tree->ops->writepage_end_io_hook(page, cur, |
2269 | page_end, NULL, 1); | 2255 | page_end, NULL, 1); |
@@ -2295,10 +2281,6 @@ static int __extent_writepage(struct page *page, struct writeback_control *wbc, | |||
2295 | */ | 2281 | */ |
2296 | if (compressed || block_start == EXTENT_MAP_HOLE || | 2282 | if (compressed || block_start == EXTENT_MAP_HOLE || |
2297 | block_start == EXTENT_MAP_INLINE) { | 2283 | block_start == EXTENT_MAP_INLINE) { |
2298 | unlock_extent_cached(tree, unlock_start, | ||
2299 | cur + iosize - 1, &cached_state, | ||
2300 | GFP_NOFS); | ||
2301 | |||
2302 | /* | 2284 | /* |
2303 | * end_io notification does not happen here for | 2285 | * end_io notification does not happen here for |
2304 | * compressed extents | 2286 | * compressed extents |
@@ -2366,9 +2348,6 @@ done: | |||
2366 | set_page_writeback(page); | 2348 | set_page_writeback(page); |
2367 | end_page_writeback(page); | 2349 | end_page_writeback(page); |
2368 | } | 2350 | } |
2369 | if (unlock_start <= page_end) | ||
2370 | unlock_extent_cached(tree, unlock_start, page_end, | ||
2371 | &cached_state, GFP_NOFS); | ||
2372 | unlock_page(page); | 2351 | unlock_page(page); |
2373 | 2352 | ||
2374 | done_unlocked: | 2353 | done_unlocked: |