fix unit of rs_same_csums accounting
Depending on resync request size, we need to account for more than one bit. Impact: cosmetic If SyncTarget reported correctly 100% equal checksums, the SyncSource usually reported 12% equal checksums instead, because it only counted requests, we typically do 32k resync requests, and the bitmap granularity is still 4k. Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com> Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
This commit is contained in:
parent
580b9767db
commit
676396d545
@ -938,7 +938,8 @@ int w_e_end_csum_rs_req(struct drbd_conf *mdev, struct drbd_work *w, int cancel)
|
|||||||
|
|
||||||
if (eq) {
|
if (eq) {
|
||||||
drbd_set_in_sync(mdev, e->sector, e->size);
|
drbd_set_in_sync(mdev, e->sector, e->size);
|
||||||
mdev->rs_same_csum++;
|
/* rs_same_csums unit is BM_BLOCK_SIZE */
|
||||||
|
mdev->rs_same_csum += e->size >> BM_BLOCK_SHIFT;
|
||||||
ok = drbd_send_ack(mdev, P_RS_IS_IN_SYNC, e);
|
ok = drbd_send_ack(mdev, P_RS_IS_IN_SYNC, e);
|
||||||
} else {
|
} else {
|
||||||
inc_rs_pending(mdev);
|
inc_rs_pending(mdev);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user