diff options
| author | Lars Ellenberg <lars@linbit.com> | 2016-06-13 18:26:29 -0400 |
|---|---|---|
| committer | Jens Axboe <axboe@fb.com> | 2016-06-13 23:43:06 -0400 |
| commit | 65f5be3579a69c6a057eeb99620999788982bff6 (patch) | |
| tree | 116ce9c598cce7bc43b837e1e36e1fab0db35c52 /drivers/block/drbd | |
| parent | af61494ad4725ed78bd6b3f159a32463d80fdd60 (diff) | |
drbd: discard_zeroes_if_aligned allows "thin" resync for discard_zeroes_data=0
Even if discard_zeroes_data != 0,
if discard_zeroes_if_aligned is set, we assume we can reliably
zero-out/discard using the drbd_issue_peer_discard() helper.
Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'drivers/block/drbd')
| -rw-r--r-- | drivers/block/drbd/drbd_nl.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/block/drbd/drbd_nl.c b/drivers/block/drbd/drbd_nl.c index e5fdcc6c2e67..169e3e15a30e 100644 --- a/drivers/block/drbd/drbd_nl.c +++ b/drivers/block/drbd/drbd_nl.c | |||
| @@ -1408,9 +1408,12 @@ static void sanitize_disk_conf(struct drbd_device *device, struct disk_conf *dis | |||
| 1408 | if (disk_conf->al_extents > drbd_al_extents_max(nbc)) | 1408 | if (disk_conf->al_extents > drbd_al_extents_max(nbc)) |
| 1409 | disk_conf->al_extents = drbd_al_extents_max(nbc); | 1409 | disk_conf->al_extents = drbd_al_extents_max(nbc); |
| 1410 | 1410 | ||
| 1411 | if (!blk_queue_discard(q) || !q->limits.discard_zeroes_data) { | 1411 | if (!blk_queue_discard(q) |
| 1412 | disk_conf->rs_discard_granularity = 0; /* disable feature */ | 1412 | || (!q->limits.discard_zeroes_data && !disk_conf->discard_zeroes_if_aligned)) { |
| 1413 | drbd_info(device, "rs_discard_granularity feature disabled\n"); | 1413 | if (disk_conf->rs_discard_granularity) { |
| 1414 | disk_conf->rs_discard_granularity = 0; /* disable feature */ | ||
| 1415 | drbd_info(device, "rs_discard_granularity feature disabled\n"); | ||
| 1416 | } | ||
| 1414 | } | 1417 | } |
| 1415 | 1418 | ||
| 1416 | if (disk_conf->rs_discard_granularity) { | 1419 | if (disk_conf->rs_discard_granularity) { |
