Commit 3f8df892 authored by Russell King's avatar Russell King

pcmcia: sa1111: fix propagation of lowlevel board init return code

When testing Lubbock, it was noticed that the sa1111 pcmcia driver bound
but was not functional due to no sockets being registered.  This is
because the return code from the lowlevel board initialisation was not
being propagated out of the probe function.  Fix this.
Tested-by: default avatarRobert Jarzmik <robert.jarzmik@free.fr>
Signed-off-by: default avatarRussell King <rmk+kernel@armlinux.org.uk>
parent a466ebd2
...@@ -134,20 +134,14 @@ static struct pcmcia_low_level badge4_pcmcia_ops = { ...@@ -134,20 +134,14 @@ static struct pcmcia_low_level badge4_pcmcia_ops = {
int pcmcia_badge4_init(struct sa1111_dev *dev) int pcmcia_badge4_init(struct sa1111_dev *dev)
{ {
int ret = -ENODEV; printk(KERN_INFO
"%s: badge4_pcmvcc=%d, badge4_pcmvpp=%d, badge4_cfvcc=%d\n",
if (machine_is_badge4()) { __func__,
printk(KERN_INFO badge4_pcmvcc, badge4_pcmvpp, badge4_cfvcc);
"%s: badge4_pcmvcc=%d, badge4_pcmvpp=%d, badge4_cfvcc=%d\n",
__func__, sa11xx_drv_pcmcia_ops(&badge4_pcmcia_ops);
badge4_pcmvcc, badge4_pcmvpp, badge4_cfvcc); return sa1111_pcmcia_add(dev, &badge4_pcmcia_ops,
sa11xx_drv_pcmcia_add_one);
sa11xx_drv_pcmcia_ops(&badge4_pcmcia_ops);
ret = sa1111_pcmcia_add(dev, &badge4_pcmcia_ops,
sa11xx_drv_pcmcia_add_one);
}
return ret;
} }
static int __init pcmv_setup(char *s) static int __init pcmv_setup(char *s)
......
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
#include <mach/hardware.h> #include <mach/hardware.h>
#include <asm/hardware/sa1111.h> #include <asm/hardware/sa1111.h>
#include <asm/mach-types.h>
#include <asm/irq.h> #include <asm/irq.h>
#include "sa1111_generic.h" #include "sa1111_generic.h"
...@@ -203,19 +204,30 @@ static int pcmcia_probe(struct sa1111_dev *dev) ...@@ -203,19 +204,30 @@ static int pcmcia_probe(struct sa1111_dev *dev)
sa1111_writel(PCSSR_S0_SLEEP | PCSSR_S1_SLEEP, base + PCSSR); sa1111_writel(PCSSR_S0_SLEEP | PCSSR_S1_SLEEP, base + PCSSR);
sa1111_writel(PCCR_S0_FLT | PCCR_S1_FLT, base + PCCR); sa1111_writel(PCCR_S0_FLT | PCCR_S1_FLT, base + PCCR);
ret = -ENODEV;
#ifdef CONFIG_SA1100_BADGE4 #ifdef CONFIG_SA1100_BADGE4
pcmcia_badge4_init(dev); if (machine_is_badge4())
ret = pcmcia_badge4_init(dev);
#endif #endif
#ifdef CONFIG_SA1100_JORNADA720 #ifdef CONFIG_SA1100_JORNADA720
pcmcia_jornada720_init(dev); if (machine_is_jornada720())
ret = pcmcia_jornada720_init(dev);
#endif #endif
#ifdef CONFIG_ARCH_LUBBOCK #ifdef CONFIG_ARCH_LUBBOCK
pcmcia_lubbock_init(dev); if (machine_is_lubbock())
ret = pcmcia_lubbock_init(dev);
#endif #endif
#ifdef CONFIG_ASSABET_NEPONSET #ifdef CONFIG_ASSABET_NEPONSET
pcmcia_neponset_init(dev); if (machine_is_assabet())
ret = pcmcia_neponset_init(dev);
#endif #endif
return 0;
if (ret) {
release_mem_region(dev->res.start, 512);
sa1111_disable_device(dev);
}
return ret;
} }
static int pcmcia_remove(struct sa1111_dev *dev) static int pcmcia_remove(struct sa1111_dev *dev)
......
...@@ -94,22 +94,17 @@ static struct pcmcia_low_level jornada720_pcmcia_ops = { ...@@ -94,22 +94,17 @@ static struct pcmcia_low_level jornada720_pcmcia_ops = {
int pcmcia_jornada720_init(struct sa1111_dev *sadev) int pcmcia_jornada720_init(struct sa1111_dev *sadev)
{ {
int ret = -ENODEV; unsigned int pin = GPIO_A0 | GPIO_A1 | GPIO_A2 | GPIO_A3;
if (machine_is_jornada720()) { /* Fixme: why messing around with SA11x0's GPIO1? */
unsigned int pin = GPIO_A0 | GPIO_A1 | GPIO_A2 | GPIO_A3; GRER |= 0x00000002;
GRER |= 0x00000002; /* Set GPIO_A<3:1> to be outputs for PCMCIA/CF power controller: */
sa1111_set_io_dir(sadev, pin, 0, 0);
sa1111_set_io(sadev, pin, 0);
sa1111_set_sleep_io(sadev, pin, 0);
/* Set GPIO_A<3:1> to be outputs for PCMCIA/CF power controller: */ sa11xx_drv_pcmcia_ops(&jornada720_pcmcia_ops);
sa1111_set_io_dir(sadev, pin, 0, 0); return sa1111_pcmcia_add(sadev, &jornada720_pcmcia_ops,
sa1111_set_io(sadev, pin, 0); sa11xx_drv_pcmcia_add_one);
sa1111_set_sleep_io(sadev, pin, 0);
sa11xx_drv_pcmcia_ops(&jornada720_pcmcia_ops);
ret = sa1111_pcmcia_add(sadev, &jornada720_pcmcia_ops,
sa11xx_drv_pcmcia_add_one);
}
return ret;
} }
...@@ -210,27 +210,21 @@ static struct pcmcia_low_level lubbock_pcmcia_ops = { ...@@ -210,27 +210,21 @@ static struct pcmcia_low_level lubbock_pcmcia_ops = {
int pcmcia_lubbock_init(struct sa1111_dev *sadev) int pcmcia_lubbock_init(struct sa1111_dev *sadev)
{ {
int ret = -ENODEV; /*
* Set GPIO_A<3:0> to be outputs for the MAX1600,
if (machine_is_lubbock()) { * and switch to standby mode.
/* */
* Set GPIO_A<3:0> to be outputs for the MAX1600, sa1111_set_io_dir(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0, 0);
* and switch to standby mode. sa1111_set_io(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0);
*/ sa1111_set_sleep_io(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0);
sa1111_set_io_dir(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0, 0);
sa1111_set_io(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0);
sa1111_set_sleep_io(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0);
/* Set CF Socket 1 power to standby mode. */
lubbock_set_misc_wr((1 << 15) | (1 << 14), 0);
pxa2xx_drv_pcmcia_ops(&lubbock_pcmcia_ops); /* Set CF Socket 1 power to standby mode. */
pxa2xx_configure_sockets(&sadev->dev); lubbock_set_misc_wr((1 << 15) | (1 << 14), 0);
ret = sa1111_pcmcia_add(sadev, &lubbock_pcmcia_ops,
pxa2xx_drv_pcmcia_add_one);
}
return ret; pxa2xx_drv_pcmcia_ops(&lubbock_pcmcia_ops);
pxa2xx_configure_sockets(&sadev->dev);
return sa1111_pcmcia_add(sadev, &lubbock_pcmcia_ops,
pxa2xx_drv_pcmcia_add_one);
} }
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
...@@ -110,20 +110,14 @@ static struct pcmcia_low_level neponset_pcmcia_ops = { ...@@ -110,20 +110,14 @@ static struct pcmcia_low_level neponset_pcmcia_ops = {
int pcmcia_neponset_init(struct sa1111_dev *sadev) int pcmcia_neponset_init(struct sa1111_dev *sadev)
{ {
int ret = -ENODEV; /*
* Set GPIO_A<3:0> to be outputs for the MAX1600,
if (machine_is_assabet()) { * and switch to standby mode.
/* */
* Set GPIO_A<3:0> to be outputs for the MAX1600, sa1111_set_io_dir(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0, 0);
* and switch to standby mode. sa1111_set_io(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0);
*/ sa1111_set_sleep_io(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0);
sa1111_set_io_dir(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0, 0); sa11xx_drv_pcmcia_ops(&neponset_pcmcia_ops);
sa1111_set_io(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0); return sa1111_pcmcia_add(sadev, &neponset_pcmcia_ops,
sa1111_set_sleep_io(sadev, GPIO_A0|GPIO_A1|GPIO_A2|GPIO_A3, 0); sa11xx_drv_pcmcia_add_one);
sa11xx_drv_pcmcia_ops(&neponset_pcmcia_ops);
ret = sa1111_pcmcia_add(sadev, &neponset_pcmcia_ops,
sa11xx_drv_pcmcia_add_one);
}
return ret;
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment