summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/osd/ReplicatedPG.cc12
1 files changed, 4 insertions, 8 deletions
diff --git a/src/osd/ReplicatedPG.cc b/src/osd/ReplicatedPG.cc
index a2a40058ac1..bca49024c0b 100644
--- a/src/osd/ReplicatedPG.cc
+++ b/src/osd/ReplicatedPG.cc
@@ -2594,7 +2594,7 @@ int ReplicatedPG::do_osd_ops(OpContext *ctx, vector<OSDOp>& ops)
case CEPH_OSD_OP_WRITE:
++ctx->num_write;
{ // write
- if (op.extent.length > osd_op.indata.length()) {
+ if (op.extent.length != osd_op.indata.length()) {
result = -EINVAL;
break;
}
@@ -2629,9 +2629,7 @@ int ReplicatedPG::do_osd_ops(OpContext *ctx, vector<OSDOp>& ops)
result = check_offset_and_length(op.extent.offset, op.extent.length);
if (result < 0)
break;
- bufferlist nbl;
- bp.copy(op.extent.length, nbl);
- t.write(coll, soid, op.extent.offset, op.extent.length, nbl);
+ t.write(coll, soid, op.extent.offset, op.extent.length, osd_op.indata);
write_update_size_and_usage(ctx->delta_stats, oi, ssc->snapset, ctx->modified_ranges,
op.extent.offset, op.extent.length, true);
if (!obs.exists) {
@@ -2644,22 +2642,20 @@ int ReplicatedPG::do_osd_ops(OpContext *ctx, vector<OSDOp>& ops)
case CEPH_OSD_OP_WRITEFULL:
++ctx->num_write;
{ // write full object
- if (op.extent.length > osd_op.indata.length()) {
+ if (op.extent.length != osd_op.indata.length()) {
result = -EINVAL;
break;
}
result = check_offset_and_length(op.extent.offset, op.extent.length);
if (result < 0)
break;
- bufferlist nbl;
- bp.copy(op.extent.length, nbl);
if (obs.exists) {
t.truncate(coll, soid, 0);
} else {
ctx->delta_stats.num_objects++;
obs.exists = true;
}
- t.write(coll, soid, op.extent.offset, op.extent.length, nbl);
+ t.write(coll, soid, op.extent.offset, op.extent.length, osd_op.indata);
interval_set<uint64_t> ch;
if (oi.size > 0)
ch.insert(0, oi.size);