aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md/bitmap.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/md/bitmap.c')
-rw-r--r--drivers/md/bitmap.c51
1 files changed, 28 insertions, 23 deletions
diff --git a/drivers/md/bitmap.c b/drivers/md/bitmap.c
index c9270f2c9ecd..1a5ada084487 100644
--- a/drivers/md/bitmap.c
+++ b/drivers/md/bitmap.c
@@ -287,27 +287,28 @@ static int write_sb_page(struct bitmap *bitmap, struct page *page, int wait)
287 287
288 while ((rdev = next_active_rdev(rdev, mddev)) != NULL) { 288 while ((rdev = next_active_rdev(rdev, mddev)) != NULL) {
289 int size = PAGE_SIZE; 289 int size = PAGE_SIZE;
290 long offset = mddev->bitmap_info.offset;
290 if (page->index == bitmap->file_pages-1) 291 if (page->index == bitmap->file_pages-1)
291 size = roundup(bitmap->last_page_size, 292 size = roundup(bitmap->last_page_size,
292 bdev_logical_block_size(rdev->bdev)); 293 bdev_logical_block_size(rdev->bdev));
293 /* Just make sure we aren't corrupting data or 294 /* Just make sure we aren't corrupting data or
294 * metadata 295 * metadata
295 */ 296 */
296 if (bitmap->offset < 0) { 297 if (offset < 0) {
297 /* DATA BITMAP METADATA */ 298 /* DATA BITMAP METADATA */
298 if (bitmap->offset 299 if (offset
299 + (long)(page->index * (PAGE_SIZE/512)) 300 + (long)(page->index * (PAGE_SIZE/512))
300 + size/512 > 0) 301 + size/512 > 0)
301 /* bitmap runs in to metadata */ 302 /* bitmap runs in to metadata */
302 goto bad_alignment; 303 goto bad_alignment;
303 if (rdev->data_offset + mddev->dev_sectors 304 if (rdev->data_offset + mddev->dev_sectors
304 > rdev->sb_start + bitmap->offset) 305 > rdev->sb_start + offset)
305 /* data runs in to bitmap */ 306 /* data runs in to bitmap */
306 goto bad_alignment; 307 goto bad_alignment;
307 } else if (rdev->sb_start < rdev->data_offset) { 308 } else if (rdev->sb_start < rdev->data_offset) {
308 /* METADATA BITMAP DATA */ 309 /* METADATA BITMAP DATA */
309 if (rdev->sb_start 310 if (rdev->sb_start
310 + bitmap->offset 311 + offset
311 + page->index*(PAGE_SIZE/512) + size/512 312 + page->index*(PAGE_SIZE/512) + size/512
312 > rdev->data_offset) 313 > rdev->data_offset)
313 /* bitmap runs in to data */ 314 /* bitmap runs in to data */
@@ -316,7 +317,7 @@ static int write_sb_page(struct bitmap *bitmap, struct page *page, int wait)
316 /* DATA METADATA BITMAP - no problems */ 317 /* DATA METADATA BITMAP - no problems */
317 } 318 }
318 md_super_write(mddev, rdev, 319 md_super_write(mddev, rdev,
319 rdev->sb_start + bitmap->offset 320 rdev->sb_start + offset
320 + page->index * (PAGE_SIZE/512), 321 + page->index * (PAGE_SIZE/512),
321 size, 322 size,
322 page); 323 page);
@@ -550,7 +551,8 @@ static int bitmap_read_sb(struct bitmap *bitmap)
550 551
551 bitmap->sb_page = read_page(bitmap->file, 0, bitmap, bytes); 552 bitmap->sb_page = read_page(bitmap->file, 0, bitmap, bytes);
552 } else { 553 } else {
553 bitmap->sb_page = read_sb_page(bitmap->mddev, bitmap->offset, 554 bitmap->sb_page = read_sb_page(bitmap->mddev,
555 bitmap->mddev->bitmap_info.offset,
554 NULL, 556 NULL,
555 0, sizeof(bitmap_super_t)); 557 0, sizeof(bitmap_super_t));
556 } 558 }
@@ -610,10 +612,10 @@ static int bitmap_read_sb(struct bitmap *bitmap)
610 } 612 }
611success: 613success:
612 /* assign fields using values from superblock */ 614 /* assign fields using values from superblock */
613 bitmap->chunksize = chunksize; 615 bitmap->mddev->bitmap_info.chunksize = chunksize;
614 bitmap->daemon_sleep = daemon_sleep; 616 bitmap->mddev->bitmap_info.daemon_sleep = daemon_sleep;
615 bitmap->daemon_lastrun = jiffies; 617 bitmap->daemon_lastrun = jiffies;
616 bitmap->max_write_behind = write_behind; 618 bitmap->mddev->bitmap_info.max_write_behind = write_behind;
617 bitmap->flags |= le32_to_cpu(sb->state); 619 bitmap->flags |= le32_to_cpu(sb->state);
618 if (le32_to_cpu(sb->version) == BITMAP_MAJOR_HOSTENDIAN) 620 if (le32_to_cpu(sb->version) == BITMAP_MAJOR_HOSTENDIAN)
619 bitmap->flags |= BITMAP_HOSTENDIAN; 621 bitmap->flags |= BITMAP_HOSTENDIAN;
@@ -907,7 +909,7 @@ static int bitmap_init_from_disk(struct bitmap *bitmap, sector_t start)
907 chunks = bitmap->chunks; 909 chunks = bitmap->chunks;
908 file = bitmap->file; 910 file = bitmap->file;
909 911
910 BUG_ON(!file && !bitmap->offset); 912 BUG_ON(!file && !bitmap->mddev->bitmap_info.offset);
911 913
912#ifdef INJECT_FAULTS_3 914#ifdef INJECT_FAULTS_3
913 outofdate = 1; 915 outofdate = 1;
@@ -967,14 +969,15 @@ static int bitmap_init_from_disk(struct bitmap *bitmap, sector_t start)
967 offset = sizeof(bitmap_super_t); 969 offset = sizeof(bitmap_super_t);
968 if (!file) 970 if (!file)
969 read_sb_page(bitmap->mddev, 971 read_sb_page(bitmap->mddev,
970 bitmap->offset, 972 bitmap->mddev->bitmap_info.offset,
971 page, 973 page,
972 index, count); 974 index, count);
973 } else if (file) { 975 } else if (file) {
974 page = read_page(file, index, bitmap, count); 976 page = read_page(file, index, bitmap, count);
975 offset = 0; 977 offset = 0;
976 } else { 978 } else {
977 page = read_sb_page(bitmap->mddev, bitmap->offset, 979 page = read_sb_page(bitmap->mddev,
980 bitmap->mddev->bitmap_info.offset,
978 NULL, 981 NULL,
979 index, count); 982 index, count);
980 offset = 0; 983 offset = 0;
@@ -1096,7 +1099,8 @@ void bitmap_daemon_work(mddev_t *mddev)
1096 mutex_unlock(&mddev->bitmap_info.mutex); 1099 mutex_unlock(&mddev->bitmap_info.mutex);
1097 return; 1100 return;
1098 } 1101 }
1099 if (time_before(jiffies, bitmap->daemon_lastrun + bitmap->daemon_sleep*HZ)) 1102 if (time_before(jiffies, bitmap->daemon_lastrun
1103 + bitmap->mddev->bitmap_info.daemon_sleep*HZ))
1100 goto done; 1104 goto done;
1101 1105
1102 bitmap->daemon_lastrun = jiffies; 1106 bitmap->daemon_lastrun = jiffies;
@@ -1210,7 +1214,8 @@ void bitmap_daemon_work(mddev_t *mddev)
1210 1214
1211 done: 1215 done:
1212 if (bitmap->allclean == 0) 1216 if (bitmap->allclean == 0)
1213 bitmap->mddev->thread->timeout = bitmap->daemon_sleep * HZ; 1217 bitmap->mddev->thread->timeout =
1218 bitmap->mddev->bitmap_info.daemon_sleep * HZ;
1214 mutex_unlock(&mddev->bitmap_info.mutex); 1219 mutex_unlock(&mddev->bitmap_info.mutex);
1215} 1220}
1216 1221
@@ -1479,7 +1484,7 @@ void bitmap_cond_end_sync(struct bitmap *bitmap, sector_t sector)
1479 return; 1484 return;
1480 } 1485 }
1481 if (time_before(jiffies, (bitmap->last_end_sync 1486 if (time_before(jiffies, (bitmap->last_end_sync
1482 + bitmap->daemon_sleep * HZ))) 1487 + bitmap->mddev->bitmap_info.daemon_sleep * HZ)))
1483 return; 1488 return;
1484 wait_event(bitmap->mddev->recovery_wait, 1489 wait_event(bitmap->mddev->recovery_wait,
1485 atomic_read(&bitmap->mddev->recovery_active) == 0); 1490 atomic_read(&bitmap->mddev->recovery_active) == 0);
@@ -1540,7 +1545,7 @@ void bitmap_dirty_bits(struct bitmap *bitmap, unsigned long s, unsigned long e)
1540void bitmap_flush(mddev_t *mddev) 1545void bitmap_flush(mddev_t *mddev)
1541{ 1546{
1542 struct bitmap *bitmap = mddev->bitmap; 1547 struct bitmap *bitmap = mddev->bitmap;
1543 int sleep; 1548 long sleep;
1544 1549
1545 if (!bitmap) /* there was no bitmap */ 1550 if (!bitmap) /* there was no bitmap */
1546 return; 1551 return;
@@ -1548,12 +1553,13 @@ void bitmap_flush(mddev_t *mddev)
1548 /* run the daemon_work three time to ensure everything is flushed 1553 /* run the daemon_work three time to ensure everything is flushed
1549 * that can be 1554 * that can be
1550 */ 1555 */
1551 sleep = bitmap->daemon_sleep; 1556 sleep = mddev->bitmap_info.daemon_sleep * HZ * 2;
1552 bitmap->daemon_sleep = 0; 1557 bitmap->daemon_lastrun -= sleep;
1553 bitmap_daemon_work(mddev); 1558 bitmap_daemon_work(mddev);
1559 bitmap->daemon_lastrun -= sleep;
1554 bitmap_daemon_work(mddev); 1560 bitmap_daemon_work(mddev);
1561 bitmap->daemon_lastrun -= sleep;
1555 bitmap_daemon_work(mddev); 1562 bitmap_daemon_work(mddev);
1556 bitmap->daemon_sleep = sleep;
1557 bitmap_update_sb(bitmap); 1563 bitmap_update_sb(bitmap);
1558} 1564}
1559 1565
@@ -1633,7 +1639,6 @@ int bitmap_create(mddev_t *mddev)
1633 bitmap->mddev = mddev; 1639 bitmap->mddev = mddev;
1634 1640
1635 bitmap->file = file; 1641 bitmap->file = file;
1636 bitmap->offset = mddev->bitmap_info.offset;
1637 if (file) { 1642 if (file) {
1638 get_file(file); 1643 get_file(file);
1639 /* As future accesses to this file will use bmap, 1644 /* As future accesses to this file will use bmap,
@@ -1642,12 +1647,12 @@ int bitmap_create(mddev_t *mddev)
1642 */ 1647 */
1643 vfs_fsync(file, file->f_dentry, 1); 1648 vfs_fsync(file, file->f_dentry, 1);
1644 } 1649 }
1645 /* read superblock from bitmap file (this sets bitmap->chunksize) */ 1650 /* read superblock from bitmap file (this sets mddev->bitmap_info.chunksize) */
1646 err = bitmap_read_sb(bitmap); 1651 err = bitmap_read_sb(bitmap);
1647 if (err) 1652 if (err)
1648 goto error; 1653 goto error;
1649 1654
1650 bitmap->chunkshift = ffz(~bitmap->chunksize); 1655 bitmap->chunkshift = ffz(~mddev->bitmap_info.chunksize);
1651 1656
1652 /* now that chunksize and chunkshift are set, we can use these macros */ 1657 /* now that chunksize and chunkshift are set, we can use these macros */
1653 chunks = (blocks + CHUNK_BLOCK_RATIO(bitmap) - 1) >> 1658 chunks = (blocks + CHUNK_BLOCK_RATIO(bitmap) - 1) >>
@@ -1689,7 +1694,7 @@ int bitmap_create(mddev_t *mddev)
1689 1694
1690 mddev->bitmap = bitmap; 1695 mddev->bitmap = bitmap;
1691 1696
1692 mddev->thread->timeout = bitmap->daemon_sleep * HZ; 1697 mddev->thread->timeout = mddev->bitmap_info.daemon_sleep * HZ;
1693 1698
1694 bitmap_update_sb(bitmap); 1699 bitmap_update_sb(bitmap);
1695 1700