ARM: S3C64XX: Hook up Littlemill audio card on Cragganmore
The Littlemill audio card is an adaptor card which can take any 6220-EV1 CODEC daughtercard. Provide standard support for the use of WM8994 class devices on the Littlemill card, configuring the MFD for WM8958 usage as this part is a superset of all others and the driver will use runtime detection to identify the actually fitted part given the configuration for the superset. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com> [kgene.kim@samsung.com: fix up conflict] Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
This commit is contained in:
parent
3d19f1cd25
commit
c5c32c965d
|
@ -15,10 +15,11 @@
|
||||||
|
|
||||||
#define BANFF_PMIC_IRQ_BASE IRQ_BOARD_START
|
#define BANFF_PMIC_IRQ_BASE IRQ_BOARD_START
|
||||||
#define GLENFARCLAS_PMIC_IRQ_BASE (IRQ_BOARD_START + 64)
|
#define GLENFARCLAS_PMIC_IRQ_BASE (IRQ_BOARD_START + 64)
|
||||||
|
#define CODEC_IRQ_BASE (IRQ_BOARD_START + 128)
|
||||||
|
|
||||||
#define PCA935X_GPIO_BASE GPIO_BOARD_START
|
#define PCA935X_GPIO_BASE GPIO_BOARD_START
|
||||||
#define CODEC_GPIO_BASE (GPIO_BOARD_START + 8)
|
#define CODEC_GPIO_BASE (GPIO_BOARD_START + 8)
|
||||||
#define GLENFARCLAS_PMIC_GPIO_BASE (GPIO_BOARD_START + 16)
|
#define GLENFARCLAS_PMIC_GPIO_BASE (GPIO_BOARD_START + 32)
|
||||||
#define BANFF_PMIC_GPIO_BASE (GPIO_BOARD_START + 32)
|
#define BANFF_PMIC_GPIO_BASE (GPIO_BOARD_START + 64)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -169,7 +169,7 @@
|
||||||
#define IRQ_BOARD_START (IRQ_EINT_GROUP9_BASE + IRQ_EINT_GROUP9_NR + 1)
|
#define IRQ_BOARD_START (IRQ_EINT_GROUP9_BASE + IRQ_EINT_GROUP9_NR + 1)
|
||||||
|
|
||||||
#ifdef CONFIG_MACH_WLF_CRAGG_6410
|
#ifdef CONFIG_MACH_WLF_CRAGG_6410
|
||||||
#define IRQ_BOARD_NR 128
|
#define IRQ_BOARD_NR 160
|
||||||
#elif defined(CONFIG_SMDK6410_WM1190_EV1)
|
#elif defined(CONFIG_SMDK6410_WM1190_EV1)
|
||||||
#define IRQ_BOARD_NR 64
|
#define IRQ_BOARD_NR 64
|
||||||
#elif defined(CONFIG_SMDK6410_WM1192_EV1)
|
#elif defined(CONFIG_SMDK6410_WM1192_EV1)
|
||||||
|
|
|
@ -14,6 +14,7 @@
|
||||||
|
|
||||||
#include <linux/mfd/wm831x/irq.h>
|
#include <linux/mfd/wm831x/irq.h>
|
||||||
#include <linux/mfd/wm831x/gpio.h>
|
#include <linux/mfd/wm831x/gpio.h>
|
||||||
|
#include <linux/mfd/wm8994/pdata.h>
|
||||||
|
|
||||||
#include <sound/wm5100.h>
|
#include <sound/wm5100.h>
|
||||||
#include <sound/wm8996.h>
|
#include <sound/wm8996.h>
|
||||||
|
@ -133,6 +134,24 @@ static const struct i2c_board_info wm1259_devs[] = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct wm8994_pdata wm8994_pdata = {
|
||||||
|
.gpio_base = CODEC_GPIO_BASE,
|
||||||
|
.gpio_defaults = {
|
||||||
|
0x3, /* IRQ out, active high, CMOS */
|
||||||
|
},
|
||||||
|
.irq_base = CODEC_IRQ_BASE,
|
||||||
|
.ldo = {
|
||||||
|
{ .supply = "WALLVDD" },
|
||||||
|
{ .supply = "WALLVDD" },
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static const struct i2c_board_info wm1277_devs[] = {
|
||||||
|
{ I2C_BOARD_INFO("wm8958", 0x1a), /* WM8958 is the superset */
|
||||||
|
.platform_data = &wm8994_pdata,
|
||||||
|
.irq = GLENFARCLAS_PMIC_IRQ_BASE + WM831X_IRQ_GPIO_2,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
static __devinitdata const struct {
|
static __devinitdata const struct {
|
||||||
u8 id;
|
u8 id;
|
||||||
|
@ -154,6 +173,8 @@ static __devinitdata const struct {
|
||||||
{ .id = 0x3b, .name = "1255-EV1 Kilchoman",
|
{ .id = 0x3b, .name = "1255-EV1 Kilchoman",
|
||||||
.i2c_devs = wm1255_devs, .num_i2c_devs = ARRAY_SIZE(wm1255_devs) },
|
.i2c_devs = wm1255_devs, .num_i2c_devs = ARRAY_SIZE(wm1255_devs) },
|
||||||
{ .id = 0x3c, .name = "1273-EV1 Longmorn" },
|
{ .id = 0x3c, .name = "1273-EV1 Longmorn" },
|
||||||
|
{ .id = 0x3d, .name = "1277-EV1 Littlemill",
|
||||||
|
.i2c_devs = wm1277_devs, .num_i2c_devs = ARRAY_SIZE(wm1277_devs) },
|
||||||
};
|
};
|
||||||
|
|
||||||
static __devinit int wlf_gf_module_probe(struct i2c_client *i2c,
|
static __devinit int wlf_gf_module_probe(struct i2c_client *i2c,
|
||||||
|
|
|
@ -289,6 +289,11 @@ static struct platform_device speyside_wm8962_device = {
|
||||||
.id = -1,
|
.id = -1,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct platform_device littlemill_device = {
|
||||||
|
.name = "littlemill",
|
||||||
|
.id = -1,
|
||||||
|
};
|
||||||
|
|
||||||
static struct regulator_consumer_supply wallvdd_consumers[] = {
|
static struct regulator_consumer_supply wallvdd_consumers[] = {
|
||||||
REGULATOR_SUPPLY("SPKVDD1", "1-001a"),
|
REGULATOR_SUPPLY("SPKVDD1", "1-001a"),
|
||||||
REGULATOR_SUPPLY("SPKVDD2", "1-001a"),
|
REGULATOR_SUPPLY("SPKVDD2", "1-001a"),
|
||||||
|
@ -341,6 +346,7 @@ static struct platform_device *crag6410_devices[] __initdata = {
|
||||||
&crag6410_backlight_device,
|
&crag6410_backlight_device,
|
||||||
&speyside_device,
|
&speyside_device,
|
||||||
&speyside_wm8962_device,
|
&speyside_wm8962_device,
|
||||||
|
&littlemill_device,
|
||||||
&lowland_device,
|
&lowland_device,
|
||||||
&wallvdd_device,
|
&wallvdd_device,
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue