In commit(db91ff55bdf06736b849afc1b1fce5763bbb8d5d),it said: >If a resync is aborted we should record how far we got >(recovery_cp) the last request that we know has completed >(->curr_resync_completed) rather than the last request that was >submitted (->curr_resync). But when resync aborted, it execed >wait_event(mddev->recovery_wait, !atomic_read(&mddev->recovery_active)); After this, the ->curr_resync is the last completed request. Signed-off-by: Jianpeng Ma <majianpeng@xxxxxxxxx> --- drivers/md/md.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/drivers/md/md.c b/drivers/md/md.c index 9ab768a..1d9940d 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c @@ -7558,8 +7558,7 @@ void md_do_sync(struct md_thread *thread) printk(KERN_INFO "md: checkpointing %s of %s.\n", desc, mdname(mddev)); - mddev->recovery_cp = - mddev->curr_resync_completed; + mddev->recovery_cp = mddev->curr_resync; } } else mddev->recovery_cp = MaxSector; -- 1.7.9.5 ?韬{.n?????%??檩??w?{.n???{炳盯w???塄}?财??j:+v??????2??璀??摺?囤??z夸z罐?+?????w棹f