2022-05-16 21:40:32 +00:00
|
|
|
From b70da899940777d92338d8f83f7a6236818ad08a Mon Sep 17 00:00:00 2001
|
|
|
|
From: Jonathan Bell <jonathan@raspberrypi.com>
|
|
|
|
Date: Mon, 16 May 2022 10:28:27 +0100
|
|
|
|
Subject: [PATCH] mmc: block: Don't do single-sector reads during
|
|
|
|
recovery
|
|
|
|
|
|
|
|
See https://github.com/raspberrypi/linux/issues/5019
|
|
|
|
|
|
|
|
If an SD card has degraded performance such that IO operations time out
|
|
|
|
then the MMC block layer will leak SG DMA mappings in the swiotlb during
|
|
|
|
recovery. It retries the same SG and this causes the leak, as it is
|
|
|
|
mapped twice - once in sdhci_pre_req() and again during single-block
|
|
|
|
reads in sdhci_prepare_data().
|
|
|
|
|
|
|
|
Resetting the card (including power-cycling if a regulator for vmmc is
|
|
|
|
present) ought to be enough to recover a stuck state, so for now don't
|
|
|
|
try single-block reads in the recovery path.
|
|
|
|
|
|
|
|
Signed-off-by: Jonathan Bell <jonathan@raspberrypi.com>
|
|
|
|
---
|
|
|
|
drivers/mmc/core/block.c | 6 +++++-
|
|
|
|
1 file changed, 5 insertions(+), 1 deletion(-)
|
|
|
|
|
|
|
|
--- a/drivers/mmc/core/block.c
|
|
|
|
+++ b/drivers/mmc/core/block.c
|
kernel: bump 5.15 to 5.15.145
Changelog: https://cdn.kernel.org/pub/linux/kernel/v5.x/ChangeLog-5.15.145
No patches needed a rebase.
23.05 backport:
Rebased patch mediatek/100-dts-update-mt7622-rfb1.patch due to
changes introduced in commit e37aa926447f ("arm64: dts: mediatek:
mt7622: fix memory node warning check") in version v5.15.143 and we
jumped over from v5.15.139 directly to v5.15.145.
Build system: x86_64
Build-tested: ramips/tplink_archer-a6-v3
Run-tested: ramips/tplink_archer-a6-v3
23.05 backport:
Stijn:
Compile-tested: ath79/generic, ipq40xx/generic, mvebu/cortexa72, ramips/mt{7621,7620,76x8}, realtek/rtl{838x,930x}, 86/64.
Run-tested: cortexa72 (RB5009UG+S+IN), mt7621 (EAP615-Wall v1), rtl838x (GS1900-10HP, GS1900-8HP, GS108T v3).
Petr:
Compile-tested: ipq807x, mvebu/cortexa9
Run-tested: turris-omnia, prpl-haze
Tested-by: Stijn Segers <foss@volatilesystems.org> [23.05 testing]
Signed-off-by: John Audia <therealgraysky@proton.me>
Signed-off-by: Petr Štetiar <ynezz@true.cz> [23.05 refresh]
(cherry picked from commit 8de4cc77a6d5c25e48566d0203f159287ac7f3fe)
2023-12-23 11:52:06 +00:00
|
|
|
@@ -1888,7 +1888,11 @@ static void mmc_blk_mq_rw_recovery(struc
|
2022-08-22 12:02:36 +00:00
|
|
|
return;
|
2022-05-16 21:40:32 +00:00
|
|
|
}
|
|
|
|
|
2022-08-22 12:02:36 +00:00
|
|
|
- if (rq_data_dir(req) == READ && brq->data.blocks >
|
2022-05-16 21:40:32 +00:00
|
|
|
+ /*
|
|
|
|
+ * XXX: don't do single-sector reads, as it leaks a SG DMA
|
|
|
|
+ * mapping when reusing the still-pending req.
|
|
|
|
+ */
|
2022-08-22 12:02:36 +00:00
|
|
|
+ if (0 && rq_data_dir(req) == READ && brq->data.blocks >
|
|
|
|
queue_physical_block_size(mq->queue) >> 9) {
|
|
|
|
/* Read one (native) sector at a time */
|
2022-05-16 21:40:32 +00:00
|
|
|
mmc_blk_read_single(mq, req);
|