[PATCH 6/7] serial: ifx6x60: fix modem names to ones recognized by firmware

From: Russ Gorby
Date: Wed Jan 05 2011 - 19:04:39 EST


The current strings used in ID table are not correct and prevent
protocol driver connecting to controller driver.
Also, the indication of which modem h/w is present is not
currently provided by the platform data.

Changed ifx_id_table[] to use strings recognized by platform firmware

Signed-off-by: Russ Gorby <russ.gorby@xxxxxxxxx>
---
drivers/serial/ifx6x60.c | 11 +++++++++--
1 files changed, 9 insertions(+), 2 deletions(-)

diff --git a/drivers/serial/ifx6x60.c b/drivers/serial/ifx6x60.c
index 6dfb47a..5a0321a 100644
--- a/drivers/serial/ifx6x60.c
+++ b/drivers/serial/ifx6x60.c
@@ -81,6 +81,10 @@ static int spi_bpw = 16; /* 8, 16 or 32 bit word length */
static struct tty_driver *tty_drv;
static struct ifx_spi_device *saved_ifx_dev;
static struct lock_class_key ifx_spi_key;
+enum ifx_mdm {
+ IFX_6160 = 1,
+ IFX_6260,
+};

/* GPIO/GPE settings */

@@ -984,7 +988,10 @@ static int ifx_spi_spi_probe(struct spi_device *spi)
init_timer(&ifx_dev->spi_timer);
ifx_dev->spi_timer.function = ifx_spi_timeout;
ifx_dev->spi_timer.data = (unsigned long)ifx_dev;
+ /* FIXME: platform data does not currently supply this information
ifx_dev->is_6160 = pl_data->is_6160;
+ */
+ ifx_dev->is_6160 = (spi_get_device_id(spi)->driver_data == IFX_6160);
/* initialize spi mode, etc */
if (ifx_dev->is_6160)
spi->max_speed_hz = 12500000;
@@ -1328,8 +1335,8 @@ static const struct dev_pm_ops ifx_spi_pm = {
};

static const struct spi_device_id ifx_id_table[] = {
- {"ifx6160", 0},
- {"ifx6260", 0},
+ { "spi_6160_modem", IFX_6160 },
+ { "spi_6260_modem", IFX_6260 },
{ }
};
MODULE_DEVICE_TABLE(spi, ifx_id_table);
--
1.7.2.3

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/