1 #ifndef __LINUX_MFD_MSM_ADIE_CODEC_H
2 #define __LINUX_MFD_MSM_ADIE_CODEC_H
3 
4 #include <linux/types.h>
5 
6 /* Value Represents a entry */
7 #define ADIE_CODEC_ACTION_ENTRY       0x1
8 /* Value representing a delay wait */
9 #define ADIE_CODEC_ACTION_DELAY_WAIT      0x2
10 /* Value representing a stage reached */
11 #define ADIE_CODEC_ACTION_STAGE_REACHED   0x3
12 
13 /* This value is the state after the client sets the path */
14 #define ADIE_CODEC_PATH_OFF                                        0x0050
15 
16 /* State to which client asks the drv to proceed to where it can
17  * set up the clocks and 0-fill PCM buffers
18  */
19 #define ADIE_CODEC_DIGITAL_READY                                   0x0100
20 
21 /* State to which client asks the drv to proceed to where it can
22  * start sending data after internal steady state delay
23  */
24 #define ADIE_CODEC_DIGITAL_ANALOG_READY                            0x1000
25 
26 
27 /*  Client Asks adie to switch off the Analog portion of the
28  *  the internal codec. After the use of this path
29  */
30 #define ADIE_CODEC_ANALOG_OFF                                      0x0750
31 
32 
33 /* Client Asks adie to switch off the digital portion of the
34  *  the internal codec. After switching off the analog portion.
35  *
36  *  0-fill PCM may or maynot be sent at this point
37  *
38  */
39 #define ADIE_CODEC_DIGITAL_OFF                                     0x0600
40 
41 /* State to which client asks the drv to write the default values
42  * to the registers */
43 #define ADIE_CODEC_FLASH_IMAGE 					   0x0001
44 
45 /* Path type */
46 #define ADIE_CODEC_RX 0
47 #define ADIE_CODEC_TX 1
48 #define ADIE_CODEC_LB 3
49 #define ADIE_CODEC_MAX 4
50 
51 #define ADIE_CODEC_PACK_ENTRY(reg, mask, val) ((val)|(mask << 8)|(reg << 16))
52 
53 #define ADIE_CODEC_UNPACK_ENTRY(packed, reg, mask, val) \
54 	do { \
55 		((reg) = ((packed >> 16) & (0xff))); \
56 		((mask) = ((packed >> 8) & (0xff))); \
57 		((val) = ((packed) & (0xff))); \
58 	} while (0);
59 
60 struct adie_codec_action_unit {
61 	u32 type;
62 	u32 action;
63 };
64 
65 struct adie_codec_hwsetting_entry{
66 	struct adie_codec_action_unit *actions;
67 	u32 action_sz;
68 	u32 freq_plan;
69 	u32 osr;
70 	/* u32  VolMask;
71 	 * u32  SidetoneMask;
72 	 */
73 };
74 
75 struct adie_codec_dev_profile {
76 	u32 path_type; /* RX or TX */
77 	u32 setting_sz;
78 	struct adie_codec_hwsetting_entry *settings;
79 };
80 
81 struct adie_codec_register {
82 	u8 reg;
83 	u8 mask;
84 	u8 val;
85 };
86 
87 struct adie_codec_register_image {
88 	struct adie_codec_register *regs;
89 	u32 img_sz;
90 };
91 
92 struct adie_codec_path;
93 
94 struct adie_codec_anc_data {
95 	u32 size;
96 	u32 writes[];
97 };
98 
99 struct adie_codec_operations {
100 	int	 codec_id;
101 	int (*codec_open) (struct adie_codec_dev_profile *profile,
102 				struct adie_codec_path **path_pptr);
103 	int (*codec_close) (struct adie_codec_path *path_ptr);
104 	int (*codec_setpath) (struct adie_codec_path *path_ptr,
105 				u32 freq_plan, u32 osr);
106 	int (*codec_proceed_stage) (struct adie_codec_path *path_ptr,
107 					u32 state);
108 	u32 (*codec_freq_supported) (struct adie_codec_dev_profile *profile,
109 					u32 requested_freq);
110 	int (*codec_enable_sidetone) (struct adie_codec_path *rx_path_ptr,
111 					u32 enable);
112 	int (*codec_enable_anc) (struct adie_codec_path *rx_path_ptr,
113 		u32 enable, struct adie_codec_anc_data *calibration_writes);
114 	int (*codec_set_device_digital_volume) (
115 					struct adie_codec_path *path_ptr,
116 					u32 num_channels,
117 					u32 vol_percentage);
118 
119 	int (*codec_set_device_analog_volume) (struct adie_codec_path *path_ptr,
120 						u32 num_channels,
121 						u32 volume);
122 	int (*codec_set_master_mode) (struct adie_codec_path *path_ptr,
123 					u8 master);
124 };
125 
126 int adie_codec_register_codec_operations(
127 				const struct adie_codec_operations *codec_ops);
128 int adie_codec_open(struct adie_codec_dev_profile *profile,
129 	struct adie_codec_path **path_pptr);
130 int adie_codec_setpath(struct adie_codec_path *path_ptr,
131 	u32 freq_plan, u32 osr);
132 int adie_codec_proceed_stage(struct adie_codec_path *path_ptr, u32 state);
133 int adie_codec_close(struct adie_codec_path *path_ptr);
134 u32 adie_codec_freq_supported(struct adie_codec_dev_profile *profile,
135 							u32 requested_freq);
136 int adie_codec_enable_sidetone(struct adie_codec_path *rx_path_ptr, u32 enable);
137 int adie_codec_enable_anc(struct adie_codec_path *rx_path_ptr, u32 enable,
138 	struct adie_codec_anc_data *calibration_writes);
139 int adie_codec_set_device_digital_volume(struct adie_codec_path *path_ptr,
140 		u32 num_channels, u32 vol_percentage /* in percentage */);
141 
142 int adie_codec_set_device_analog_volume(struct adie_codec_path *path_ptr,
143 		u32 num_channels, u32 volume /* in percentage */);
144 
145 int adie_codec_set_master_mode(struct adie_codec_path *path_ptr, u8 master);
146 #endif
147