mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-11-01 17:08:10 +00:00
3aa78e0cb5
But we also have: - Support for the TPS659038 PMIC from the palmas driver. - Intel's Coleto Creek and Avoton SoCs support from the lpc_ich driver. - RTL8411B support from the rtsx driver. - More DT support for the Arizona, max8998, twl4030-power and the ti_am335x_tsadc drivers. - The SSBI driver move under MFD. - A conversion to the devm_* API for most of the MFD drivers. - The twl4030-power got split from twl-core into its own module. - A major ti_am335x_adc cleanup, leading to a proper DT support. - Our regular arizona and wm* updates and cleanups from the Wolfson folks. - A better error handling and initialization, and a regulator subdevice addition for the 88pm80x driver. - A bulk platform_set_drvdata() call removal that's no longer need since commit0998d063
. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.12 (GNU/Linux) iQIcBAABAgAGBQJR2zCaAAoJEIqAPN1PVmxK29EP/ieZf7Z7z7bg/0lEOvtOzACy WoCdSGFu5XcHOnlv0Fl1Rr/1AJFQoh4KugkGnVyrlztYVOFymj5VDdd8B43cxMLt 7ymK/3crIH7uJuOoeDoDr3glLuo0TGB9f5Kv4ITdVD3/+AuqY4VIAisEDb0aWghW +v0I3fYeGdwRv+IqO5wacvddSoLa4rmOhnpbVMB2O1Y/LCm/yHI6tAFx1+AfH7y8 zMHbGFc+gHg1xupJBCnRel0v8J+KNc02G/B1zNom/avL8b/mNXNI8JFxs3bMA0r8 NpTHJ49OVPbhBQTA4U+BPoG4nzOiAOj0czf9dkGa5cyR8t4C9mmK+s8QHwepzrSG qbhCgTqp4bomB1m0RAO+z4F6BHTpmoChpho2btrwN9ZmhMHQeTWnGjjhEwZngpBq F22DC6k5ipV0k4962ZHfZ76v2Vot1gfd6zQ5r+2oHMMfWaKgS4L5efP2/wsU9H58 BxMm84C7OWbgcTRmNn9jl4L9phBD31wvNANfUeMhLMyshnwPK5ZuUdX/+K2rq6h9 w26Hg62HtKZFv/TEsCBQqpB6zSZa4u/KZzvwEahllQSQGKxIHaNYGtLGzJj9sCM+ baT/82DFKuEvKfJpUKSBMznImp4WNGEz+8s2w4m/Ssuf30GN2GHjM9Q4gcHJu2mk 7fTrsSHWYN+EHVzh1Zb8 =RqMp -----END PGP SIGNATURE----- Merge tag 'mfd-3.11-1' of git://git.kernel.org/pub/scm/linux/kernel/git/sameo/mfd-next Pull MFD update from Samuel Ortiz: "For the 3.11 merge we only have one new MFD driver for the Kontron PLD. But we also have: - Support for the TPS659038 PMIC from the palmas driver. - Intel's Coleto Creek and Avoton SoCs support from the lpc_ich driver. - RTL8411B support from the rtsx driver. - More DT support for the Arizona, max8998, twl4030-power and the ti_am335x_tsadc drivers. - The SSBI driver move under MFD. - A conversion to the devm_* API for most of the MFD drivers. - The twl4030-power got split from twl-core into its own module. - A major ti_am335x_adc cleanup, leading to a proper DT support. - Our regular arizona and wm* updates and cleanups from the Wolfson folks. - A better error handling and initialization, and a regulator subdevice addition for the 88pm80x driver. - A bulk platform_set_drvdata() call removal that's no longer need since commit0998d06310
("device-core: Ensure drvdata = NULL when no driver is bound") * tag 'mfd-3.11-1' of git://git.kernel.org/pub/scm/linux/kernel/git/sameo/mfd-next: (102 commits) mfd: sec: Provide max_register to regmap mfd: wm8994: Remove duplicate check for active JACKDET MAINTAINERS: Add include directory to MFD file patterns mfd: sec: Remove fields not used since regmap conversion watchdog: Kontron PLD watchdog timer driver mfd: max8998: Add support for Device Tree regulator: max8998: Use arrays for specifying voltages in platform data mfd: max8998: Add irq domain support regulator: palmas: Add TPS659038 support mfd: Kontron PLD mfd driver mfd: palmas: Add TPS659038 PMIC support mfd: palmas: Add SMPS10_BOOST feature mfd: palmas: Check if irq is valid mfd: lpc_ich: iTCO_wdt patch for Intel Coleto Creek DeviceIDs mfd: twl-core: Change TWL6025 references to TWL6032 mfd: davinci_voicecodec: Fix build breakage mfd: vexpress: Make the driver optional for arm and arm64 mfd: htc-egpio: Use devm_ioremap_nocache() instead of ioremap_nocache() mfd: davinci_voicecodec: Convert to use devm_* APIs mfd: twl4030-power: Fix relocking on error ...
238 lines
6.4 KiB
C
238 lines
6.4 KiB
C
/*
|
|
* include/linux/mfd/wm8994/pdata.h -- Platform data for WM8994
|
|
*
|
|
* Copyright 2009 Wolfson Microelectronics PLC.
|
|
*
|
|
* Author: 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 as published by the
|
|
* Free Software Foundation; either version 2 of the License, or (at your
|
|
* option) any later version.
|
|
*
|
|
*/
|
|
|
|
#ifndef __MFD_WM8994_PDATA_H__
|
|
#define __MFD_WM8994_PDATA_H__
|
|
|
|
#define WM8994_NUM_LDO 2
|
|
#define WM8994_NUM_GPIO 11
|
|
#define WM8994_NUM_AIF 3
|
|
|
|
struct wm8994_ldo_pdata {
|
|
/** GPIOs to enable regulator, 0 or less if not available */
|
|
int enable;
|
|
|
|
const struct regulator_init_data *init_data;
|
|
};
|
|
|
|
#define WM8994_CONFIGURE_GPIO 0x10000
|
|
|
|
#define WM8994_DRC_REGS 5
|
|
#define WM8994_EQ_REGS 20
|
|
#define WM8958_MBC_CUTOFF_REGS 20
|
|
#define WM8958_MBC_COEFF_REGS 48
|
|
#define WM8958_MBC_COMBINED_REGS 56
|
|
#define WM8958_VSS_HPF_REGS 2
|
|
#define WM8958_VSS_REGS 148
|
|
#define WM8958_ENH_EQ_REGS 32
|
|
|
|
/**
|
|
* DRC configurations are specified with a label and a set of register
|
|
* values to write (the enable bits will be ignored). At runtime an
|
|
* enumerated control will be presented for each DRC block allowing
|
|
* the user to choose the configration to use.
|
|
*
|
|
* Configurations may be generated by hand or by using the DRC control
|
|
* panel provided by the WISCE - see http://www.wolfsonmicro.com/wisce/
|
|
* for details.
|
|
*/
|
|
struct wm8994_drc_cfg {
|
|
const char *name;
|
|
u16 regs[WM8994_DRC_REGS];
|
|
};
|
|
|
|
/**
|
|
* ReTune Mobile configurations are specified with a label, sample
|
|
* rate and set of values to write (the enable bits will be ignored).
|
|
*
|
|
* Configurations are expected to be generated using the ReTune Mobile
|
|
* control panel in WISCE - see http://www.wolfsonmicro.com/wisce/
|
|
*/
|
|
struct wm8994_retune_mobile_cfg {
|
|
const char *name;
|
|
unsigned int rate;
|
|
u16 regs[WM8994_EQ_REGS];
|
|
};
|
|
|
|
/**
|
|
* Multiband compressor configurations are specified with a label and
|
|
* two sets of values to write. Configurations are expected to be
|
|
* generated using the multiband compressor configuration panel in
|
|
* WISCE - see http://www.wolfsonmicro.com/wisce/
|
|
*/
|
|
struct wm8958_mbc_cfg {
|
|
const char *name;
|
|
u16 cutoff_regs[WM8958_MBC_CUTOFF_REGS];
|
|
u16 coeff_regs[WM8958_MBC_COEFF_REGS];
|
|
|
|
/* Coefficient layout when using MBC+VSS firmware */
|
|
u16 combined_regs[WM8958_MBC_COMBINED_REGS];
|
|
};
|
|
|
|
/**
|
|
* VSS HPF configurations are specified with a label and two values to
|
|
* write. Configurations are expected to be generated using the
|
|
* multiband compressor configuration panel in WISCE - see
|
|
* http://www.wolfsonmicro.com/wisce/
|
|
*/
|
|
struct wm8958_vss_hpf_cfg {
|
|
const char *name;
|
|
u16 regs[WM8958_VSS_HPF_REGS];
|
|
};
|
|
|
|
/**
|
|
* VSS configurations are specified with a label and array of values
|
|
* to write. Configurations are expected to be generated using the
|
|
* multiband compressor configuration panel in WISCE - see
|
|
* http://www.wolfsonmicro.com/wisce/
|
|
*/
|
|
struct wm8958_vss_cfg {
|
|
const char *name;
|
|
u16 regs[WM8958_VSS_REGS];
|
|
};
|
|
|
|
/**
|
|
* Enhanced EQ configurations are specified with a label and array of
|
|
* values to write. Configurations are expected to be generated using
|
|
* the multiband compressor configuration panel in WISCE - see
|
|
* http://www.wolfsonmicro.com/wisce/
|
|
*/
|
|
struct wm8958_enh_eq_cfg {
|
|
const char *name;
|
|
u16 regs[WM8958_ENH_EQ_REGS];
|
|
};
|
|
|
|
/**
|
|
* Microphone detection rates, used to tune response rates and power
|
|
* consumption for WM8958/WM1811 microphone detection.
|
|
*
|
|
* @sysclk: System clock rate to use this configuration for.
|
|
* @idle: True if this configuration should use when no accessory is detected,
|
|
* false otherwise.
|
|
* @start: Value for MICD_BIAS_START_TIME register field (not shifted).
|
|
* @rate: Value for MICD_RATE register field (not shifted).
|
|
*/
|
|
struct wm8958_micd_rate {
|
|
int sysclk;
|
|
bool idle;
|
|
int start;
|
|
int rate;
|
|
};
|
|
|
|
struct wm8994_pdata {
|
|
int gpio_base;
|
|
|
|
/**
|
|
* Default values for GPIOs if non-zero, WM8994_CONFIGURE_GPIO
|
|
* can be used for all zero values.
|
|
*/
|
|
int gpio_defaults[WM8994_NUM_GPIO];
|
|
|
|
struct wm8994_ldo_pdata ldo[WM8994_NUM_LDO];
|
|
|
|
int irq_base; /** Base IRQ number for WM8994, required for IRQs */
|
|
unsigned long irq_flags; /** user irq flags */
|
|
|
|
int num_drc_cfgs;
|
|
struct wm8994_drc_cfg *drc_cfgs;
|
|
|
|
int num_retune_mobile_cfgs;
|
|
struct wm8994_retune_mobile_cfg *retune_mobile_cfgs;
|
|
|
|
int num_mbc_cfgs;
|
|
struct wm8958_mbc_cfg *mbc_cfgs;
|
|
|
|
int num_vss_cfgs;
|
|
struct wm8958_vss_cfg *vss_cfgs;
|
|
|
|
int num_vss_hpf_cfgs;
|
|
struct wm8958_vss_hpf_cfg *vss_hpf_cfgs;
|
|
|
|
int num_enh_eq_cfgs;
|
|
struct wm8958_enh_eq_cfg *enh_eq_cfgs;
|
|
|
|
int num_micd_rates;
|
|
struct wm8958_micd_rate *micd_rates;
|
|
|
|
/* Power up delays to add after microphone bias power up (ms) */
|
|
int micb1_delay;
|
|
int micb2_delay;
|
|
|
|
/* LINEOUT can be differential or single ended */
|
|
unsigned int lineout1_diff:1;
|
|
unsigned int lineout2_diff:1;
|
|
|
|
/* Common mode feedback */
|
|
unsigned int lineout1fb:1;
|
|
unsigned int lineout2fb:1;
|
|
|
|
/* Delay between detecting a jack and starting microphone
|
|
* detect (specified in ms)
|
|
*/
|
|
int micdet_delay;
|
|
|
|
/* Delay between microphone detect completing and reporting on
|
|
* insert (specified in ms)
|
|
*/
|
|
int mic_id_delay;
|
|
|
|
/* IRQ for microphone detection if brought out directly as a
|
|
* signal.
|
|
*/
|
|
int micdet_irq;
|
|
|
|
/* WM8994 microphone biases: 0=0.9*AVDD1 1=0.65*AVVD1 */
|
|
unsigned int micbias1_lvl:1;
|
|
unsigned int micbias2_lvl:1;
|
|
|
|
/* WM8994 jack detect threashold levels, see datasheet for values */
|
|
unsigned int jd_scthr:2;
|
|
unsigned int jd_thr:2;
|
|
|
|
/* Configure WM1811 jack detection for use with external capacitor */
|
|
unsigned int jd_ext_cap:1;
|
|
|
|
/* WM8958 microphone bias configuration */
|
|
int micbias[2];
|
|
|
|
/* WM8958 microphone detection ranges */
|
|
u16 micd_lvl_sel;
|
|
|
|
/* Disable the internal pull downs on the LDOs if they are
|
|
* always driven (eg, connected to an always on supply or
|
|
* GPIO that always drives an output. If they float power
|
|
* consumption will rise.
|
|
*/
|
|
bool ldo_ena_always_driven;
|
|
|
|
/*
|
|
* SPKMODE must be pulled internally by the device on this
|
|
* system.
|
|
*/
|
|
bool spkmode_pu;
|
|
|
|
/**
|
|
* Maximum number of channels clocks will be generated for,
|
|
* useful for systems where and I2S bus with multiple data
|
|
* lines is mastered.
|
|
*/
|
|
int max_channels_clocked[WM8994_NUM_AIF];
|
|
|
|
/**
|
|
* GPIO for the IRQ pin if host only supports edge triggering
|
|
*/
|
|
int irq_gpio;
|
|
};
|
|
|
|
#endif
|