mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-23 15:32:33 +00:00
01d8e41c16
Changelog: https://cdn.kernel.org/pub/linux/kernel/v6.x/ChangeLog-6.6.51 Removed upstreamed: generic/backport-6.6/200-regmap-maple-work-around-false-positive-warning.patch generic/backport-6.6/822-v6.11-0012-nvmem-Fix-return-type-of-devm_nvmem_device_get-in-ke.patch bcm27xx/patches-6.6/950-1018-drivers-mmc-apply-SD-quirks-earlier-during-probe.patch Manually rebased: bcm27xx/patches-6.6/950-0993-drivers-mmc-cqhci-clear-CQHCI_CTL-if-halt-fails.patch ramips/patches-6.6/311-MIPS-use-set_mode-to-enable-disable-the-cevt-r4k-irq.patch[4] All other patches automatically rebased. 1. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.6.51&id=e42ea96d6d36a16526cb82b8aa2e5422814c3250 2. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.6.51&id=3d1baf322a3a69b38b6b2d511cfe0d611d1b5462 3. https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?h=v6.6.51&id=115a755bb38db5a1175be44e6a9a93a0a8233885 4. Adapted the changes from Hauke Mehrtens' modification in PR#16366 to 5.15.167 Build system: x86/64 Build-tested: x86/64/AMD Cezanne, flogic/xiaomi_redmi-router-ax6000-ubootmod, ramips/tplink_archer-a6-v3 Run-tested: x86/64/AMD Cezanne, flogic/xiaomi_redmi-router-ax6000-ubootmod, ramips/tplink_archer-a6-v3 Signed-off-by: John Audia <therealgraysky@proton.me> Link: https://github.com/openwrt/openwrt/pull/16370 Signed-off-by: Robert Marko <robimarko@gmail.com>
54 lines
1.8 KiB
Diff
54 lines
1.8 KiB
Diff
From b16e3d359b99c5771f9a22f74cbd193c7f14f895 Mon Sep 17 00:00:00 2001
|
|
From: Jonathan Bell <jonathan@raspberrypi.com>
|
|
Date: Tue, 26 Mar 2024 14:58:58 +0000
|
|
Subject: [PATCH 0997/1085] drivers: mmc: handle 1024-byte SD General Info
|
|
lengths
|
|
|
|
The spec allows for up to two 512-byte pages to be allocated for the
|
|
Extension Register General Info block, so allocate accordingly.
|
|
|
|
Signed-off-by: Jonathan Bell <jonathan@raspberrypi.com>
|
|
---
|
|
drivers/mmc/core/sd.c | 19 ++++++++++++++-----
|
|
1 file changed, 14 insertions(+), 5 deletions(-)
|
|
|
|
--- a/drivers/mmc/core/sd.c
|
|
+++ b/drivers/mmc/core/sd.c
|
|
@@ -1177,7 +1177,7 @@ static int mmc_sd_read_ext_regs(struct m
|
|
if (!(card->scr.cmds & SD_SCR_CMD48_SUPPORT))
|
|
return 0;
|
|
|
|
- gen_info_buf = kzalloc(512, GFP_KERNEL);
|
|
+ gen_info_buf = kzalloc(1024, GFP_KERNEL);
|
|
if (!gen_info_buf)
|
|
return -ENOMEM;
|
|
|
|
@@ -1208,14 +1208,23 @@ static int mmc_sd_read_ext_regs(struct m
|
|
num_ext = gen_info_buf[4];
|
|
|
|
/*
|
|
- * We only support revision 0 and limit it to 512 bytes for simplicity.
|
|
+ * We only support revision 0 and up to the spec-defined maximum of 1K.
|
|
* No matter what, let's return zero to allow us to continue using the
|
|
* card, even if we can't support the features from the SD function
|
|
* extensions registers.
|
|
*/
|
|
- if (rev != 0 || len > 512) {
|
|
- pr_warn("%s: non-supported SD ext reg layout\n",
|
|
- mmc_hostname(card->host));
|
|
+ if (rev != 0 || len > 1024) {
|
|
+ pr_warn("%s: non-supported SD ext reg layout rev %u length %u\n",
|
|
+ mmc_hostname(card->host), rev, len);
|
|
+ goto out;
|
|
+ }
|
|
+
|
|
+ /* If the General Information block spills into the next page, read the rest */
|
|
+ if (len > 512)
|
|
+ err = mmc_sd_read_ext_reg(card, 0, 1, 0, 512, &gen_info_buf[512]);
|
|
+ if (err) {
|
|
+ pr_err("%s: error %d reading page 1 of general info of SD ext reg\n",
|
|
+ mmc_hostname(card->host), err);
|
|
goto out;
|
|
}
|
|
|