/* SPDX-License-Identifier: GPL-2.0 */ #ifndef _WCD_CLSH_V2_H_ #define _WCD_CLSH_V2_H_ #include <sound/soc.h> enum wcd_clsh_event { WCD_CLSH_EVENT_PRE_DAC = 1, WCD_CLSH_EVENT_POST_PA, }; /* * Basic states for Class H state machine. * represented as a bit mask within a u8 data type * bit 0: EAR mode * bit 1: HPH Left mode * bit 2: HPH Right mode * bit 3: Lineout mode */ #define WCD_CLSH_STATE_IDLE 0 #define WCD_CLSH_STATE_EAR BIT(0) #define WCD_CLSH_STATE_HPHL BIT(1) #define WCD_CLSH_STATE_HPHR BIT(2) #define WCD_CLSH_STATE_LO BIT(3) #define WCD_CLSH_STATE_AUX BIT(4) #define WCD_CLSH_STATE_MAX 4 #define WCD_CLSH_V3_STATE_MAX 5 #define NUM_CLSH_STATES_V2 BIT(WCD_CLSH_STATE_MAX) #define NUM_CLSH_STATES_V3 BIT(WCD_CLSH_V3_STATE_MAX) enum wcd_clsh_mode { CLS_H_NORMAL = 0, /* Class-H Default */ CLS_H_HIFI, /* Class-H HiFi */ CLS_H_LP, /* Class-H Low Power */ CLS_AB, /* Class-AB */ CLS_H_LOHIFI, /* LoHIFI */ CLS_H_ULP, /* Ultra Low power */ CLS_AB_HIFI, /* Class-AB */ CLS_AB_LP, /* Class-AB Low Power */ CLS_AB_LOHIFI, /* Class-AB Low HIFI */ CLS_NONE, /* None of the above modes */ }; enum wcd_codec_version { WCD9335 = 0, WCD934X = 1, /* New CLSH after this */ WCD937X = 2, WCD938X = 3, }; struct wcd_clsh_ctrl; extern struct wcd_clsh_ctrl *wcd_clsh_ctrl_alloc( struct snd_soc_component *comp, int version); extern void wcd_clsh_ctrl_free(struct wcd_clsh_ctrl *ctrl); extern int wcd_clsh_ctrl_get_state(struct wcd_clsh_ctrl *ctrl); extern int wcd_clsh_ctrl_set_state(struct wcd_clsh_ctrl *ctrl, enum wcd_clsh_event clsh_event, int nstate, enum wcd_clsh_mode mode); extern void wcd_clsh_set_hph_mode(struct wcd_clsh_ctrl *ctrl, int mode); #endif /* _WCD_CLSH_V2_H_ */