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: Robert Jarzmik <robert.jarzmik@free.fr> Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
This commit is contained in:
parent
a466ebd2fc
commit
3f8df892b2
|
@ -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",
|
||||||
|
__func__,
|
||||||
|
badge4_pcmvcc, badge4_pcmvpp, badge4_cfvcc);
|
||||||
|
|
||||||
if (machine_is_badge4()) {
|
sa11xx_drv_pcmcia_ops(&badge4_pcmcia_ops);
|
||||||
printk(KERN_INFO
|
return sa1111_pcmcia_add(dev, &badge4_pcmcia_ops,
|
||||||
"%s: badge4_pcmvcc=%d, badge4_pcmvpp=%d, badge4_cfvcc=%d\n",
|
sa11xx_drv_pcmcia_add_one);
|
||||||
__func__,
|
|
||||||
badge4_pcmvcc, badge4_pcmvpp, badge4_cfvcc);
|
|
||||||
|
|
||||||
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 @@
|
||||||
|
|
||||||
#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)
|
||||||
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 = {
|
||||||
|
|
||||||
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 = {
|
||||||
|
|
||||||
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,
|
||||||
|
* and switch to standby mode.
|
||||||
|
*/
|
||||||
|
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);
|
||||||
|
|
||||||
if (machine_is_lubbock()) {
|
/* Set CF Socket 1 power to standby mode. */
|
||||||
/*
|
lubbock_set_misc_wr((1 << 15) | (1 << 14), 0);
|
||||||
* Set GPIO_A<3:0> to be outputs for the MAX1600,
|
|
||||||
* and switch to standby mode.
|
|
||||||
*/
|
|
||||||
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. */
|
pxa2xx_drv_pcmcia_ops(&lubbock_pcmcia_ops);
|
||||||
lubbock_set_misc_wr((1 << 15) | (1 << 14), 0);
|
pxa2xx_configure_sockets(&sadev->dev);
|
||||||
|
return sa1111_pcmcia_add(sadev, &lubbock_pcmcia_ops,
|
||||||
pxa2xx_drv_pcmcia_ops(&lubbock_pcmcia_ops);
|
pxa2xx_drv_pcmcia_add_one);
|
||||||
pxa2xx_configure_sockets(&sadev->dev);
|
|
||||||
ret = sa1111_pcmcia_add(sadev, &lubbock_pcmcia_ops,
|
|
||||||
pxa2xx_drv_pcmcia_add_one);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue