123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274 |
- /* Speyside modules for Cragganmore - board data probing
- *
- * Copyright 2011 Wolfson Microelectronics plc
- * Mark Brown <broonie@opensource.wolfsonmicro.com>
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
- #include <linux/export.h>
- #include <linux/interrupt.h>
- #include <linux/i2c.h>
- #include <linux/spi/spi.h>
- #include <linux/mfd/wm831x/irq.h>
- #include <linux/mfd/wm831x/gpio.h>
- #include <linux/mfd/wm8994/pdata.h>
- #include <linux/mfd/arizona/pdata.h>
- #include <linux/regulator/machine.h>
- #include <sound/wm0010.h>
- #include <sound/wm2200.h>
- #include <sound/wm5100.h>
- #include <sound/wm8996.h>
- #include <sound/wm8962.h>
- #include <sound/wm9081.h>
- #include <linux/platform_data/spi-s3c64xx.h>
- #include <mach/crag6410.h>
- static struct s3c64xx_spi_csinfo wm0010_spi_csinfo = {
- .line = S3C64XX_GPC(3),
- };
- static struct wm0010_pdata wm0010_pdata = {
- .gpio_reset = S3C64XX_GPN(6),
- .reset_active_high = 1, /* Active high for Glenfarclas Rev 2 */
- };
- static struct spi_board_info wm1253_devs[] = {
- [0] = {
- .modalias = "wm0010",
- .max_speed_hz = 26 * 1000 * 1000,
- .bus_num = 0,
- .chip_select = 0,
- .mode = SPI_MODE_0,
- .irq = S3C_EINT(4),
- .controller_data = &wm0010_spi_csinfo,
- .platform_data = &wm0010_pdata,
- },
- };
- static struct spi_board_info balblair_devs[] = {
- [0] = {
- .modalias = "wm0010",
- .max_speed_hz = 26 * 1000 * 1000,
- .bus_num = 0,
- .chip_select = 0,
- .mode = SPI_MODE_0,
- .irq = S3C_EINT(4),
- .controller_data = &wm0010_spi_csinfo,
- .platform_data = &wm0010_pdata,
- },
- };
- static struct wm5100_pdata wm5100_pdata = {
- .ldo_ena = S3C64XX_GPN(7),
- .irq_flags = IRQF_TRIGGER_HIGH,
- .gpio_base = CODEC_GPIO_BASE,
- .in_mode = {
- WM5100_IN_DIFF,
- WM5100_IN_DIFF,
- WM5100_IN_DIFF,
- WM5100_IN_SE,
- },
- .hp_pol = CODEC_GPIO_BASE + 3,
- .jack_modes = {
- { WM5100_MICDET_MICBIAS3, 0, 0 },
- { WM5100_MICDET_MICBIAS2, 1, 1 },
- },
- .gpio_defaults = {
- 0,
- 0,
- 0,
- 0,
- 0x2, /* IRQ: CMOS output */
- 0x3, /* CLKOUT: CMOS output */
- },
- };
- static struct wm8996_retune_mobile_config wm8996_retune[] = {
- {
- .name = "Sub LPF",
- .rate = 48000,
- .regs = {
- 0x6318, 0x6300, 0x1000, 0x0000, 0x0004, 0x2000, 0xF000,
- 0x0000, 0x0004, 0x2000, 0xF000, 0x0000, 0x0004, 0x2000,
- 0xF000, 0x0000, 0x0004, 0x1000, 0x0800, 0x4000
- },
- },
- {
- .name = "Sub HPF",
- .rate = 48000,
- .regs = {
- 0x000A, 0x6300, 0x1000, 0x0000, 0x0004, 0x2000, 0xF000,
- 0x0000, 0x0004, 0x2000, 0xF000, 0x0000, 0x0004, 0x2000,
- 0xF000, 0x0000, 0x0004, 0x1000, 0x0800, 0x4000
- },
- },
- };
- static struct wm8996_pdata wm8996_pdata __initdata = {
- .ldo_ena = S3C64XX_GPN(7),
- .gpio_base = CODEC_GPIO_BASE,
- .micdet_def = 1,
- .inl_mode = WM8996_DIFFERRENTIAL_1,
- .inr_mode = WM8996_DIFFERRENTIAL_1,
- .irq_flags = IRQF_TRIGGER_RISING,
- .gpio_default = {
- 0x8001, /* GPIO1 == ADCLRCLK1 */
- 0x8001, /* GPIO2 == ADCLRCLK2, input due to CPU */
- 0x0141, /* GPIO3 == HP_SEL */
- 0x0002, /* GPIO4 == IRQ */
- 0x020e, /* GPIO5 == CLKOUT */
- },
- .retune_mobile_cfgs = wm8996_retune,
- .num_retune_mobile_cfgs = ARRAY_SIZE(wm8996_retune),
- };
- static struct wm8962_pdata wm8962_pdata __initdata = {
- .gpio_init = {
- 0,
- WM8962_GPIO_FN_OPCLK,
- WM8962_GPIO_FN_DMICCLK,
- 0,
- 0x8000 | WM8962_GPIO_FN_DMICDAT,
- WM8962_GPIO_FN_IRQ, /* Open drain mode */
- },
- .in4_dc_measure = true,
- };
- static struct wm9081_pdata wm9081_pdata __initdata = {
- .irq_high = false,
- .irq_cmos = false,
- };
- static const struct i2c_board_info wm1254_devs[] = {
- { I2C_BOARD_INFO("wm8996", 0x1a),
- .platform_data = &wm8996_pdata,
- .irq = GLENFARCLAS_PMIC_IRQ_BASE + WM831X_IRQ_GPIO_2,
- },
- { I2C_BOARD_INFO("wm9081", 0x6c),
- .platform_data = &wm9081_pdata, },
- };
- static const struct i2c_board_info wm1255_devs[] = {
- { I2C_BOARD_INFO("wm5100", 0x1a),
- .platform_data = &wm5100_pdata,
- .irq = GLENFARCLAS_PMIC_IRQ_BASE + WM831X_IRQ_GPIO_2,
- },
- { I2C_BOARD_INFO("wm9081", 0x6c),
- .platform_data = &wm9081_pdata, },
- };
- static const struct i2c_board_info wm1259_devs[] = {
- { I2C_BOARD_INFO("wm8962", 0x1a),
- .platform_data = &wm8962_pdata,
- .irq = GLENFARCLAS_PMIC_IRQ_BASE + WM831X_IRQ_GPIO_2,
- },
- };
- static struct regulator_init_data wm8994_ldo1 = {
- .supply_regulator = "WALLVDD",
- };
- static struct regulator_init_data wm8994_ldo2 = {
- .supply_regulator = "WALLVDD",
- };
- static struct wm8994_pdata wm8994_pdata = {
- .gpio_base = CODEC_GPIO_BASE,
- .micb2_delay = 150,
- .gpio_defaults = {
- 0x3, /* IRQ out, active high, CMOS */
- },
- .ldo = {
- { .enable = S3C64XX_GPN(6), .init_data = &wm8994_ldo1, },
- { .enable = S3C64XX_GPN(4), .init_data = &wm8994_ldo2, },
- },
- };
- 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 struct arizona_pdata wm5102_reva_pdata = {
- .ldoena = S3C64XX_GPN(7),
- .gpio_base = CODEC_GPIO_BASE,
- .irq_active_high = true,
- .micd_pol_gpio = CODEC_GPIO_BASE + 4,
- .gpio_defaults = {
- [2] = 0x10000, /* AIF3TXLRCLK */
- [3] = 0x4, /* OPCLK */
- },
- };
- static struct s3c64xx_spi_csinfo codec_spi_csinfo = {
- .line = S3C64XX_GPN(5),
- };
- static struct spi_board_info wm5102_reva_spi_devs[] = {
- [0] = {
- .modalias = "wm5102",
- .max_speed_hz = 10 * 1000 * 1000,
- .bus_num = 0,
- .chip_select = 1,
- .mode = SPI_MODE_0,
- .irq = GLENFARCLAS_PMIC_IRQ_BASE +
- WM831X_IRQ_GPIO_2,
- .controller_data = &codec_spi_csinfo,
- .platform_data = &wm5102_reva_pdata,
- },
- };
- static struct arizona_pdata wm5102_pdata = {
- .ldoena = S3C64XX_GPN(7),
- .gpio_base = CODEC_GPIO_BASE,
- .irq_active_high = true,
- .micd_pol_gpio = CODEC_GPIO_BASE + 2,
- .gpio_defaults = {
- [2] = 0x10000, /* AIF3TXLRCLK */
- [3] = 0x4, /* OPCLK */
- },
- };
- static struct spi_board_info wm5102_spi_devs[] = {
- [0] = {
- .modalias = "wm5102",
- .max_speed_hz = 10 * 1000 * 1000,
- .bus_num = 0,
- .chip_select = 1,
- .mode = SPI_MODE_0,
- .irq = GLENFARCLAS_PMIC_IRQ_BASE +
- WM831X_IRQ_GPIO_2,
- .controller_data = &codec_spi_csinfo,
- .platform_data = &wm5102_pdata,
- },
- };
- static struct spi_board_info wm5110_spi_devs[] = {
- [0] = {
- .modalias = "wm5110",
- .max_speed_hz = 10 * 1000 * 1000,
- .bus_num = 0,
- .chip_select = 1,
- .mode = SPI_MODE_0,
- .irq = GLENFARCLAS_PMIC_IRQ_BASE +
- WM831X_IRQ_GPIO_2,
- .controller_data = &codec_spi_csinfo,
- .platform_data = &wm5102_reva_pdata,
- },
- };
|