From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1423159AbWCXGCm (ORCPT ); Fri, 24 Mar 2006 01:02:42 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1423162AbWCXGCl (ORCPT ); Fri, 24 Mar 2006 01:02:41 -0500 Received: from cantor2.suse.de ([195.135.220.15]:33434 "EHLO mx2.suse.de") by vger.kernel.org with ESMTP id S1423159AbWCXGCk (ORCPT ); Fri, 24 Mar 2006 01:02:40 -0500 From: NeilBrown To: Andrew Morton Date: Fri, 24 Mar 2006 17:00:36 +1100 Message-Id: <1060324060036.2474@suse.de> X-face: [Gw_3E*Gng}4rRrKRYotwlE?.2|**#s9D Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org When retrying a write due to barrier failure, we don't reset 'remaining', so it goes negative and never hits 0 again. Signed-off-by: Neil Brown ### Diffstat output ./drivers/md/raid1.c | 3 +++ 1 file changed, 3 insertions(+) diff ./drivers/md/raid1.c~current~ ./drivers/md/raid1.c --- ./drivers/md/raid1.c~current~ 2006-03-24 14:01:30.000000000 +1100 +++ ./drivers/md/raid1.c 2006-03-24 14:06:49.000000000 +1100 @@ -1402,6 +1402,9 @@ static void raid1d(mddev_t *mddev) clear_bit(R1BIO_BarrierRetry, &r1_bio->state); clear_bit(R1BIO_Barrier, &r1_bio->state); for (i=0; i < conf->raid_disks; i++) + if (r1_bio->bios[i]) + atomic_inc(&r1_bio->remaining); + for (i=0; i < conf->raid_disks; i++) if (r1_bio->bios[i]) { struct bio_vec *bvec; int j;