summaryrefslogtreecommitdiff
path: root/tools/perf/scripts/python/failed-syscalls-by-pid.py
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2013-07-16 10:50:47 +0400
committerNeilBrown <neilb@suse.de>2013-07-18 08:18:01 +0400
commit7bb23c4934059c64cbee2e41d5d24ce122285176 (patch)
treee457c9dc9bfbc502f8a739749a6d6d287f2ec144 /tools/perf/scripts/python/failed-syscalls-by-pid.py
parent47188d39b5deeebf41f87a02af1b3935866364cf (diff)
downloadlinux-7bb23c4934059c64cbee2e41d5d24ce122285176.tar.xz
md/raid10: fix two problems with RAID10 resync.
1/ When an different between blocks is found, data is copied from one bio to the other. However bv_len is used as the length to copy and this could be zero. So use r10_bio->sectors to calculate length instead. Using bv_len was probably always a bit dubious, but the introduction of bio_advance made it much more likely to be a problem. 2/ When preparing some blocks for sync, we don't set BIO_UPTODATE except on bios that we schedule for a read. This ensures that missing/failed devices don't confuse the loop at the top of sync_request write. Commit 8be185f2c9d54d6 "raid10: Use bio_reset()" removed a loop which set BIO_UPTDATE on all appropriate bios. So we need to re-add that flag. These bugs were introduced in 3.10, so this patch is suitable for 3.10-stable, and can remove a potential for data corruption. Cc: stable@vger.kernel.org (3.10) Reported-by: Brassow Jonathan <jbrassow@redhat.com> Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'tools/perf/scripts/python/failed-syscalls-by-pid.py')
0 files changed, 0 insertions, 0 deletions