mfd: arizona: Use correct type ID for device tree config
authorRichard Fitzgerald <rf@opensource.wolfsonmicro.com>
Fri, 2 Oct 2015 12:29:15 +0000 (13:29 +0100)
committerLee Jones <lee.jones@linaro.org>
Fri, 30 Oct 2015 17:20:30 +0000 (17:20 +0000)
In the case of a device tree config the code uses the device ID
from the DT entry to check which codec is required but when storing
the ID into struct arizona it was always using the non-DT SPI device
table to get an ID.

This patch changes the code to store the correct ID into struct arizona.

Signed-off-by: Richard Fitzgerald <rf@opensource.wolfsonmicro.com>
Acked-by: Lee Jones <lee.jones@linaro.org>
Signed-off-by: Charles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
drivers/mfd/arizona-i2c.c
drivers/mfd/arizona-spi.c

index 914bdce58bdf49e1b87ea30ecd0bbbeec5d92e34..4e3afd1861fc4b16e998089c87db95e8085d13a8 100644 (file)
@@ -56,8 +56,7 @@ static int arizona_i2c_probe(struct i2c_client *i2c,
                        regmap_config = &wm8998_i2c_regmap;
                break;
        default:
-               dev_err(&i2c->dev, "Unknown device type %ld\n",
-                       id->driver_data);
+               dev_err(&i2c->dev, "Unknown device type %ld\n", type);
                return -EINVAL;
        }
 
@@ -79,7 +78,7 @@ static int arizona_i2c_probe(struct i2c_client *i2c,
                return ret;
        }
 
-       arizona->type = id->driver_data;
+       arizona->type = type;
        arizona->dev = &i2c->dev;
        arizona->irq = i2c->irq;
 
index 850a63a3235e117bc1b346bbd262fa813af6246b..8cffb1cfe73d112052859a30c47ad413508c878a 100644 (file)
@@ -47,8 +47,7 @@ static int arizona_spi_probe(struct spi_device *spi)
                        regmap_config = &wm5110_spi_regmap;
                break;
        default:
-               dev_err(&spi->dev, "Unknown device type %ld\n",
-                       id->driver_data);
+               dev_err(&spi->dev, "Unknown device type %ld\n", type);
                return -EINVAL;
        }
 
@@ -70,7 +69,7 @@ static int arizona_spi_probe(struct spi_device *spi)
                return ret;
        }
 
-       arizona->type = id->driver_data;
+       arizona->type = type;
        arizona->dev = &spi->dev;
        arizona->irq = spi->irq;