raid10.c (6b9656205469269c050963c71fca1998b247a560) | raid10.c (2c7d46ec192e4f2b350f67a0e185b9bce646cd6b) |
---|---|
1/* 2 * raid10.c : Multiple Devices driver for Linux 3 * 4 * Copyright (C) 2000-2004 Neil Brown 5 * 6 * RAID-10 support for md. 7 * 8 * Base on code in raid1.c. See raid1.c for futher copyright information. --- 785 unchanged lines hidden (view full) --- 794{ 795 conf_t *conf = mddev->private; 796 mirror_info_t *mirror; 797 r10bio_t *r10_bio; 798 struct bio *read_bio; 799 int i; 800 int chunk_sects = conf->chunk_mask + 1; 801 const int rw = bio_data_dir(bio); | 1/* 2 * raid10.c : Multiple Devices driver for Linux 3 * 4 * Copyright (C) 2000-2004 Neil Brown 5 * 6 * RAID-10 support for md. 7 * 8 * Base on code in raid1.c. See raid1.c for futher copyright information. --- 785 unchanged lines hidden (view full) --- 794{ 795 conf_t *conf = mddev->private; 796 mirror_info_t *mirror; 797 r10bio_t *r10_bio; 798 struct bio *read_bio; 799 int i; 800 int chunk_sects = conf->chunk_mask + 1; 801 const int rw = bio_data_dir(bio); |
802 const bool do_sync = (bio->bi_rw & REQ_SYNC); | 802 const unsigned long do_sync = (bio->bi_rw & REQ_SYNC); |
803 struct bio_list bl; 804 unsigned long flags; 805 mdk_rdev_t *blocked_rdev; 806 807 if (unlikely(bio->bi_rw & REQ_HARDBARRIER)) { 808 md_barrier_request(mddev, bio); 809 return 0; 810 } --- 921 unchanged lines hidden (view full) --- 1732 printk(KERN_ALERT "md/raid10:%s: %s: unrecoverable I/O" 1733 " read error for block %llu\n", 1734 mdname(mddev), 1735 bdevname(bio->bi_bdev,b), 1736 (unsigned long long)r10_bio->sector); 1737 raid_end_bio_io(r10_bio); 1738 bio_put(bio); 1739 } else { | 803 struct bio_list bl; 804 unsigned long flags; 805 mdk_rdev_t *blocked_rdev; 806 807 if (unlikely(bio->bi_rw & REQ_HARDBARRIER)) { 808 md_barrier_request(mddev, bio); 809 return 0; 810 } --- 921 unchanged lines hidden (view full) --- 1732 printk(KERN_ALERT "md/raid10:%s: %s: unrecoverable I/O" 1733 " read error for block %llu\n", 1734 mdname(mddev), 1735 bdevname(bio->bi_bdev,b), 1736 (unsigned long long)r10_bio->sector); 1737 raid_end_bio_io(r10_bio); 1738 bio_put(bio); 1739 } else { |
1740 const bool do_sync = (r10_bio->master_bio->bi_rw & REQ_SYNC); | 1740 const unsigned long do_sync = (r10_bio->master_bio->bi_rw & REQ_SYNC); |
1741 bio_put(bio); 1742 rdev = conf->mirrors[mirror].rdev; 1743 if (printk_ratelimit()) 1744 printk(KERN_ERR "md/raid10:%s: %s: redirecting sector %llu to" 1745 " another mirror\n", 1746 mdname(mddev), 1747 bdevname(rdev->bdev,b), 1748 (unsigned long long)r10_bio->sector); --- 780 unchanged lines hidden --- | 1741 bio_put(bio); 1742 rdev = conf->mirrors[mirror].rdev; 1743 if (printk_ratelimit()) 1744 printk(KERN_ERR "md/raid10:%s: %s: redirecting sector %llu to" 1745 " another mirror\n", 1746 mdname(mddev), 1747 bdevname(rdev->bdev,b), 1748 (unsigned long long)r10_bio->sector); --- 780 unchanged lines hidden --- |