rbd: create+truncate for whole-object layered discards
authorIlya Dryomov <idryomov@gmail.com>
Tue, 6 Feb 2018 18:26:34 +0000 (19:26 +0100)
committerIlya Dryomov <idryomov@gmail.com>
Mon, 2 Apr 2018 08:12:43 +0000 (10:12 +0200)
commit2bb1e56ec6450ce533c644c5bfa548dc34c551a0
tree10b591e350fc80d19b5a46c3798f3be5fa3acbc8
parent86bd7998fa2c1b18fda74cfa4674cfb49ae701c7
rbd: create+truncate for whole-object layered discards

A whole-object layered discard is implemented as a truncate rather
than a delete: a dummy object is needed to prevent the CoW machinery
from kicking in.  However, a truncate on a non-existent object is
a no-op.  If the object doesn't exist in HEAD, a discard request is
effectively ignored, which violates our "discard zeroes data" promise
and breaks REQ_OP_WRITE_ZEROES implementation.

A non-exclusive create on an existing object is also a no-op, so the
fix is to do a compound create+truncate instead.

Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
drivers/block/rbd.c