aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/extent_map.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/btrfs/extent_map.c')
-rw-r--r--fs/btrfs/extent_map.c27
1 files changed, 15 insertions, 12 deletions
diff --git a/fs/btrfs/extent_map.c b/fs/btrfs/extent_map.c
index e4ee980cc138..238cb1d81d56 100644
--- a/fs/btrfs/extent_map.c
+++ b/fs/btrfs/extent_map.c
@@ -1229,7 +1229,7 @@ EXPORT_SYMBOL(test_range_bit);
1229static int check_page_uptodate(struct extent_map_tree *tree, 1229static int check_page_uptodate(struct extent_map_tree *tree,
1230 struct page *page) 1230 struct page *page)
1231{ 1231{
1232 u64 start = page->index << PAGE_CACHE_SHIFT; 1232 u64 start = (u64)page->index << PAGE_CACHE_SHIFT;
1233 u64 end = start + PAGE_CACHE_SIZE - 1; 1233 u64 end = start + PAGE_CACHE_SIZE - 1;
1234 if (test_range_bit(tree, start, end, EXTENT_UPTODATE, 1)) 1234 if (test_range_bit(tree, start, end, EXTENT_UPTODATE, 1))
1235 SetPageUptodate(page); 1235 SetPageUptodate(page);
@@ -1243,7 +1243,7 @@ static int check_page_uptodate(struct extent_map_tree *tree,
1243static int check_page_locked(struct extent_map_tree *tree, 1243static int check_page_locked(struct extent_map_tree *tree,
1244 struct page *page) 1244 struct page *page)
1245{ 1245{
1246 u64 start = page->index << PAGE_CACHE_SHIFT; 1246 u64 start = (u64)page->index << PAGE_CACHE_SHIFT;
1247 u64 end = start + PAGE_CACHE_SIZE - 1; 1247 u64 end = start + PAGE_CACHE_SIZE - 1;
1248 if (!test_range_bit(tree, start, end, EXTENT_LOCKED, 0)) 1248 if (!test_range_bit(tree, start, end, EXTENT_LOCKED, 0))
1249 unlock_page(page); 1249 unlock_page(page);
@@ -1257,7 +1257,7 @@ static int check_page_locked(struct extent_map_tree *tree,
1257static int check_page_writeback(struct extent_map_tree *tree, 1257static int check_page_writeback(struct extent_map_tree *tree,
1258 struct page *page) 1258 struct page *page)
1259{ 1259{
1260 u64 start = page->index << PAGE_CACHE_SHIFT; 1260 u64 start = (u64)page->index << PAGE_CACHE_SHIFT;
1261 u64 end = start + PAGE_CACHE_SIZE - 1; 1261 u64 end = start + PAGE_CACHE_SIZE - 1;
1262 if (!test_range_bit(tree, start, end, EXTENT_WRITEBACK, 0)) 1262 if (!test_range_bit(tree, start, end, EXTENT_WRITEBACK, 0))
1263 end_page_writeback(page); 1263 end_page_writeback(page);
@@ -1296,7 +1296,8 @@ static int end_bio_extent_writepage(struct bio *bio,
1296 1296
1297 do { 1297 do {
1298 struct page *page = bvec->bv_page; 1298 struct page *page = bvec->bv_page;
1299 start = (page->index << PAGE_CACHE_SHIFT) + bvec->bv_offset; 1299 start = ((u64)page->index << PAGE_CACHE_SHIFT) +
1300 bvec->bv_offset;
1300 end = start + bvec->bv_len - 1; 1301 end = start + bvec->bv_len - 1;
1301 1302
1302 if (bvec->bv_offset == 0 && bvec->bv_len == PAGE_CACHE_SIZE) 1303 if (bvec->bv_offset == 0 && bvec->bv_len == PAGE_CACHE_SIZE)
@@ -1361,7 +1362,8 @@ static int end_bio_extent_readpage(struct bio *bio,
1361 1362
1362 do { 1363 do {
1363 struct page *page = bvec->bv_page; 1364 struct page *page = bvec->bv_page;
1364 start = (page->index << PAGE_CACHE_SHIFT) + bvec->bv_offset; 1365 start = ((u64)page->index << PAGE_CACHE_SHIFT) +
1366 bvec->bv_offset;
1365 end = start + bvec->bv_len - 1; 1367 end = start + bvec->bv_len - 1;
1366 1368
1367 if (bvec->bv_offset == 0 && bvec->bv_len == PAGE_CACHE_SIZE) 1369 if (bvec->bv_offset == 0 && bvec->bv_len == PAGE_CACHE_SIZE)
@@ -1427,7 +1429,8 @@ static int end_bio_extent_preparewrite(struct bio *bio,
1427 1429
1428 do { 1430 do {
1429 struct page *page = bvec->bv_page; 1431 struct page *page = bvec->bv_page;
1430 start = (page->index << PAGE_CACHE_SHIFT) + bvec->bv_offset; 1432 start = ((u64)page->index << PAGE_CACHE_SHIFT) +
1433 bvec->bv_offset;
1431 end = start + bvec->bv_len - 1; 1434 end = start + bvec->bv_len - 1;
1432 1435
1433 if (--bvec >= bio->bi_io_vec) 1436 if (--bvec >= bio->bi_io_vec)
@@ -1503,7 +1506,7 @@ int extent_read_full_page(struct extent_map_tree *tree, struct page *page,
1503 get_extent_t *get_extent) 1506 get_extent_t *get_extent)
1504{ 1507{
1505 struct inode *inode = page->mapping->host; 1508 struct inode *inode = page->mapping->host;
1506 u64 start = page->index << PAGE_CACHE_SHIFT; 1509 u64 start = (u64)page->index << PAGE_CACHE_SHIFT;
1507 u64 page_end = start + PAGE_CACHE_SIZE - 1; 1510 u64 page_end = start + PAGE_CACHE_SIZE - 1;
1508 u64 end; 1511 u64 end;
1509 u64 cur = start; 1512 u64 cur = start;
@@ -1608,7 +1611,7 @@ int extent_write_full_page(struct extent_map_tree *tree, struct page *page,
1608 struct writeback_control *wbc) 1611 struct writeback_control *wbc)
1609{ 1612{
1610 struct inode *inode = page->mapping->host; 1613 struct inode *inode = page->mapping->host;
1611 u64 start = page->index << PAGE_CACHE_SHIFT; 1614 u64 start = (u64)page->index << PAGE_CACHE_SHIFT;
1612 u64 page_end = start + PAGE_CACHE_SIZE - 1; 1615 u64 page_end = start + PAGE_CACHE_SIZE - 1;
1613 u64 end; 1616 u64 end;
1614 u64 cur = start; 1617 u64 cur = start;
@@ -1750,7 +1753,7 @@ EXPORT_SYMBOL(extent_write_full_page);
1750int extent_invalidatepage(struct extent_map_tree *tree, 1753int extent_invalidatepage(struct extent_map_tree *tree,
1751 struct page *page, unsigned long offset) 1754 struct page *page, unsigned long offset)
1752{ 1755{
1753 u64 start = (page->index << PAGE_CACHE_SHIFT); 1756 u64 start = ((u64)page->index << PAGE_CACHE_SHIFT);
1754 u64 end = start + PAGE_CACHE_SIZE - 1; 1757 u64 end = start + PAGE_CACHE_SIZE - 1;
1755 size_t blocksize = page->mapping->host->i_sb->s_blocksize; 1758 size_t blocksize = page->mapping->host->i_sb->s_blocksize;
1756 1759
@@ -1792,7 +1795,7 @@ int extent_prepare_write(struct extent_map_tree *tree,
1792 struct inode *inode, struct page *page, 1795 struct inode *inode, struct page *page,
1793 unsigned from, unsigned to, get_extent_t *get_extent) 1796 unsigned from, unsigned to, get_extent_t *get_extent)
1794{ 1797{
1795 u64 page_start = page->index << PAGE_CACHE_SHIFT; 1798 u64 page_start = (u64)page->index << PAGE_CACHE_SHIFT;
1796 u64 page_end = page_start + PAGE_CACHE_SIZE - 1; 1799 u64 page_end = page_start + PAGE_CACHE_SIZE - 1;
1797 u64 block_start; 1800 u64 block_start;
1798 u64 orig_block_start; 1801 u64 orig_block_start;
@@ -1890,7 +1893,7 @@ EXPORT_SYMBOL(extent_prepare_write);
1890int try_release_extent_mapping(struct extent_map_tree *tree, struct page *page) 1893int try_release_extent_mapping(struct extent_map_tree *tree, struct page *page)
1891{ 1894{
1892 struct extent_map *em; 1895 struct extent_map *em;
1893 u64 start = page->index << PAGE_CACHE_SHIFT; 1896 u64 start = (u64)page->index << PAGE_CACHE_SHIFT;
1894 u64 end = start + PAGE_CACHE_SIZE - 1; 1897 u64 end = start + PAGE_CACHE_SIZE - 1;
1895 u64 orig_start = start; 1898 u64 orig_start = start;
1896 int ret = 1; 1899 int ret = 1;
@@ -2202,7 +2205,7 @@ int clear_extent_buffer_dirty(struct extent_map_tree *tree,
2202 if ((i == 0 && (eb->start & (PAGE_CACHE_SIZE - 1))) || 2205 if ((i == 0 && (eb->start & (PAGE_CACHE_SIZE - 1))) ||
2203 ((i == num_pages - 1) && 2206 ((i == num_pages - 1) &&
2204 ((eb->start + eb->len) & (PAGE_CACHE_SIZE - 1)))) { 2207 ((eb->start + eb->len) & (PAGE_CACHE_SIZE - 1)))) {
2205 start = page->index << PAGE_CACHE_SHIFT; 2208 start = (u64)page->index << PAGE_CACHE_SHIFT;
2206 end = start + PAGE_CACHE_SIZE - 1; 2209 end = start + PAGE_CACHE_SIZE - 1;
2207 if (test_range_bit(tree, start, end, 2210 if (test_range_bit(tree, start, end,
2208 EXTENT_DIRTY, 0)) { 2211 EXTENT_DIRTY, 0)) {