From: Andrey Zhadchenko <andrey.zhadche...@virtuozzo.com>

When mapping request, save all flags, rather then only operation
type. Use it later to check if the request is FUA or not.
Unfortunately there is no REQ_FUA equivalent on IOCB layer, but
IOCB_DSYNC is usually translated to it, as can be seen in
__iomap_dio_rw().

https://virtuozzo.atlassian.net/browse/VSTOR-91817
Signed-off-by: Andrey Zhadchenko <andrey.zhadche...@virtuozzo.com>
---
 drivers/md/dm-ploop-map.c    | 13 ++++++++++---
 drivers/md/dm-ploop-target.c |  2 ++
 2 files changed, 12 insertions(+), 3 deletions(-)

diff --git a/drivers/md/dm-ploop-map.c b/drivers/md/dm-ploop-map.c
index c83b93f0590a..857896a61ce9 100644
--- a/drivers/md/dm-ploop-map.c
+++ b/drivers/md/dm-ploop-map.c
@@ -133,7 +133,7 @@ static void ploop_init_prq_and_embedded_pio(struct ploop 
*ploop,
                struct request *rq, struct ploop_rq *prq, struct pio *pio)
 {
        ploop_init_prq(prq, rq);
-       ploop_init_pio(ploop, req_op(rq), pio);
+       ploop_init_pio(ploop, rq->cmd_flags, pio);
        pio->css = prq->css;
 
        pio->endio_cb = ploop_prq_endio;
@@ -279,7 +279,11 @@ static struct pio *ploop_split_and_chain_pio(struct ploop 
*ploop,
        if (!split)
                return NULL;
 
-       ploop_init_pio(ploop, pio->bi_op, split);
+       /*
+        * Do not copy REQ_FUA to every split pio. we will sync
+        * before calling endio on original pio.
+        */
+       ploop_init_pio(ploop, pio->bi_op & ~REQ_FUA, split);
        split->css = pio->css;
        split->queue_list_id = pio->queue_list_id;
        split->free_on_endio = true;
@@ -1496,6 +1500,9 @@ static bool 
ploop_locate_new_cluster_and_attach_pio(struct ploop *ploop,
        if (bat_update_prepared)
                ploop_md_make_dirty(ploop, md);
 
+       if (pio->bi_op & REQ_FUA)
+               piwb->pio->bi_op |= REQ_FUA;
+
        ploop_attach_end_action(pio, piwb);
        attached = true;
 out:
@@ -1914,7 +1921,7 @@ static void ploop_submit_embedded_pio(struct ploop 
*ploop, struct pio *pio)
        if (blk_rq_bytes(rq)) {
                pio->queue_list_id = PLOOP_LIST_PREPARE;
        } else {
-               WARN_ON_ONCE(pio->bi_op != REQ_OP_FLUSH);
+               WARN_ON_ONCE(!((pio->bi_op & REQ_OP_MASK) == REQ_OP_FLUSH));
                pio->queue_list_id = PLOOP_LIST_FLUSH;
        }
 
diff --git a/drivers/md/dm-ploop-target.c b/drivers/md/dm-ploop-target.c
index 589082c8e110..00d160b3fd3c 100644
--- a/drivers/md/dm-ploop-target.c
+++ b/drivers/md/dm-ploop-target.c
@@ -61,6 +61,8 @@ void ploop_call_rw_iter(struct file *file, loff_t pos, 
unsigned rw,
        init_sync_kiocb(iocb, file);
        iocb->ki_pos = pos;
        iocb->ki_complete = ploop_aio_complete;
+       if (pio->bi_op & REQ_FUA)
+               iocb->ki_flags |= IOCB_DSYNC;
 
        atomic_set(&pio->aio_ref, 2);
 
-- 
2.43.0

_______________________________________________
Devel mailing list
Devel@openvz.org
https://lists.openvz.org/mailman/listinfo/devel

Reply via email to