404

[ Avaa Bypassed ]




Upload:

Command:

botdev@18.222.106.93: ~ $
/*
 * 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

Filemanager

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