diff options
author | Philipp Reisner <philipp.reisner@linbit.com> | 2013-03-27 09:08:36 -0400 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2013-03-28 12:10:24 -0400 |
commit | 9376d9f8b97f20df5d30c83713652c3118b31534 (patch) | |
tree | 279e6afef66121afe7dc86564fb3249ae7b36ab8 /drivers/block/drbd | |
parent | a700471bf335965e7603273fd51034415553246a (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.c | 36 | ||||
-rw-r--r-- | drivers/block/drbd/drbd_state.c | 7 |
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) { |