From e4c0fe5d160d1e27840d94e8a74ae5be1741db8e Mon Sep 17 00:00:00 2001
From: Zheng Zengkai <zhengzengkai@huawei.com>
Date: Wed, 12 Jan 2022 10:26:44 +0800
Subject: [PATCH] Revert "bcache: Rewrite patch to delay to invalidate cache
 data"

euleros/rtos inclusion
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I4LOJ6
CVE: NA

--------------------------------

This patch set introduce many conflicts while backporting mainline
bcache patches, revert it temporarily.

This reverts commit e8c75ee9914771ad5dcffaf4ff5716429440dfbc.

Signed-off-by: Zheng Zengkai <zhengzengkai@huawei.com>
Acked-by: Xie XiuQi <xiexiuqi@huawei.com>
---
 drivers/md/bcache/request.c | 15 ++++-----------
 drivers/md/bcache/request.h | 13 -------------
 2 files changed, 4 insertions(+), 24 deletions(-)

diff --git a/drivers/md/bcache/request.c b/drivers/md/bcache/request.c
index bad70906e8a2..04a779573fdd 100644
--- a/drivers/md/bcache/request.c
+++ b/drivers/md/bcache/request.c
@@ -735,8 +735,6 @@ struct search *search_alloc(struct bio *bio,
 	/* Count on the bcache device */
 	s->start_time		= part_start_io_acct(d->disk, &s->part, bio);
 	s->prefetch		= prefetch;
-	s->write_inval_data_putoff = false;
-
 	s->iop.c		= d->c;
 	s->iop.bio		= NULL;
 	s->iop.inode		= d->id;
@@ -757,10 +755,6 @@ static void cached_dev_bio_complete(struct closure *cl)
 	struct search *s = container_of(cl, struct search, cl);
 	struct cached_dev *dc = container_of(s->d, struct cached_dev, disk);
 
-	/* eusure this lock is released after data_insert */
-	if (s->write_inval_data_putoff)
-		up_read_non_owner(&dc->writeback_lock);
-
 	cached_dev_put(dc);
 	search_free(cl);
 }
@@ -999,10 +993,10 @@ static void cached_dev_write_complete(struct closure *cl)
 	struct search *s = container_of(cl, struct search, cl);
 	struct cached_dev *dc = container_of(s->d, struct cached_dev, disk);
 
-	if (s->write_inval_data_putoff)
+	if (!s->iop.bypass)
 		closure_call(&s->iop.cl, bch_data_insert, NULL, cl);
-	else
-		up_read_non_owner(&dc->writeback_lock);
+
+	up_read_non_owner(&dc->writeback_lock);
 	continue_at(cl, cached_dev_bio_complete, NULL);
 }
 
@@ -1054,7 +1048,6 @@ static void cached_dev_write(struct cached_dev *dc, struct search *s)
 		bio->bi_end_io = backing_request_endio;
 		closure_bio_submit(s->iop.c, bio, cl);
 
-		s->write_inval_data_putoff = true;
 	} else if (s->iop.writeback) {
 		bch_writeback_add(dc);
 		s->iop.bio = bio;
@@ -1087,7 +1080,7 @@ static void cached_dev_write(struct cached_dev *dc, struct search *s)
 	}
 
 insert_data:
-	if (!s->write_inval_data_putoff)
+	if (!s->iop.bypass)
 		closure_call(&s->iop.cl, bch_data_insert, NULL, cl);
 	continue_at(cl, cached_dev_write_complete, NULL);
 }
diff --git a/drivers/md/bcache/request.h b/drivers/md/bcache/request.h
index 42bf280d4625..21678037d215 100644
--- a/drivers/md/bcache/request.h
+++ b/drivers/md/bcache/request.h
@@ -65,19 +65,6 @@ struct search {
 	unsigned long		start_time;
 	/* for prefetch, we do not need copy data to bio */
 	bool			prefetch;
-	/*
-	 * The function bch_data_insert() is invoked asynchronously as the bio
-	 * subbmited to backend block device, therefore there may be a read
-	 * request subbmited after the bch_data_insert() done and ended before
-	 * the backend bio is end. This read request will read data from the
-	 * backend block device, and insert dirty data to cache device. However
-	 * by writearound cache mode, bcache will not invalidate data again,
-	 * so that read request after will read dirty data from the cache,
-	 * causing a data corruption.
-	 * So that we should put off this invalidation. This switch is for this
-	 * put off.
-	 */
-	bool			write_inval_data_putoff;
 	struct list_head	list_node;
 	wait_queue_head_t	wqh;
 	struct acache_info	smp;
-- 
GitLab