xref: /kernel/linux/linux-6.6/sound/pci/oxygen/wm8776.h (revision 62306a36)
162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci#ifndef WM8776_H_INCLUDED
362306a36Sopenharmony_ci#define WM8776_H_INCLUDED
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci/*
662306a36Sopenharmony_ci * the following register names are from:
762306a36Sopenharmony_ci * wm8776.h  --  WM8776 ASoC driver
862306a36Sopenharmony_ci *
962306a36Sopenharmony_ci * Copyright 2009 Wolfson Microelectronics plc
1062306a36Sopenharmony_ci *
1162306a36Sopenharmony_ci * Author: Mark Brown <broonie@opensource.wolfsonmicro.com>
1262306a36Sopenharmony_ci */
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ci#define WM8776_HPLVOL		0x00
1562306a36Sopenharmony_ci#define WM8776_HPRVOL		0x01
1662306a36Sopenharmony_ci#define WM8776_HPMASTER		0x02
1762306a36Sopenharmony_ci#define WM8776_DACLVOL		0x03
1862306a36Sopenharmony_ci#define WM8776_DACRVOL		0x04
1962306a36Sopenharmony_ci#define WM8776_DACMASTER	0x05
2062306a36Sopenharmony_ci#define WM8776_PHASESWAP	0x06
2162306a36Sopenharmony_ci#define WM8776_DACCTRL1		0x07
2262306a36Sopenharmony_ci#define WM8776_DACMUTE		0x08
2362306a36Sopenharmony_ci#define WM8776_DACCTRL2		0x09
2462306a36Sopenharmony_ci#define WM8776_DACIFCTRL	0x0a
2562306a36Sopenharmony_ci#define WM8776_ADCIFCTRL	0x0b
2662306a36Sopenharmony_ci#define WM8776_MSTRCTRL		0x0c
2762306a36Sopenharmony_ci#define WM8776_PWRDOWN		0x0d
2862306a36Sopenharmony_ci#define WM8776_ADCLVOL		0x0e
2962306a36Sopenharmony_ci#define WM8776_ADCRVOL		0x0f
3062306a36Sopenharmony_ci#define WM8776_ALCCTRL1		0x10
3162306a36Sopenharmony_ci#define WM8776_ALCCTRL2		0x11
3262306a36Sopenharmony_ci#define WM8776_ALCCTRL3		0x12
3362306a36Sopenharmony_ci#define WM8776_NOISEGATE	0x13
3462306a36Sopenharmony_ci#define WM8776_LIMITER		0x14
3562306a36Sopenharmony_ci#define WM8776_ADCMUX		0x15
3662306a36Sopenharmony_ci#define WM8776_OUTMUX		0x16
3762306a36Sopenharmony_ci#define WM8776_RESET		0x17
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci/* HPLVOL/HPRVOL/HPMASTER */
4162306a36Sopenharmony_ci#define WM8776_HPATT_MASK	0x07f
4262306a36Sopenharmony_ci#define WM8776_HPZCEN		0x080
4362306a36Sopenharmony_ci#define WM8776_UPDATE		0x100
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci/* DACLVOL/DACRVOL/DACMASTER */
4662306a36Sopenharmony_ci#define WM8776_DATT_MASK	0x0ff
4762306a36Sopenharmony_ci/*#define WM8776_UPDATE		0x100*/
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci/* PHASESWAP */
5062306a36Sopenharmony_ci#define WM8776_PH_MASK		0x003
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci/* DACCTRL1 */
5362306a36Sopenharmony_ci#define WM8776_DZCEN		0x001
5462306a36Sopenharmony_ci#define WM8776_ATC		0x002
5562306a36Sopenharmony_ci#define WM8776_IZD		0x004
5662306a36Sopenharmony_ci#define WM8776_TOD		0x008
5762306a36Sopenharmony_ci#define WM8776_PL_LEFT_MASK	0x030
5862306a36Sopenharmony_ci#define WM8776_PL_LEFT_MUTE	0x000
5962306a36Sopenharmony_ci#define WM8776_PL_LEFT_LEFT	0x010
6062306a36Sopenharmony_ci#define WM8776_PL_LEFT_RIGHT	0x020
6162306a36Sopenharmony_ci#define WM8776_PL_LEFT_LRMIX	0x030
6262306a36Sopenharmony_ci#define WM8776_PL_RIGHT_MASK	0x0c0
6362306a36Sopenharmony_ci#define WM8776_PL_RIGHT_MUTE	0x000
6462306a36Sopenharmony_ci#define WM8776_PL_RIGHT_LEFT	0x040
6562306a36Sopenharmony_ci#define WM8776_PL_RIGHT_RIGHT	0x080
6662306a36Sopenharmony_ci#define WM8776_PL_RIGHT_LRMIX	0x0c0
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci/* DACMUTE */
6962306a36Sopenharmony_ci#define WM8776_DMUTE		0x001
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci/* DACCTRL2 */
7262306a36Sopenharmony_ci#define WM8776_DEEMPH		0x001
7362306a36Sopenharmony_ci#define WM8776_DZFM_MASK	0x006
7462306a36Sopenharmony_ci#define WM8776_DZFM_NONE	0x000
7562306a36Sopenharmony_ci#define WM8776_DZFM_LR		0x002
7662306a36Sopenharmony_ci#define WM8776_DZFM_BOTH	0x004
7762306a36Sopenharmony_ci#define WM8776_DZFM_EITHER	0x006
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci/* DACIFCTRL */
8062306a36Sopenharmony_ci#define WM8776_DACFMT_MASK	0x003
8162306a36Sopenharmony_ci#define WM8776_DACFMT_RJUST	0x000
8262306a36Sopenharmony_ci#define WM8776_DACFMT_LJUST	0x001
8362306a36Sopenharmony_ci#define WM8776_DACFMT_I2S	0x002
8462306a36Sopenharmony_ci#define WM8776_DACFMT_DSP	0x003
8562306a36Sopenharmony_ci#define WM8776_DACLRP		0x004
8662306a36Sopenharmony_ci#define WM8776_DACBCP		0x008
8762306a36Sopenharmony_ci#define WM8776_DACWL_MASK	0x030
8862306a36Sopenharmony_ci#define WM8776_DACWL_16		0x000
8962306a36Sopenharmony_ci#define WM8776_DACWL_20		0x010
9062306a36Sopenharmony_ci#define WM8776_DACWL_24		0x020
9162306a36Sopenharmony_ci#define WM8776_DACWL_32		0x030
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci/* ADCIFCTRL */
9462306a36Sopenharmony_ci#define WM8776_ADCFMT_MASK	0x003
9562306a36Sopenharmony_ci#define WM8776_ADCFMT_RJUST	0x000
9662306a36Sopenharmony_ci#define WM8776_ADCFMT_LJUST	0x001
9762306a36Sopenharmony_ci#define WM8776_ADCFMT_I2S	0x002
9862306a36Sopenharmony_ci#define WM8776_ADCFMT_DSP	0x003
9962306a36Sopenharmony_ci#define WM8776_ADCLRP		0x004
10062306a36Sopenharmony_ci#define WM8776_ADCBCP		0x008
10162306a36Sopenharmony_ci#define WM8776_ADCWL_MASK	0x030
10262306a36Sopenharmony_ci#define WM8776_ADCWL_16		0x000
10362306a36Sopenharmony_ci#define WM8776_ADCWL_20		0x010
10462306a36Sopenharmony_ci#define WM8776_ADCWL_24		0x020
10562306a36Sopenharmony_ci#define WM8776_ADCWL_32		0x030
10662306a36Sopenharmony_ci#define WM8776_ADCMCLK		0x040
10762306a36Sopenharmony_ci#define WM8776_ADCHPD		0x100
10862306a36Sopenharmony_ci
10962306a36Sopenharmony_ci/* MSTRCTRL */
11062306a36Sopenharmony_ci#define WM8776_ADCRATE_MASK	0x007
11162306a36Sopenharmony_ci#define WM8776_ADCRATE_256	0x002
11262306a36Sopenharmony_ci#define WM8776_ADCRATE_384	0x003
11362306a36Sopenharmony_ci#define WM8776_ADCRATE_512	0x004
11462306a36Sopenharmony_ci#define WM8776_ADCRATE_768	0x005
11562306a36Sopenharmony_ci#define WM8776_ADCOSR		0x008
11662306a36Sopenharmony_ci#define WM8776_DACRATE_MASK	0x070
11762306a36Sopenharmony_ci#define WM8776_DACRATE_128	0x000
11862306a36Sopenharmony_ci#define WM8776_DACRATE_192	0x010
11962306a36Sopenharmony_ci#define WM8776_DACRATE_256	0x020
12062306a36Sopenharmony_ci#define WM8776_DACRATE_384	0x030
12162306a36Sopenharmony_ci#define WM8776_DACRATE_512	0x040
12262306a36Sopenharmony_ci#define WM8776_DACRATE_768	0x050
12362306a36Sopenharmony_ci#define WM8776_DACMS		0x080
12462306a36Sopenharmony_ci#define WM8776_ADCMS		0x100
12562306a36Sopenharmony_ci
12662306a36Sopenharmony_ci/* PWRDOWN */
12762306a36Sopenharmony_ci#define WM8776_PDWN		0x001
12862306a36Sopenharmony_ci#define WM8776_ADCPD		0x002
12962306a36Sopenharmony_ci#define WM8776_DACPD		0x004
13062306a36Sopenharmony_ci#define WM8776_HPPD		0x008
13162306a36Sopenharmony_ci#define WM8776_AINPD		0x040
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci/* ADCLVOL/ADCRVOL */
13462306a36Sopenharmony_ci#define WM8776_AGMASK		0x0ff
13562306a36Sopenharmony_ci#define WM8776_ZCA		0x100
13662306a36Sopenharmony_ci
13762306a36Sopenharmony_ci/* ALCCTRL1 */
13862306a36Sopenharmony_ci#define WM8776_LCT_MASK		0x00f
13962306a36Sopenharmony_ci#define WM8776_MAXGAIN_MASK	0x070
14062306a36Sopenharmony_ci#define WM8776_LCSEL_MASK	0x180
14162306a36Sopenharmony_ci#define WM8776_LCSEL_LIMITER	0x000
14262306a36Sopenharmony_ci#define WM8776_LCSEL_ALC_RIGHT 0x080
14362306a36Sopenharmony_ci#define WM8776_LCSEL_ALC_LEFT	0x100
14462306a36Sopenharmony_ci#define WM8776_LCSEL_ALC_STEREO	0x180
14562306a36Sopenharmony_ci
14662306a36Sopenharmony_ci/* ALCCTRL2 */
14762306a36Sopenharmony_ci#define WM8776_HLD_MASK		0x00f
14862306a36Sopenharmony_ci#define WM8776_ALCZC		0x080
14962306a36Sopenharmony_ci#define WM8776_LCEN		0x100
15062306a36Sopenharmony_ci
15162306a36Sopenharmony_ci/* ALCCTRL3 */
15262306a36Sopenharmony_ci#define WM8776_ATK_MASK		0x00f
15362306a36Sopenharmony_ci#define WM8776_DCY_MASK		0x0f0
15462306a36Sopenharmony_ci
15562306a36Sopenharmony_ci/* NOISEGATE */
15662306a36Sopenharmony_ci#define WM8776_NGAT		0x001
15762306a36Sopenharmony_ci#define WM8776_NGTH_MASK	0x01c
15862306a36Sopenharmony_ci
15962306a36Sopenharmony_ci/* LIMITER */
16062306a36Sopenharmony_ci#define WM8776_MAXATTEN_MASK	0x00f
16162306a36Sopenharmony_ci#define WM8776_TRANWIN_MASK	0x070
16262306a36Sopenharmony_ci
16362306a36Sopenharmony_ci/* ADCMUX */
16462306a36Sopenharmony_ci#define WM8776_AMX_MASK		0x01f
16562306a36Sopenharmony_ci#define WM8776_MUTERA		0x040
16662306a36Sopenharmony_ci#define WM8776_MUTELA		0x080
16762306a36Sopenharmony_ci#define WM8776_LRBOTH		0x100
16862306a36Sopenharmony_ci
16962306a36Sopenharmony_ci/* OUTMUX */
17062306a36Sopenharmony_ci#define WM8776_MX_DAC		0x001
17162306a36Sopenharmony_ci#define WM8776_MX_AUX		0x002
17262306a36Sopenharmony_ci#define WM8776_MX_BYPASS	0x004
17362306a36Sopenharmony_ci
17462306a36Sopenharmony_ci#endif
175