[PATCH 1/3] mmc: mvsdio: Support inverted CD and WP GPIO lines
Simon Baatz
gmbnomis at gmail.com
Mon Apr 22 15:54:58 EDT 2013
The slot-gpio helper functions allow to specify whether card detect and
write protect GPIO lines are active high or active low. Since DT
allows to specify active low/high for GPIO lines as well, we can simply
initialize the flags for slot-gpio using the GPIO flags to support all
cases.
We need to adapt the dts files that use CD/WP via GPIO accordingly.
Only the dts for "MPL CEC4" is affected by this change.
Signed-off-by: Simon Baatz <gmbnomis at gmail.com>
---
arch/arm/boot/dts/kirkwood-mplcec4.dts | 2 +-
drivers/mmc/host/mvsdio.c | 14 ++++++++++++--
2 files changed, 13 insertions(+), 3 deletions(-)
diff --git a/arch/arm/boot/dts/kirkwood-mplcec4.dts b/arch/arm/boot/dts/kirkwood-mplcec4.dts
index 7588241..bf3a58c 100644
--- a/arch/arm/boot/dts/kirkwood-mplcec4.dts
+++ b/arch/arm/boot/dts/kirkwood-mplcec4.dts
@@ -136,7 +136,7 @@
pinctrl-0 = <&pmx_sdio &pmx_sdio_cd>;
pinctrl-names = "default";
status = "okay";
- cd-gpios = <&gpio1 15 0>;
+ cd-gpios = <&gpio1 15 1>;
/* No WP GPIO */
};
};
diff --git a/drivers/mmc/host/mvsdio.c b/drivers/mmc/host/mvsdio.c
index 145cdaf..d444efd 100644
--- a/drivers/mmc/host/mvsdio.c
+++ b/drivers/mmc/host/mvsdio.c
@@ -691,6 +691,7 @@ static int __init mvsd_probe(struct platform_device *pdev)
struct resource *r;
int ret, irq;
int gpio_card_detect, gpio_write_protect;
+ enum of_gpio_flags gpio_flags;
struct pinctrl *pinctrl;
r = platform_get_resource(pdev, IORESOURCE_MEM, 0);
@@ -731,8 +732,17 @@ static int __init mvsd_probe(struct platform_device *pdev)
}
host->base_clock = clk_get_rate(host->clk) / 2;
- gpio_card_detect = of_get_named_gpio(np, "cd-gpios", 0);
- gpio_write_protect = of_get_named_gpio(np, "wp-gpios", 0);
+ gpio_card_detect = of_get_named_gpio_flags(np, "cd-gpios", 0,
+ &gpio_flags);
+ if (gpio_is_valid(gpio_card_detect) &&
+ !(gpio_flags & OF_GPIO_ACTIVE_LOW))
+ mmc->caps2 |= MMC_CAP2_CD_ACTIVE_HIGH;
+
+ gpio_write_protect = of_get_named_gpio_flags(np, "wp-gpios", 0,
+ &gpio_flags);
+ if (gpio_is_valid(gpio_write_protect) &&
+ !(gpio_flags & OF_GPIO_ACTIVE_LOW))
+ mmc->caps2 |= MMC_CAP2_RO_ACTIVE_HIGH;
} else {
const struct mvsdio_platform_data *mvsd_data;
mvsd_data = pdev->dev.platform_data;
--
1.7.9.5
More information about the linux-arm-kernel
mailing list