aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/block/drbd
diff options
context:
space:
mode:
authorPhilipp Reisner <philipp.reisner@linbit.com>2013-03-27 09:08:36 -0400
committerJens Axboe <axboe@kernel.dk>2013-03-28 12:10:24 -0400
commit9376d9f8b97f20df5d30c83713652c3118b31534 (patch)
tree279e6afef66121afe7dc86564fb3249ae7b36ab8 /drivers/block/drbd
parenta700471bf335965e7603273fd51034415553246a (diff)
drbd: move invalidating the whole bitmap out of after_state ch()
To avoid other state change requests, after passing through sanitize_state(), to be mistaken for an invalidate, move the "set all bits as out-of-sync" into the invalidate path. Make invalidate and invalidate-remote behave consistently wrt. current connection state (need either an established replication link, or really be disconnected). Also mention that in the documentation. Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com> Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com> Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'drivers/block/drbd')
-rw-r--r--drivers/block/drbd/drbd_nl.c36
-rw-r--r--drivers/block/drbd/drbd_state.c7
2 files changed, 20 insertions, 23 deletions
diff --git a/drivers/block/drbd/drbd_nl.c b/drivers/block/drbd/drbd_nl.c
index 42fda4ae2f87..c49bda7918b3 100644
--- a/drivers/block/drbd/drbd_nl.c
+++ b/drivers/block/drbd/drbd_nl.c
@@ -2448,19 +2448,23 @@ int drbd_adm_invalidate(struct sk_buff *skb, struct genl_info *info)
2448 2448
2449 retcode = _drbd_request_state(mdev, NS(conn, C_STARTING_SYNC_T), CS_ORDERED); 2449 retcode = _drbd_request_state(mdev, NS(conn, C_STARTING_SYNC_T), CS_ORDERED);
2450 2450
2451 if (retcode < SS_SUCCESS && retcode != SS_NEED_CONNECTION) 2451 /* If that did not work, try again,
2452 retcode = drbd_request_state(mdev, NS(conn, C_STARTING_SYNC_T)); 2452 * but log failures this time (implicit CS_VERBOSE).
2453 2453 *
2454 while (retcode == SS_NEED_CONNECTION) { 2454 * If we happen to be C_STANDALONE R_SECONDARY,
2455 spin_lock_irq(&mdev->tconn->req_lock); 2455 * just change to D_INCONSISTENT, and set all bits in the bitmap.
2456 if (mdev->state.conn < C_CONNECTED) 2456 * Otherwise, we just fail, to avoid races with the resync handshake.
2457 retcode = _drbd_set_state(_NS(mdev, disk, D_INCONSISTENT), CS_VERBOSE, NULL); 2457 */
2458 spin_unlock_irq(&mdev->tconn->req_lock); 2458 if (retcode < SS_SUCCESS) {
2459 2459 if (mdev->state.conn == C_STANDALONE && mdev->state.role == R_SECONDARY) {
2460 if (retcode != SS_NEED_CONNECTION) 2460 retcode = drbd_request_state(mdev, NS(disk, D_INCONSISTENT));
2461 break; 2461 if (retcode >= SS_SUCCESS) {
2462 2462 if (drbd_bitmap_io(mdev, &drbd_bmio_set_n_write,
2463 retcode = drbd_request_state(mdev, NS(conn, C_STARTING_SYNC_T)); 2463 "set_n_write from invalidate", BM_LOCKED_MASK))
2464 retcode = ERR_IO_MD_DISK;
2465 }
2466 } else
2467 retcode = drbd_request_state(mdev, NS(conn, C_STARTING_SYNC_T));
2464 } 2468 }
2465 drbd_resume_io(mdev); 2469 drbd_resume_io(mdev);
2466 2470
@@ -2517,9 +2521,9 @@ int drbd_adm_invalidate_peer(struct sk_buff *skb, struct genl_info *info)
2517 2521
2518 retcode = _drbd_request_state(mdev, NS(conn, C_STARTING_SYNC_S), CS_ORDERED); 2522 retcode = _drbd_request_state(mdev, NS(conn, C_STARTING_SYNC_S), CS_ORDERED);
2519 if (retcode < SS_SUCCESS) { 2523 if (retcode < SS_SUCCESS) {
2520 if (retcode == SS_NEED_CONNECTION && mdev->state.role == R_PRIMARY) { 2524 if (mdev->state.conn == C_STANDALONE && mdev->state.role == R_PRIMARY) {
2521 /* The peer will get a resync upon connect anyways. 2525 /* The peer will get a resync upon connect anyways. Just make that
2522 * Just make that into a full resync. */ 2526 into a full resync. */
2523 retcode = drbd_request_state(mdev, NS(pdsk, D_INCONSISTENT)); 2527 retcode = drbd_request_state(mdev, NS(pdsk, D_INCONSISTENT));
2524 if (retcode >= SS_SUCCESS) { 2528 if (retcode >= SS_SUCCESS) {
2525 if (drbd_bitmap_io(mdev, &drbd_bmio_set_susp_al, 2529 if (drbd_bitmap_io(mdev, &drbd_bmio_set_susp_al,
diff --git a/drivers/block/drbd/drbd_state.c b/drivers/block/drbd/drbd_state.c
index 0fe220cfb9e9..3bc686f48b53 100644
--- a/drivers/block/drbd/drbd_state.c
+++ b/drivers/block/drbd/drbd_state.c
@@ -1377,13 +1377,6 @@ static void after_state_ch(struct drbd_conf *mdev, union drbd_state os,
1377 &drbd_bmio_set_n_write, &abw_start_sync, 1377 &drbd_bmio_set_n_write, &abw_start_sync,
1378 "set_n_write from StartingSync", BM_LOCKED_TEST_ALLOWED); 1378 "set_n_write from StartingSync", BM_LOCKED_TEST_ALLOWED);
1379 1379
1380 /* We are invalidating our self... */
1381 if (os.conn < C_CONNECTED && ns.conn < C_CONNECTED &&
1382 os.disk > D_INCONSISTENT && ns.disk == D_INCONSISTENT)
1383 /* other bitmap operation expected during this phase */
1384 drbd_queue_bitmap_io(mdev, &drbd_bmio_set_n_write, NULL,
1385 "set_n_write from invalidate", BM_LOCKED_MASK);
1386
1387 /* first half of local IO error, failure to attach, 1380 /* first half of local IO error, failure to attach,
1388 * or administrative detach */ 1381 * or administrative detach */
1389 if (os.disk != D_FAILED && ns.disk == D_FAILED) { 1382 if (os.disk != D_FAILED && ns.disk == D_FAILED) {