mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-10 15:03:07 +00:00
b55efebb1f
Deleted (upstreamed): generic/backport-5.15/702-v5.19-32-net-ethernet-mtk_eth_soc-out-of-bounds-read-in-mtk_h.patch [01] [01] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v5.15.47&id=b24ca1cf846273361d5bd73a35de95a486a54b6d Signed-off-by: Rui Salvaterra <rsalvaterra@gmail.com> [Removed 702-v5.19-32-net-ethernet-mtk_eth_soc-out-of-bounds-read-in-mtk_h.patch] Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
39 lines
1.4 KiB
Diff
39 lines
1.4 KiB
Diff
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
|
|
@@ -1870,7 +1870,11 @@ static void mmc_blk_mq_rw_recovery(struc
|
|
}
|
|
|
|
/* FIXME: Missing single sector read for large sector size */
|
|
- if (!mmc_large_sector(card) && rq_data_dir(req) == READ &&
|
|
+ /*
|
|
+ * XXX: don't do single-sector reads, as it leaks a SG DMA
|
|
+ * mapping when reusing the still-pending req.
|
|
+ */
|
|
+ if (0 && !mmc_large_sector(card) && rq_data_dir(req) == READ &&
|
|
brq->data.blocks > 1) {
|
|
/* Read one sector at a time */
|
|
mmc_blk_read_single(mq, req);
|