drbd: Consider that the no-data-condition could be in connected state
authorPhilipp Reisner <philipp.reisner@linbit.com>
Fri, 15 Jul 2011 16:44:26 +0000 (18:44 +0200)
committerPhilipp Reisner <philipp.reisner@linbit.com>
Thu, 8 Nov 2012 15:57:57 +0000 (16:57 +0100)
...when the peer has inconsistent data. In that case we failed to
clear the susp_nod flag. When the local disk was attached again

Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
drivers/block/drbd/drbd_state.c

index 1763357a065a532050124fc950fcb9364d25d45d..60371ba90fb1b0b4ddf1a09aea459fcdac45f9d1 100644 (file)
@@ -1180,7 +1180,8 @@ static void after_state_ch(struct drbd_conf *mdev, union drbd_state os,
                if (os.conn < C_CONNECTED && conn_lowest_conn(mdev->tconn) >= C_CONNECTED)
                        what = RESEND;
 
-               if (os.disk == D_ATTACHING && conn_lowest_disk(mdev->tconn) > D_ATTACHING)
+               if ((os.disk == D_ATTACHING || os.disk == D_NEGOTIATING) &&
+                   conn_lowest_disk(mdev->tconn) > D_NEGOTIATING)
                        what = RESTART_FROZEN_DISK_IO;
 
                if (what != NOTHING) {