/* * Platform data for WM8904 * * 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__ /* Used to enable configuration of a GPIO to all zeros */ #define WM8904_GPIO_NO_CONFIG 0x8000 /* * R6 (0x06) - Mic Bias Control 0 */ #define WM8904_MICDET_THR_MASK 0x0070 /* MICDET_THR - [6:4] */ #define WM8904_MICDET_THR_SHIFT 4 /* MICDET_THR - [6:4] */ #define WM8904_MICDET_THR_WIDTH 3 /* MICDET_THR - [6:4] */ #define WM8904_MICSHORT_THR_MASK 0x000C /* MICSHORT_THR - [3:2] */ #define WM8904_MICSHORT_THR_SHIFT 2 /* MICSHORT_THR - [3:2] */ #define WM8904_MICSHORT_THR_WIDTH 2 /* MICSHORT_THR - [3:2] */ #define WM8904_MICDET_ENA 0x0002 /* MICDET_ENA */ #define WM8904_MICDET_ENA_MASK 0x0002 /* MICDET_ENA */ #define WM8904_MICDET_ENA_SHIFT 1 /* MICDET_ENA */ #define WM8904_MICDET_ENA_WIDTH 1 /* MICDET_ENA */ #define WM8904_MICBIAS_ENA 0x0001 /* MICBIAS_ENA */ #define WM8904_MICBIAS_ENA_MASK 0x0001 /* MICBIAS_ENA */ #define WM8904_MICBIAS_ENA_SHIFT 0 /* MICBIAS_ENA */ #define WM8904_MICBIAS_ENA_WIDTH 1 /* MICBIAS_ENA */ /* * R7 (0x07) - Mic Bias Control 1 */ #define WM8904_MIC_DET_FILTER_ENA 0x8000 /* MIC_DET_FILTER_ENA */ #define WM8904_MIC_DET_FILTER_ENA_MASK 0x8000 /* MIC_DET_FILTER_ENA */ #define WM8904_MIC_DET_FILTER_ENA_SHIFT 15 /* MIC_DET_FILTER_ENA */ #define WM8904_MIC_DET_FILTER_ENA_WIDTH 1 /* MIC_DET_FILTER_ENA */ #define WM8904_MIC_SHORT_FILTER_ENA 0x4000 /* MIC_SHORT_FILTER_ENA */ #define WM8904_MIC_SHORT_FILTER_ENA_MASK 0x4000 /* MIC_SHORT_FILTER_ENA */ #define WM8904_MIC_SHORT_FILTER_ENA_SHIFT 14 /* MIC_SHORT_FILTER_ENA */ #define WM8904_MIC_SHORT_FILTER_ENA_WIDTH 1 /* MIC_SHORT_FILTER_ENA */ #define WM8904_MICBIAS_SEL_MASK 0x0007 /* MICBIAS_SEL - [2:0] */ #define WM8904_MICBIAS_SEL_SHIFT 0 /* MICBIAS_SEL - [2:0] */ #define WM8904_MICBIAS_SEL_WIDTH 3 /* MICBIAS_SEL - [2:0] */ /* * R121 (0x79) - GPIO Control 1 */ #define WM8904_GPIO1_PU 0x0020 /* GPIO1_PU */ #define WM8904_GPIO1_PU_MASK 0x0020 /* GPIO1_PU */ #define WM8904_GPIO1_PU_SHIFT 5 /* GPIO1_PU */ #define WM8904_GPIO1_PU_WIDTH 1 /* GPIO1_PU */ #define WM8904_GPIO1_PD 0x0010 /* GPIO1_PD */ #define WM8904_GPIO1_PD_MASK 0x0010 /* GPIO1_PD */ #define WM8904_GPIO1_PD_SHIFT 4 /* GPIO1_PD */ #define WM8904_GPIO1_PD_WIDTH 1 /* GPIO1_PD */ #define WM8904_GPIO1_SEL_MASK 0x000F /* GPIO1_SEL - [3:0] */ #define WM8904_GPIO1_SEL_SHIFT 0 /* GPIO1_SEL - [3:0] */ #define WM8904_GPIO1_SEL_WIDTH 4 /* GPIO1_SEL - [3:0] */ /* * R122 (0x7A) - GPIO Control 2 */ #define WM8904_GPIO2_PU 0x0020 /* GPIO2_PU */ #define WM8904_GPIO2_PU_MASK 0x0020 /* GPIO2_PU */ #define WM8904_GPIO2_PU_SHIFT 5 /* GPIO2_PU */ #define WM8904_GPIO2_PU_WIDTH 1 /* GPIO2_PU */ #define WM8904_GPIO2_PD 0x0010 /* GPIO2_PD */ #define WM8904_GPIO2_PD_MASK 0x0010 /* GPIO2_PD */ #define WM8904_GPIO2_PD_SHIFT 4 /* GPIO2_PD */ #define WM8904_GPIO2_PD_WIDTH 1 /* GPIO2_PD */ #define WM8904_GPIO2_SEL_MASK 0x000F /* GPIO2_SEL - [3:0] */ #define WM8904_GPIO2_SEL_SHIFT 0 /* GPIO2_SEL - [3:0] */ #define WM8904_GPIO2_SEL_WIDTH 4 /* GPIO2_SEL - [3:0] */ /* * R123 (0x7B) - GPIO Control 3 */ #define WM8904_GPIO3_PU 0x0020 /* GPIO3_PU */ #define WM8904_GPIO3_PU_MASK 0x0020 /* GPIO3_PU */ #define WM8904_GPIO3_PU_SHIFT 5 /* GPIO3_PU */ #define WM8904_GPIO3_PU_WIDTH 1 /* GPIO3_PU */ #define WM8904_GPIO3_PD 0x0010 /* GPIO3_PD */ #define WM8904_GPIO3_PD_MASK 0x0010 /* GPIO3_PD */ #define WM8904_GPIO3_PD_SHIFT 4 /* GPIO3_PD */ #define WM8904_GPIO3_PD_WIDTH 1 /* GPIO3_PD */ #define WM8904_GPIO3_SEL_MASK 0x000F /* GPIO3_SEL - [3:0] */ #define WM8904_GPIO3_SEL_SHIFT 0 /* GPIO3_SEL - [3:0] */ #define WM8904_GPIO3_SEL_WIDTH 4 /* GPIO3_SEL - [3:0] */ /* * R124 (0x7C) - GPIO Control 4 */ #define WM8904_GPI7_ENA 0x0200 /* GPI7_ENA */ #define WM8904_GPI7_ENA_MASK 0x0200 /* GPI7_ENA */ #define WM8904_GPI7_ENA_SHIFT 9 /* GPI7_ENA */ #define WM8904_GPI7_ENA_WIDTH 1 /* GPI7_ENA */ #define WM8904_GPI8_ENA 0x0100 /* GPI8_ENA */ #define WM8904_GPI8_ENA_MASK 0x0100 /* GPI8_ENA */ #define WM8904_GPI8_ENA_SHIFT 8 /* GPI8_ENA */ #define WM8904_GPI8_ENA_WIDTH 1 /* GPI8_ENA */ #define WM8904_GPIO_BCLK_MODE_ENA 0x0080 /* GPIO_BCLK_MODE_ENA */ #define WM8904_GPIO_BCLK_MODE_ENA_MASK 0x0080 /* GPIO_BCLK_MODE_ENA */ #define WM8904_GPIO_BCLK_MODE_ENA_SHIFT 7 /* GPIO_BCLK_MODE_ENA */ #define WM8904_GPIO_BCLK_MODE_ENA_WIDTH 1 /* GPIO_BCLK_MODE_ENA */ #define WM8904_GPIO_BCLK_SEL_MASK 0x000F /* GPIO_BCLK_SEL - [3:0] */ #define WM8904_GPIO_BCLK_SEL_SHIFT 0 /* GPIO_BCLK_SEL - [3:0] */ #define WM8904_GPIO_BCLK_SEL_WIDTH 4 /* GPIO_BCLK_SEL - [3:0] */ #define WM8904_MIC_REGS 2 #define WM8904_GPIO_REGS 4 #define WM8904_DRC_REGS 4 #define WM8904_EQ_REGS 24 /** * 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 wm8904_drc_cfg { const char *name; u16 regs[WM8904_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 wm8904_retune_mobile_cfg { const char *name; unsigned int rate; u16 regs[WM8904_EQ_REGS]; }; struct wm8904_pdata { int num_drc_cfgs; struct wm8904_drc_cfg *drc_cfgs; int num_retune_mobile_cfgs; struct wm8904_retune_mobile_cfg *retune_mobile_cfgs; u32 gpio_cfg[WM8904_GPIO_REGS]; u32 mic_cfg[WM8904_MIC_REGS]; }; #endif
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
ac97 | Folder | 0755 |
|
|
ac97_codec.h | File | 16.34 KB | 0644 |
|
aci.h | File | 2.4 KB | 0644 |
|
ad1816a.h | File | 5.38 KB | 0644 |
|
ad1843.h | File | 1.48 KB | 0644 |
|
adau1373.h | File | 699 B | 0644 |
|
aess.h | File | 1.63 KB | 0644 |
|
ak4113.h | File | 10.89 KB | 0644 |
|
ak4114.h | File | 10.22 KB | 0644 |
|
ak4117.h | File | 9.02 KB | 0644 |
|
ak4531_codec.h | File | 3.1 KB | 0644 |
|
ak4641.h | File | 622 B | 0644 |
|
ak4xxx-adda.h | File | 3.34 KB | 0644 |
|
alc5623.h | File | 536 B | 0644 |
|
asequencer.h | File | 3.58 KB | 0644 |
|
asound.h | File | 1.25 KB | 0644 |
|
asoundef.h | File | 16.7 KB | 0644 |
|
compress_driver.h | File | 6.93 KB | 0644 |
|
control.h | File | 8.84 KB | 0644 |
|
core.h | File | 13.84 KB | 0644 |
|
cs35l33.h | File | 1.01 KB | 0644 |
|
cs35l34.h | File | 887 B | 0644 |
|
cs35l35.h | File | 2.36 KB | 0644 |
|
cs4231-regs.h | File | 8.28 KB | 0644 |
|
cs4271.h | File | 1.38 KB | 0644 |
|
cs42l52.h | File | 738 B | 0644 |
|
cs42l56.h | File | 1.16 KB | 0644 |
|
cs42l73.h | File | 507 B | 0644 |
|
cs8403.h | File | 8.63 KB | 0644 |
|
cs8427.h | File | 10.4 KB | 0644 |
|
da7213.h | File | 1.15 KB | 0644 |
|
da7218.h | File | 2.62 KB | 0644 |
|
da7219-aad.h | File | 2.42 KB | 0644 |
|
da7219.h | File | 1.04 KB | 0644 |
|
da9055.h | File | 914 B | 0644 |
|
designware_i2s.h | File | 2.25 KB | 0644 |
|
dmaengine_pcm.h | File | 6.22 KB | 0644 |
|
emu10k1.h | File | 89.25 KB | 0644 |
|
emu10k1_synth.h | File | 1.35 KB | 0644 |
|
emu8000.h | File | 4.01 KB | 0644 |
|
emu8000_reg.h | File | 10.21 KB | 0644 |
|
emux_legacy.h | File | 5.37 KB | 0644 |
|
emux_synth.h | File | 7.46 KB | 0644 |
|
es1688.h | File | 3.53 KB | 0644 |
|
gus.h | File | 20.21 KB | 0644 |
|
hda_chmap.h | File | 2.6 KB | 0644 |
|
hda_hwdep.h | File | 1.38 KB | 0644 |
|
hda_i915.h | File | 1.64 KB | 0644 |
|
hda_register.h | File | 10 KB | 0644 |
|
hda_regmap.h | File | 6.59 KB | 0644 |
|
hda_verbs.h | File | 16.81 KB | 0644 |
|
hdaudio.h | File | 18.39 KB | 0644 |
|
hdaudio_ext.h | File | 6.99 KB | 0644 |
|
hdmi-codec.h | File | 2.42 KB | 0644 |
|
hwdep.h | File | 2.56 KB | 0644 |
|
i2c.h | File | 3.47 KB | 0644 |
|
info.h | File | 7.41 KB | 0644 |
|
initval.h | File | 3.08 KB | 0644 |
|
jack.h | File | 3.75 KB | 0644 |
|
l3.h | File | 524 B | 0644 |
|
max9768.h | File | 729 B | 0644 |
|
max98088.h | File | 1.26 KB | 0644 |
|
max98090.h | File | 754 B | 0644 |
|
max98095.h | File | 1.54 KB | 0644 |
|
memalloc.h | File | 4.41 KB | 0644 |
|
minors.h | File | 4.33 KB | 0644 |
|
mixer_oss.h | File | 2.41 KB | 0644 |
|
mpu401.h | File | 4.49 KB | 0644 |
|
omap-hdmi-audio.h | File | 1.34 KB | 0644 |
|
omap-pcm.h | File | 864 B | 0644 |
|
opl3.h | File | 12.31 KB | 0644 |
|
opl4.h | File | 1.1 KB | 0644 |
|
pcm-indirect.h | File | 5.7 KB | 0644 |
|
pcm.h | File | 47.51 KB | 0644 |
|
pcm_drm_eld.h | File | 183 B | 0644 |
|
pcm_iec958.h | File | 332 B | 0644 |
|
pcm_oss.h | File | 2.69 KB | 0644 |
|
pcm_params.h | File | 9.03 KB | 0644 |
|
pt2258.h | File | 1.18 KB | 0644 |
|
pxa2xx-lib.h | File | 1.48 KB | 0644 |
|
rawmidi.h | File | 6.17 KB | 0644 |
|
rt286.h | File | 460 B | 0644 |
|
rt298.h | File | 519 B | 0644 |
|
rt5514.h | File | 478 B | 0644 |
|
rt5640.h | File | 648 B | 0644 |
|
rt5645.h | File | 738 B | 0644 |
|
rt5651.h | File | 581 B | 0644 |
|
rt5659.h | File | 1003 B | 0644 |
|
rt5660.h | File | 724 B | 0644 |
|
rt5663.h | File | 622 B | 0644 |
|
rt5665.h | File | 907 B | 0644 |
|
rt5670.h | File | 679 B | 0644 |
|
s3c24xx_uda134x.h | File | 229 B | 0644 |
|
sb.h | File | 10.98 KB | 0644 |
|
sb16_csp.h | File | 2.71 KB | 0644 |
|
seq_device.h | File | 2.79 KB | 0644 |
|
seq_kernel.h | File | 3.96 KB | 0644 |
|
seq_midi_emul.h | File | 7.26 KB | 0644 |
|
seq_midi_event.h | File | 2.17 KB | 0644 |
|
seq_oss.h | File | 2.86 KB | 0644 |
|
seq_oss_legacy.h | File | 1 KB | 0644 |
|
seq_virmidi.h | File | 2.73 KB | 0644 |
|
sh_dac_audio.h | File | 587 B | 0644 |
|
sh_fsi.h | File | 847 B | 0644 |
|
simple_card.h | File | 683 B | 0644 |
|
simple_card_utils.h | File | 3.96 KB | 0644 |
|
snd_wavefront.h | File | 5.57 KB | 0644 |
|
soc-acpi-intel-match.h | File | 1.1 KB | 0644 |
|
soc-acpi.h | File | 3.6 KB | 0644 |
|
soc-dai.h | File | 11.13 KB | 0644 |
|
soc-dapm.h | File | 30.87 KB | 0644 |
|
soc-dpcm.h | File | 4.73 KB | 0644 |
|
soc-topology.h | File | 5.71 KB | 0644 |
|
soc.h | File | 63.47 KB | 0644 |
|
soundfont.h | File | 4.48 KB | 0644 |
|
spear_dma.h | File | 1003 B | 0644 |
|
spear_spdif.h | File | 1010 B | 0644 |
|
sta32x.h | File | 1.2 KB | 0644 |
|
sta350.h | File | 1.65 KB | 0644 |
|
tas2552-plat.h | File | 678 B | 0644 |
|
tas5086.h | File | 210 B | 0644 |
|
tea6330t.h | File | 1.14 KB | 0644 |
|
timer.h | File | 5.56 KB | 0644 |
|
tlv.h | File | 2.27 KB | 0644 |
|
tlv320aic32x4.h | File | 1.43 KB | 0644 |
|
tlv320aic3x.h | File | 1.88 KB | 0644 |
|
tlv320dac33-plat.h | File | 720 B | 0644 |
|
tpa6130a2-plat.h | File | 900 B | 0644 |
|
uda134x.h | File | 597 B | 0644 |
|
uda1380.h | File | 481 B | 0644 |
|
util_mem.h | File | 2.26 KB | 0644 |
|
vx_core.h | File | 15.34 KB | 0644 |
|
wavefront.h | File | 18.76 KB | 0644 |
|
wm0010.h | File | 679 B | 0644 |
|
wm1250-ev1.h | File | 656 B | 0644 |
|
wm2000.h | File | 625 B | 0644 |
|
wm2200.h | File | 1.46 KB | 0644 |
|
wm5100.h | File | 1.25 KB | 0644 |
|
wm8903.h | File | 15.16 KB | 0644 |
|
wm8904.h | File | 7.43 KB | 0644 |
|
wm8955.h | File | 662 B | 0644 |
|
wm8960.h | File | 603 B | 0644 |
|
wm8962.h | File | 1.8 KB | 0644 |
|
wm8993.h | File | 1.19 KB | 0644 |
|
wm8996.h | File | 1.4 KB | 0644 |
|
wm9081.h | File | 661 B | 0644 |
|
wm9090.h | File | 780 B | 0644 |
|
wss.h | File | 8.44 KB | 0644 |
|