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