From 023927bc473b6088daf14b6c8bf4ed9bec9a60ee Mon Sep 17 00:00:00 2001 From: Jianpeng Ma Date: Fri, 19 Sep 2014 11:27:57 +0800 Subject: [PATCH] ReplicatedPG: For MAPEXT, using bl.length() instead of op.extent.length as num_rd_kb. For fiemap, it don't real read the data(offset,length). It only fetech the infos of extents. So don't use length as num_rd_kb. Signed-off-by: Jianpeng Ma --- src/osd/ReplicatedPG.cc | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/osd/ReplicatedPG.cc b/src/osd/ReplicatedPG.cc index 9addff11125a..579535bbe661 100644 --- a/src/osd/ReplicatedPG.cc +++ b/src/osd/ReplicatedPG.cc @@ -3367,7 +3367,8 @@ int ReplicatedPG::do_osd_ops(OpContext *ctx, vector& ops) osd_op.outdata.claim(bl); if (r < 0) result = r; - ctx->delta_stats.num_rd_kb += SHIFT_ROUND_UP(op.extent.length, 10); + else + ctx->delta_stats.num_rd_kb += SHIFT_ROUND_UP(bl.length(), 10); ctx->delta_stats.num_rd++; dout(10) << " map_extents done on object " << soid << dendl; } -- 2.47.3