From: alberto@amarulasolutions.com (Alberto Panizzo)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 2/4] mach-mx31_3ds: Add support for the MMC slot of the personality board
Date: Mon, 07 Mar 2011 10:06:31 +0100 [thread overview]
Message-ID: <1299488791.2468.17.camel@realization> (raw)
In-Reply-To: <20110307082721.GK29521@pengutronix.de>
On Mon, 2011-03-07 at 09:27 +0100, Sascha Hauer wrote:
> On Sun, Mar 06, 2011 at 04:40:01PM +0100, Alberto Panizzo wrote:
> >
> >
> > Signed-off-by: Alberto Panizzo <alberto@amarulasolutions.com>
> > ---
> > arch/arm/mach-mx3/mach-mx31_3ds.c | 116 ++++++++++++++++++++++++++++++++++++-
> > 1 files changed, 114 insertions(+), 2 deletions(-)
> >
> > diff --git a/arch/arm/mach-mx3/mach-mx31_3ds.c b/arch/arm/mach-mx3/mach-mx31_3ds.c
> > index f1dbb9d..cd73513 100644
> > --- a/arch/arm/mach-mx3/mach-mx31_3ds.c
> > +++ b/arch/arm/mach-mx3/mach-mx31_3ds.c
> > @@ -35,6 +35,7 @@
> > #include <mach/iomux-mx3.h>
> > #include <mach/3ds_debugboard.h>
> > #include <mach/ulpi.h>
> > +#include <mach/mmc.h>
> >
> > #include "devices-imx31.h"
> > #include "devices.h"
> > @@ -99,6 +100,98 @@ static int mx31_3ds_pins[] = {
> > /* I2C1 */
> > MX31_PIN_I2C_CLK__I2C1_SCL,
> > MX31_PIN_I2C_DAT__I2C1_SDA,
> > + /* SDHC1 */
> > + MX31_PIN_SD1_DATA3__SD1_DATA3,
> > + MX31_PIN_SD1_DATA2__SD1_DATA2,
> > + MX31_PIN_SD1_DATA1__SD1_DATA1,
> > + MX31_PIN_SD1_DATA0__SD1_DATA0,
> > + MX31_PIN_SD1_CLK__SD1_CLK,
> > + MX31_PIN_SD1_CMD__SD1_CMD,
> > + MX31_PIN_GPIO3_1__GPIO3_1, /* Card detect */
> > + MX31_PIN_GPIO3_0__GPIO3_0, /* OE */
> > +};
> > +
> > +/*
> > + * Support for SD card slot in personality board
> > + */
> > +static int mx31_3ds_sdhc1_init(struct device *dev, irq_handler_t detect_irq,
> > + void *data)
> > +{
> > + int ret;
> > + int gpio_det, gpio_bus_en;
> > +
> > + gpio_det = IOMUX_TO_GPIO(MX31_PIN_GPIO3_1);
> > + gpio_bus_en = IOMUX_TO_GPIO(MX31_PIN_GPIO3_0);
> > +
> > + ret = gpio_request(gpio_det, "sdhc1-card-detect");
> > + if (ret) {
> > + pr_warning("Unable to request the SD/MMC card-detect GPIO.\n");
> > + return ret;
> > + }
> > +
> > + ret = gpio_request(gpio_bus_en, "sdhc1-bus-enable");
> > + if (ret) {
> > + pr_warning("Unable to request the SD/MMC bus enable GPIO.\n");
> > + goto gpio_free_be;
> > + }
> > +
> > + ret = gpio_direction_input(gpio_det);
> > + if (ret) {
> > + pr_warning("Unable to manage the SD/MMC card-detect GPIO.\n");
> > + goto gpio_free_all;
> > + }
> > +
> > + ret = gpio_direction_output(gpio_bus_en, 0);
> > + if (ret) {
> > + pr_warning("Unable to manage the SD/MMC bus enable GPIO.\n");
> > + goto gpio_free_all;
> > + }
>
> Wolfram just arrived, so I probably have some moments left before he
> says it: You should use gpio_request_array here.
Ok I'll check the API.
>
> > +
> > + ret = request_irq(IOMUX_TO_IRQ(MX31_PIN_GPIO3_1),
> > + detect_irq, IRQF_DISABLED |
> > + IRQF_TRIGGER_FALLING | IRQF_TRIGGER_RISING,
> > + "sdhc1-detect", data);
> > + if (ret) {
> > + pr_warning("Unable to request the SD/MMC card-detect IRQ.\n");
> > + goto gpio_free_all;
> > + }
> > +
> > + return 0;
> > +
> > +gpio_free_all:
> > + gpio_free(gpio_bus_en);
> > +gpio_free_be:
> > + gpio_free(gpio_det);
> > + return ret;
> > +}
> > +
> > +static void mx31_3ds_sdhc1_exit(struct device *dev, void *data)
> > +{
> > + free_irq(IOMUX_TO_IRQ(MX31_PIN_GPIO3_1), data);
> > + gpio_free(IOMUX_TO_GPIO(MX31_PIN_GPIO3_1));
> > + gpio_free(IOMUX_TO_GPIO(MX31_PIN_GPIO3_0));
> > +}
> > +
> > +static void mx31_3ds_sdhc1_setpower(struct device *dev, unsigned int vdd)
> > +{
> > + /*
> > + * While the voltage stuff is done by the driver, activate the
> > + * Buffer Enable Pin only if there is a card in slot to fix the card
> > + * voltage issue caused by bi-directional chip TXB0108 on 3Stack.
> > + * Done here because at this stage we have for sure a debounced value
> > + * of the presence of the card, showed by the value of vdd.
> > + * 7 == ilog2(MMC_VDD_165_195)
> > + */
> > + if (vdd > 7)
> > + gpio_set_value(IOMUX_TO_GPIO(MX31_PIN_GPIO3_0), 1);
> > + else
> > + gpio_set_value(IOMUX_TO_GPIO(MX31_PIN_GPIO3_0), 0);
> > +}
> > +
> > +static struct imxmmc_platform_data sdhc1_pdata = {
> > + .init = mx31_3ds_sdhc1_init,
> > + .exit = mx31_3ds_sdhc1_exit,
> > + .setpower = mx31_3ds_sdhc1_setpower,
> > };
> >
> > /*
> > @@ -132,11 +225,26 @@ static struct regulator_init_data pwgtx_init = {
> >
> > static struct regulator_init_data gpo_init = {
> > .constraints = {
> > - .boot_on = 1,
> > - .always_on = 1,
> > + .boot_on = 1,
> > + .always_on = 1,
> > }
> > };
>
>
> Please just keep it as it is. Some people like the initializers
> vertically aligned, others prefer spaces here. But if someone made
> a decision, don't change it to increase the chance that git blame
> shows something useful.
OK but indeed I've done it for consistency with all the rest of the
file.
A new version soon.
Alberto!
--
| Alberto Panizzo Amarula Solutions BV |
| CTO - Founder Cruquiuskade 47 |
| T. +31(0)851119171 Amsterdam 1018 AM NL |
| F. +31(0)204106211 www.amarulasolutions.com |
next prev parent reply other threads:[~2011-03-07 9:06 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-03-06 15:37 [PATCH 0/4] Continue the mx31_3ds machine support Alberto Panizzo
2011-03-06 15:39 ` [PATCH 1/4] spi_imx: Fix misspelled configuration variable SOC_IMX31 Alberto Panizzo
2011-03-08 19:44 ` Uwe Kleine-König
2011-03-06 15:40 ` [PATCH 2/4] mach-mx31_3ds: Add support for the MMC slot of the personality board Alberto Panizzo
2011-03-07 8:27 ` Sascha Hauer
2011-03-07 9:06 ` Alberto Panizzo [this message]
2011-03-06 15:40 ` [PATCH 3/4] mach-mx31_3ds: Add support for framebuffer and LCD Alberto Panizzo
2011-03-06 15:41 ` [PATCH 4/4] mx31_3ds: Add support for the camera device on the personality board Alberto Panizzo
2011-03-08 19:59 ` Uwe Kleine-König
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1299488791.2468.17.camel@realization \
--to=alberto@amarulasolutions.com \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.