diff options
author | Gregory Farnum <greg@inktank.com> | 2013-09-26 13:12:37 -0700 |
---|---|---|
committer | Gregory Farnum <greg@inktank.com> | 2013-09-26 13:12:37 -0700 |
commit | b5a3978728d9435a543c00bb718f6e02438285c7 (patch) | |
tree | 42532262085a2bc170b4cc8fce262705572cf303 | |
parent | bd0f29a2c28cca496ec830eac932477ebf3182ba (diff) | |
parent | 179001b42c142e0877e6c4991f88e7355c9b82ff (diff) | |
download | ceph-b5a3978728d9435a543c00bb718f6e02438285c7.tar.gz |
Merge pull request #645 from liewegas/wip-6346
Reviewed-by: Greg Farnum <greg@inktank.com>
-rw-r--r-- | src/osd/ReplicatedPG.cc | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/src/osd/ReplicatedPG.cc b/src/osd/ReplicatedPG.cc index 9b4d069370b..e949c7a9b7f 100644 --- a/src/osd/ReplicatedPG.cc +++ b/src/osd/ReplicatedPG.cc @@ -2645,6 +2645,9 @@ int ReplicatedPG::do_osd_ops(OpContext *ctx, vector<OSDOp>& ops) op.extent.length = (op.extent.offset > oi.size ? 0 : oi.size - op.extent.offset); dout(10) << " old truncate_seq " << op.extent.truncate_seq << " < current " << seq << ", adjusting write length to " << op.extent.length << dendl; + bufferlist t; + t.substr_of(osd_op.indata, 0, op.extent.length); + osd_op.indata.swap(t); } if (op.extent.truncate_seq > seq) { // write arrives before trimtrunc |