123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright (c) 2015-2019,, 2021, The Linux Foundation. All rights reserved.
- */
- #ifndef _WCD_CLSH
- #define _WCD_CLSH
- #include <linux/stringify.h>
- #define WCD_CLSH_STRINGIFY(s) __stringify(s)
- #define CLSH_REQ_ENABLE true
- #define CLSH_REQ_DISABLE false
- #define WCD_CLSH_EVENT_PRE_DAC 0x01
- #define WCD_CLSH_EVENT_POST_PA 0x02
- /*
- * 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: AUX mode
- */
- #define WCD_CLSH_STATE_IDLE 0x00
- #define WCD_CLSH_STATE_EAR (0x01 << 0)
- #define WCD_CLSH_STATE_HPHL (0x01 << 1)
- #define WCD_CLSH_STATE_HPHR (0x01 << 2)
- #define WCD_CLSH_STATE_AUX (0x01 << 3)
- /*
- * Though number of CLSH states is 4, max state should be 5
- * because state array index starts from 1.
- */
- #define WCD_CLSH_STATE_MAX 5
- #define NUM_CLSH_STATES (0x01 << WCD_CLSH_STATE_MAX)
- /* Derived State: Bits 1 and 2 should be set for Headphone stereo */
- #define WCD_CLSH_STATE_HPH_ST (WCD_CLSH_STATE_HPHL | \
- WCD_CLSH_STATE_HPHR)
- #define WCD_CLSH_STATE_HPHL_AUX (WCD_CLSH_STATE_HPHL | \
- WCD_CLSH_STATE_AUX)
- #define WCD_CLSH_STATE_HPHR_AUX (WCD_CLSH_STATE_HPHR | \
- WCD_CLSH_STATE_AUX)
- #define WCD_CLSH_STATE_HPH_ST_AUX (WCD_CLSH_STATE_HPH_ST | \
- WCD_CLSH_STATE_AUX)
- #define WCD_CLSH_STATE_EAR_AUX (WCD_CLSH_STATE_EAR | \
- WCD_CLSH_STATE_AUX)
- #define WCD_CLSH_STATE_HPHL_EAR (WCD_CLSH_STATE_HPHL | \
- WCD_CLSH_STATE_EAR)
- #define WCD_CLSH_STATE_HPHR_EAR (WCD_CLSH_STATE_HPHR | \
- WCD_CLSH_STATE_EAR)
- #define WCD_CLSH_STATE_HPH_ST_EAR (WCD_CLSH_STATE_HPH_ST | \
- WCD_CLSH_STATE_EAR)
- #define WCD9XXX_BASE_ADDRESS 0x3000
- #define WCD9XXX_ANA_RX_SUPPLIES (WCD9XXX_BASE_ADDRESS+0x008)
- #define WCD9XXX_ANA_HPH (WCD9XXX_BASE_ADDRESS+0x009)
- #define WCD9XXX_CLASSH_MODE_2 (WCD9XXX_BASE_ADDRESS+0x098)
- #define WCD9XXX_CLASSH_MODE_3 (WCD9XXX_BASE_ADDRESS+0x099)
- #define WCD9XXX_FLYBACK_VNEG_CTRL_1 (WCD9XXX_BASE_ADDRESS+0x0A5)
- #define WCD9XXX_FLYBACK_VNEG_CTRL_4 (WCD9XXX_BASE_ADDRESS+0x0A8)
- #define WCD9XXX_FLYBACK_VNEGDAC_CTRL_2 (WCD9XXX_BASE_ADDRESS+0x0AF)
- #define WCD9XXX_RX_BIAS_HPH_LOWPOWER (WCD9XXX_BASE_ADDRESS+0x0BF)
- #define WCD9XXX_RX_BIAS_FLYB_BUFF (WCD9XXX_BASE_ADDRESS+0x0C7)
- #define WCD9XXX_HPH_PA_CTL1 (WCD9XXX_BASE_ADDRESS+0x0D1)
- #define WCD9XXX_HPH_NEW_INT_PA_MISC2 (WCD9XXX_BASE_ADDRESS+0x138)
- enum {
- CLS_H_NORMAL = 0, /* Class-H Default */
- CLS_H_HIFI, /* Class-H HiFi */
- CLS_H_LP, /* Class-H Low Power */
- CLS_AB, /* Class-AB Low HIFI*/
- 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 */
- };
- /* Class H data that the codec driver will maintain */
- struct wcd_clsh_cdc_info {
- u8 state;
- int flyback_users;
- int buck_users;
- int interpolator_modes[WCD_CLSH_STATE_MAX];
- };
- #ifdef CONFIG_SND_SOC_WCD9XXX_V2
- extern void wcd_cls_h_fsm(struct snd_soc_component *component,
- struct wcd_clsh_cdc_info *cdc_clsh_d,
- u8 clsh_event, u8 req_state,
- int int_mode);
- extern void wcd_cls_h_init(struct wcd_clsh_cdc_info *clsh);
- extern void wcd_clsh_set_hph_mode(struct snd_soc_component *component,
- int mode);
- #else
- static inline void wcd_cls_h_fsm(struct snd_soc_component *component,
- struct wcd_clsh_cdc_info *cdc_clsh_d,
- u8 clsh_event, u8 req_state,
- int int_mode)
- {
- }
- static inline extern void wcd_cls_h_init(struct wcd_clsh_cdc_info *clsh)
- {
- }
- static inline extern void wcd_clsh_set_hph_mode(struct snd_soc_component *component,
- int mode)
- {
- }
- #endif /* CONFIG_SND_SOC_WCD9XXX_V2 */
- #endif
|