Re: [PATCH] mmc: dw_mmc: rockchip: Keep controller working for card detect

From: FUKAUMI Naoki
Date: Sat Sep 14 2024 - 07:21:58 EST


hi

On 9/12/24 16:26, Kever Yang wrote:
In order to make the SD card hotplug working we need the card detect
function logic inside the controller always working. The runtime PM will
gate the clock and the power domain, which stops controller working when
no data transfer happen.

So lets skip enable runtime PM when the card needs to detected by the
controller and the card is removable.

Signed-off-by: Kever Yang <kever.yang@xxxxxxxxxxxxxx>

following RK3588(s) boards work fine without cd-gpios,

- Radxa E54C
- Radxa ROCK 5A
- Radxa ROCK 5B
- Radxa ROCK 5C

thank you very much!

Tested-by: FUKAUMI Naoki <naoki@xxxxxxxxx>

--
FUKAUMI Naoki
Radxa Computer (Shenzhen) Co., Ltd.

---

drivers/mmc/host/dw_mmc-rockchip.c | 23 +++++++++++++++++------
1 file changed, 17 insertions(+), 6 deletions(-)

diff --git a/drivers/mmc/host/dw_mmc-rockchip.c b/drivers/mmc/host/dw_mmc-rockchip.c
index b07190ba4b7a..df91205f9cd3 100644
--- a/drivers/mmc/host/dw_mmc-rockchip.c
+++ b/drivers/mmc/host/dw_mmc-rockchip.c
@@ -345,28 +345,39 @@ static int dw_mci_rockchip_probe(struct platform_device *pdev)
const struct dw_mci_drv_data *drv_data;
const struct of_device_id *match;
int ret;
+ bool use_rpm = true;
if (!pdev->dev.of_node)
return -ENODEV;
+ if (!device_property_read_bool(&pdev->dev, "non-removable") &&
+ !device_property_read_bool(&pdev->dev, "cd-gpios"))
+ use_rpm = false;
+
match = of_match_node(dw_mci_rockchip_match, pdev->dev.of_node);
drv_data = match->data;
pm_runtime_get_noresume(&pdev->dev);
pm_runtime_set_active(&pdev->dev);
- pm_runtime_enable(&pdev->dev);
- pm_runtime_set_autosuspend_delay(&pdev->dev, 50);
- pm_runtime_use_autosuspend(&pdev->dev);
+
+ if (use_rpm) {
+ pm_runtime_enable(&pdev->dev);
+ pm_runtime_set_autosuspend_delay(&pdev->dev, 50);
+ pm_runtime_use_autosuspend(&pdev->dev);
+ }
ret = dw_mci_pltfm_register(pdev, drv_data);
if (ret) {
- pm_runtime_disable(&pdev->dev);
- pm_runtime_set_suspended(&pdev->dev);
+ if (use_rpm) {
+ pm_runtime_disable(&pdev->dev);
+ pm_runtime_set_suspended(&pdev->dev);
+ }
pm_runtime_put_noidle(&pdev->dev);
return ret;
}
- pm_runtime_put_autosuspend(&pdev->dev);
+ if (use_rpm)
+ pm_runtime_put_autosuspend(&pdev->dev);
return 0;
}