aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md/dm-service-time.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2013-11-19 12:02:01 +1100
committerNeilBrown <neilb@suse.de>2013-11-19 15:19:17 +1100
commitc91abf5a3546a4ff0838d2905f4d7eae2795f724 (patch)
tree39b3735cebfa73ff370f2738bd8578a113fe4215 /drivers/md/dm-service-time.c
parentmd: fix some places where mddev_lock return value is not checked. (diff)
downloadlinux-dev-c91abf5a3546a4ff0838d2905f4d7eae2795f724.tar.xz
linux-dev-c91abf5a3546a4ff0838d2905f4d7eae2795f724.zip
md: use MD_RECOVERY_INTR instead of kthread_should_stop in resync thread.
We currently use kthread_should_stop() in various places in the sync/reshape code to abort early. However some places set MD_RECOVERY_INTR but don't immediately call md_reap_sync_thread() (and we will shortly get another one). When this happens we are relying on md_check_recovery() to reap the thread and that only happen when it finishes normally. So MD_RECOVERY_INTR must lead to a normal finish without the kthread_should_stop() test. So replace all relevant tests, and be more careful when the thread is interrupted not to acknowledge that latest step in a reshape as it may not be fully committed yet. Also add a test on MD_RECOVERY_INTR in the 'is_mddev_idle' loop so we don't wait have to wait for the speed to drop before we can abort. Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md/dm-service-time.c')
0 files changed, 0 insertions, 0 deletions