aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/block/drbd/drbd_receiver.c
diff options
context:
space:
mode:
authorPhilipp Reisner <philipp.reisner@linbit.com>2011-09-29 07:00:14 -0400
committerPhilipp Reisner <philipp.reisner@linbit.com>2012-11-08 10:58:04 -0500
commit9bcd2521827bb7c418a83a77474c449d6496d55c (patch)
treeaae5995f4d1d6b72d0a7ccd30d31fab01be29a45 /drivers/block/drbd/drbd_receiver.c
parent22d81140aea85f9ac388fa12768dc502ef00eaae (diff)
drbd: fix "stalled" empty resync
With sync-after dependencies, given "lucky" timing of pause/unpause events, and the end of an empty (0 bits set) resync was sometimes not detected on the SyncTarget, leading to a "stalled" SyncSource state. Fixed this by expecting not only "Inconsistent -> UpToDate" but also "Consistent -> UpToDate" transitions for the peer disk state to end a resync. Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com> Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
Diffstat (limited to 'drivers/block/drbd/drbd_receiver.c')
-rw-r--r--drivers/block/drbd/drbd_receiver.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/drivers/block/drbd/drbd_receiver.c b/drivers/block/drbd/drbd_receiver.c
index 4004a682d0ec..aba04d7dadf5 100644
--- a/drivers/block/drbd/drbd_receiver.c
+++ b/drivers/block/drbd/drbd_receiver.c
@@ -3748,9 +3748,14 @@ static int receive_state(struct drbd_tconn *tconn, struct packet_info *pi)
3748 os = ns = drbd_read_state(mdev); 3748 os = ns = drbd_read_state(mdev);
3749 spin_unlock_irq(&mdev->tconn->req_lock); 3749 spin_unlock_irq(&mdev->tconn->req_lock);
3750 3750
3751 /* peer says his disk is uptodate, while we think it is inconsistent, 3751 /* If this is the "end of sync" confirmation, usually the peer disk
3752 * and this happens while we think we have a sync going on. */ 3752 * transitions from D_INCONSISTENT to D_UP_TO_DATE. For empty (0 bits
3753 if (os.pdsk == D_INCONSISTENT && real_peer_disk == D_UP_TO_DATE && 3753 * set) resync started in PausedSyncT, or if the timing of pause-/
3754 * unpause-sync events has been "just right", the peer disk may
3755 * transition from D_CONSISTENT to D_UP_TO_DATE as well.
3756 */
3757 if ((os.pdsk == D_INCONSISTENT || os.pdsk == D_CONSISTENT) &&
3758 real_peer_disk == D_UP_TO_DATE &&
3754 os.conn > C_CONNECTED && os.disk == D_UP_TO_DATE) { 3759 os.conn > C_CONNECTED && os.disk == D_UP_TO_DATE) {
3755 /* If we are (becoming) SyncSource, but peer is still in sync 3760 /* If we are (becoming) SyncSource, but peer is still in sync
3756 * preparation, ignore its uptodate-ness to avoid flapping, it 3761 * preparation, ignore its uptodate-ness to avoid flapping, it