1f213f4b5SHaojian Zhuang /*
2f213f4b5SHaojian Zhuang  * 88pm860x-codec.h -- 88PM860x ALSA SoC Audio Driver
3f213f4b5SHaojian Zhuang  *
4f213f4b5SHaojian Zhuang  * Copyright 2010 Marvell International Ltd.
5f213f4b5SHaojian Zhuang  *	Haojian Zhuang <haojian.zhuang@marvell.com>
6f213f4b5SHaojian Zhuang  *
7f213f4b5SHaojian Zhuang  * This program is free software; you can redistribute it and/or modify
8f213f4b5SHaojian Zhuang  * it under the terms of the GNU General Public License version 2 as
9f213f4b5SHaojian Zhuang  * published by the Free Software Foundation.
10f213f4b5SHaojian Zhuang  */
11f213f4b5SHaojian Zhuang 
12f213f4b5SHaojian Zhuang #ifndef __88PM860X_H
13f213f4b5SHaojian Zhuang #define __88PM860X_H
14f213f4b5SHaojian Zhuang 
15f9ded3b2SMark Brown #define PM860X_PCM_IFACE_1		0xb0
16f9ded3b2SMark Brown #define PM860X_PCM_IFACE_2		0xb1
17f9ded3b2SMark Brown #define PM860X_PCM_IFACE_3		0xb2
18f9ded3b2SMark Brown #define PM860X_PCM_RATE			0xb3
19f9ded3b2SMark Brown #define PM860X_EC_PATH			0xb4
20f9ded3b2SMark Brown #define PM860X_SIDETONE_L_GAIN		0xb5
21f9ded3b2SMark Brown #define PM860X_SIDETONE_R_GAIN		0xb6
22f9ded3b2SMark Brown #define PM860X_SIDETONE_SHIFT		0xb7
23f9ded3b2SMark Brown #define PM860X_ADC_OFFSET_1		0xb8
24f9ded3b2SMark Brown #define PM860X_ADC_OFFSET_2		0xb9
25f9ded3b2SMark Brown #define PM860X_DMIC_DELAY		0xba
26f213f4b5SHaojian Zhuang 
27f9ded3b2SMark Brown #define PM860X_I2S_IFACE_1		0xbb
28f9ded3b2SMark Brown #define PM860X_I2S_IFACE_2		0xbc
29f9ded3b2SMark Brown #define PM860X_I2S_IFACE_3		0xbd
30f9ded3b2SMark Brown #define PM860X_I2S_IFACE_4		0xbe
31f9ded3b2SMark Brown #define PM860X_EQUALIZER_N0_1		0xbf
32f9ded3b2SMark Brown #define PM860X_EQUALIZER_N0_2		0xc0
33f9ded3b2SMark Brown #define PM860X_EQUALIZER_N1_1		0xc1
34f9ded3b2SMark Brown #define PM860X_EQUALIZER_N1_2		0xc2
35f9ded3b2SMark Brown #define PM860X_EQUALIZER_D1_1		0xc3
36f9ded3b2SMark Brown #define PM860X_EQUALIZER_D1_2		0xc4
37f9ded3b2SMark Brown #define PM860X_LOFI_GAIN_LEFT		0xc5
38f9ded3b2SMark Brown #define PM860X_LOFI_GAIN_RIGHT		0xc6
39f9ded3b2SMark Brown #define PM860X_HIFIL_GAIN_LEFT		0xc7
40f9ded3b2SMark Brown #define PM860X_HIFIL_GAIN_RIGHT		0xc8
41f9ded3b2SMark Brown #define PM860X_HIFIR_GAIN_LEFT		0xc9
42f9ded3b2SMark Brown #define PM860X_HIFIR_GAIN_RIGHT		0xca
43f9ded3b2SMark Brown #define PM860X_DAC_OFFSET		0xcb
44f9ded3b2SMark Brown #define PM860X_OFFSET_LEFT_1		0xcc
45f9ded3b2SMark Brown #define PM860X_OFFSET_LEFT_2		0xcd
46f9ded3b2SMark Brown #define PM860X_OFFSET_RIGHT_1		0xce
47f9ded3b2SMark Brown #define PM860X_OFFSET_RIGHT_2		0xcf
48f9ded3b2SMark Brown #define PM860X_ADC_ANA_1		0xd0
49f9ded3b2SMark Brown #define PM860X_ADC_ANA_2		0xd1
50f9ded3b2SMark Brown #define PM860X_ADC_ANA_3		0xd2
51f9ded3b2SMark Brown #define PM860X_ADC_ANA_4		0xd3
52f9ded3b2SMark Brown #define PM860X_ANA_TO_ANA		0xd4
53f9ded3b2SMark Brown #define PM860X_HS1_CTRL			0xd5
54f9ded3b2SMark Brown #define PM860X_HS2_CTRL			0xd6
55f9ded3b2SMark Brown #define PM860X_LO1_CTRL			0xd7
56f9ded3b2SMark Brown #define PM860X_LO2_CTRL			0xd8
57f9ded3b2SMark Brown #define PM860X_EAR_CTRL_1		0xd9
58f9ded3b2SMark Brown #define PM860X_EAR_CTRL_2		0xda
59f9ded3b2SMark Brown #define PM860X_AUDIO_SUPPLIES_1		0xdb
60f9ded3b2SMark Brown #define PM860X_AUDIO_SUPPLIES_2		0xdc
61f9ded3b2SMark Brown #define PM860X_ADC_EN_1			0xdd
62f9ded3b2SMark Brown #define PM860X_ADC_EN_2			0xde
63f9ded3b2SMark Brown #define PM860X_DAC_EN_1			0xdf
64f9ded3b2SMark Brown #define PM860X_DAC_EN_2			0xe1
65f9ded3b2SMark Brown #define PM860X_AUDIO_CAL_1		0xe2
66f9ded3b2SMark Brown #define PM860X_AUDIO_CAL_2		0xe3
67f9ded3b2SMark Brown #define PM860X_AUDIO_CAL_3		0xe4
68f9ded3b2SMark Brown #define PM860X_AUDIO_CAL_4		0xe5
69f9ded3b2SMark Brown #define PM860X_AUDIO_CAL_5		0xe6
70f9ded3b2SMark Brown #define PM860X_ANA_INPUT_SEL_1		0xe7
71f9ded3b2SMark Brown #define PM860X_ANA_INPUT_SEL_2		0xe8
72f213f4b5SHaojian Zhuang 
73f9ded3b2SMark Brown #define PM860X_PCM_IFACE_4		0xe9
74f9ded3b2SMark Brown #define PM860X_I2S_IFACE_5		0xea
75f213f4b5SHaojian Zhuang 
76f213f4b5SHaojian Zhuang #define PM860X_SHORTS			0x3b
77f213f4b5SHaojian Zhuang #define PM860X_PLL_ADJ_1		0x3c
78f213f4b5SHaojian Zhuang #define PM860X_PLL_ADJ_2		0x3d
79f213f4b5SHaojian Zhuang 
80f213f4b5SHaojian Zhuang /* bits definition */
81f213f4b5SHaojian Zhuang #define PM860X_CLK_DIR_IN		0
82f213f4b5SHaojian Zhuang #define PM860X_CLK_DIR_OUT		1
83f213f4b5SHaojian Zhuang 
84f213f4b5SHaojian Zhuang #define PM860X_DET_HEADSET		(1 << 0)
85f213f4b5SHaojian Zhuang #define PM860X_DET_MIC			(1 << 1)
86f213f4b5SHaojian Zhuang #define PM860X_DET_HOOK			(1 << 2)
87f213f4b5SHaojian Zhuang #define PM860X_SHORT_HEADSET		(1 << 3)
88f213f4b5SHaojian Zhuang #define PM860X_SHORT_LINEOUT		(1 << 4)
89f213f4b5SHaojian Zhuang #define PM860X_DET_MASK			0x1F
90f213f4b5SHaojian Zhuang 
915783994bSKuninori Morimoto extern int pm860x_hs_jack_detect(struct snd_soc_component *, struct snd_soc_jack *,
92f213f4b5SHaojian Zhuang 				 int, int, int, int);
935783994bSKuninori Morimoto extern int pm860x_mic_jack_detect(struct snd_soc_component *, struct snd_soc_jack *,
94f213f4b5SHaojian Zhuang 				  int);
95f213f4b5SHaojian Zhuang 
96f213f4b5SHaojian Zhuang #endif	/* __88PM860X_H */
97