14d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#ifndef __UAPI_MFD_MSM_ADIE_CODEC_H
24d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define __UAPI_MFD_MSM_ADIE_CODEC_H
34d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
44d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#include <linux/types.h>
54d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
64d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* Value Represents a entry */
74d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_ACTION_ENTRY       0x1
84d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* Value representing a delay wait */
94d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_ACTION_DELAY_WAIT      0x2
104d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* Value representing a stage reached */
114d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_ACTION_STAGE_REACHED   0x3
124d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
134d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* This value is the state after the client sets the path */
144d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_PATH_OFF                                        0x0050
154d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
164d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* State to which client asks the drv to proceed to where it can
174d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin * set up the clocks and 0-fill PCM buffers
184d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin */
194d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_DIGITAL_READY                                   0x0100
204d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
214d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* State to which client asks the drv to proceed to where it can
224d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin * start sending data after internal steady state delay
234d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin */
244d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_DIGITAL_ANALOG_READY                            0x1000
254d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
264d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
274d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/*  Client Asks adie to switch off the Analog portion of the
284d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin *  the internal codec. After the use of this path
294d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin */
304d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_ANALOG_OFF                                      0x0750
314d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
324d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
334d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* Client Asks adie to switch off the digital portion of the
344d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin *  the internal codec. After switching off the analog portion.
354d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin *
364d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin *  0-fill PCM may or maynot be sent at this point
374d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin *
384d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin */
394d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_DIGITAL_OFF                                     0x0600
404d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
414d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* State to which client asks the drv to write the default values
424d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin * to the registers */
434d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_FLASH_IMAGE 					   0x0001
444d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
454d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin/* Path type */
464d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_RX 0
474d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_TX 1
484d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_LB 3
494d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_MAX 4
504d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
514d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_PACK_ENTRY(reg, mask, val) ((val)|(mask << 8)|(reg << 16))
524d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
534d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#define ADIE_CODEC_UNPACK_ENTRY(packed, reg, mask, val) \
544d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	do { \
554d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin		((reg) = ((packed >> 16) & (0xff))); \
564d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin		((mask) = ((packed >> 8) & (0xff))); \
574d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin		((val) = ((packed) & (0xff))); \
584d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	} while (0);
594d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
604d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinstruct adie_codec_action_unit {
614d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 type;
624d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 action;
634d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin};
644d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
654d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinstruct adie_codec_hwsetting_entry{
664d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	struct adie_codec_action_unit *actions;
674d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 action_sz;
684d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 freq_plan;
694d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 osr;
704d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	/* u32  VolMask;
714d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	 * u32  SidetoneMask;
724d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	 */
734d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin};
744d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
754d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinstruct adie_codec_dev_profile {
764d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 path_type; /* RX or TX */
774d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 setting_sz;
784d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	struct adie_codec_hwsetting_entry *settings;
794d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin};
804d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
814d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinstruct adie_codec_register {
824d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u8 reg;
834d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u8 mask;
844d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u8 val;
854d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin};
864d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
874d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinstruct adie_codec_register_image {
884d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	struct adie_codec_register *regs;
894d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 img_sz;
904d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin};
914d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
924d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinstruct adie_codec_path;
934d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
944d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinstruct adie_codec_anc_data {
954d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 size;
964d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 writes[];
974d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin};
984d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
994d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinstruct adie_codec_operations {
1004d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int	 codec_id;
1014d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_open) (struct adie_codec_dev_profile *profile,
1024d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin				struct adie_codec_path **path_pptr);
1034d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_close) (struct adie_codec_path *path_ptr);
1044d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_setpath) (struct adie_codec_path *path_ptr,
1054d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin				u32 freq_plan, u32 osr);
1064d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_proceed_stage) (struct adie_codec_path *path_ptr,
1074d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin					u32 state);
1084d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 (*codec_freq_supported) (struct adie_codec_dev_profile *profile,
1094d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin					u32 requested_freq);
1104d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_enable_sidetone) (struct adie_codec_path *rx_path_ptr,
1114d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin					u32 enable);
1124d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_enable_anc) (struct adie_codec_path *rx_path_ptr,
1134d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin		u32 enable, struct adie_codec_anc_data *calibration_writes);
1144d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_set_device_digital_volume) (
1154d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin					struct adie_codec_path *path_ptr,
1164d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin					u32 num_channels,
1174d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin					u32 vol_percentage);
1184d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
1194d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_set_device_analog_volume) (struct adie_codec_path *path_ptr,
1204d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin						u32 num_channels,
1214d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin						u32 volume);
1224d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	int (*codec_set_master_mode) (struct adie_codec_path *path_ptr,
1234d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin					u8 master);
1244d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin};
1254d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
1264d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_register_codec_operations(
1274d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin				const struct adie_codec_operations *codec_ops);
1284d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_open(struct adie_codec_dev_profile *profile,
1294d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	struct adie_codec_path **path_pptr);
1304d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_setpath(struct adie_codec_path *path_ptr,
1314d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	u32 freq_plan, u32 osr);
1324d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_proceed_stage(struct adie_codec_path *path_ptr, u32 state);
1334d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_close(struct adie_codec_path *path_ptr);
1344d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinu32 adie_codec_freq_supported(struct adie_codec_dev_profile *profile,
1354d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin							u32 requested_freq);
1364d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_enable_sidetone(struct adie_codec_path *rx_path_ptr, u32 enable);
1374d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_enable_anc(struct adie_codec_path *rx_path_ptr, u32 enable,
1384d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin	struct adie_codec_anc_data *calibration_writes);
1394d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_set_device_digital_volume(struct adie_codec_path *path_ptr,
1404d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin		u32 num_channels, u32 vol_percentage /* in percentage */);
1414d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
1424d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_set_device_analog_volume(struct adie_codec_path *path_ptr,
1434d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin		u32 num_channels, u32 volume /* in percentage */);
1444d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin
1454d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjinint adie_codec_set_master_mode(struct adie_codec_path *path_ptr, u8 master);
1464d667bae0175a66dffc4d241a449e706bdee0a85Patrick Tjin#endif
147