Files
android_kernel_samsung_sm86…/asoc/codecs/lpass-cdc/internal.h
Vangala, Amarnath a267ec5239 asoc: lpass-codec: enable TX Core clock before codec reg access
Enable the TX Core clock to enable access to lpass-cdc registers.

Change-Id: I3088e06e9e77ef24b2e4e802852cc3bb65542f5c
Signed-off-by: Vangala, Amarnath <quic_avangala@quicinc.com>
2023-07-25 09:27:58 +05:30

113 sor
3.0 KiB
C

/* SPDX-License-Identifier: GPL-2.0-only */
/* Copyright (c) 2018-2021, The Linux Foundation. All rights reserved.
* Copyright (c) 2023 Qualcomm Innovation Center, Inc. All rights reserved.
*/
#ifndef _LPASS_CDC_INTERNAL_H
#define _LPASS_CDC_INTERNAL_H
#include "lpass-cdc-registers.h"
#define LPASS_CDC_CHILD_DEVICES_MAX 6
/* from lpass_cdc to WCD events */
enum {
LPASS_CDC_WCD_EVT_TX_CH_HOLD_CLEAR = 1,
LPASS_CDC_WCD_EVT_PA_OFF_PRE_SSR,
LPASS_CDC_WCD_EVT_SSR_DOWN,
LPASS_CDC_WCD_EVT_SSR_UP,
LPASS_CDC_WCD_EVT_PA_ON_POST_FSCLK,
LPASS_CDC_WCD_EVT_PA_ON_POST_FSCLK_ADIE_LB,
LPASS_CDC_WCD_EVT_CLK_NOTIFY,
};
enum {
REG_NO_ACCESS,
RD_REG,
WR_REG,
RD_WR_REG
};
/* from WCD to lpass_cdc events */
enum {
WCD_LPASS_CDC_EVT_RX_MUTE = 1, /* for RX mute/unmute */
WCD_LPASS_CDC_EVT_IMPED_TRUE, /* for imped true */
WCD_LPASS_CDC_EVT_IMPED_FALSE, /* for imped false */
WCD_LPASS_CDC_EVT_RX_COMPANDER_SOFT_RST,
WCD_LPASS_CDC_EVT_BCS_CLK_OFF,
WCD_LPASS_CDC_EVT_RX_PA_GAIN_UPDATE,
WCD_LPASS_CDC_EVT_HPHL_HD2_ENABLE, /* to enable hd2 config for hphl */
WCD_LPASS_CDC_EVT_HPHR_HD2_ENABLE, /* to enable hd2 config for hphr */
};
struct wcd_ctrl_platform_data {
void *handle;
int (*update_wcd_event)(void *handle, u16 event, u32 data);
int (*register_notifier)(void *handle,
struct notifier_block *nblock,
bool enable);
};
struct lpass_cdc_priv {
struct device *dev;
struct snd_soc_component *component;
struct regmap *regmap;
struct mutex macro_lock;
struct mutex io_lock;
struct mutex clk_lock;
struct mutex vote_lock;
bool va_without_decimation;
bool macros_supported[MAX_MACRO];
bool dev_up;
bool pre_dev_up;
bool initial_boot;
struct macro_ops macro_params[MAX_MACRO];
struct snd_soc_dai_driver *lpass_cdc_dais;
u16 num_dais;
u16 num_macros_registered;
u16 num_macros;
u16 current_mclk_mux_macro[MAX_MACRO];
struct work_struct lpass_cdc_add_child_devices_work;
u32 version;
struct clk *lpass_core_hw_vote;
struct clk *lpass_audio_hw_vote;
int core_hw_vote_count;
int core_audio_vote_count;
int core_clk_vote_count;
/* Entry for version info */
struct snd_info_entry *entry;
struct snd_info_entry *version_entry;
int (*read_dev)(struct lpass_cdc_priv *priv,
u16 macro_id, u16 reg, u8 *val);
int (*write_dev)(struct lpass_cdc_priv *priv,
u16 macro_id, u16 reg, u8 val);
struct platform_device *pdev_child_devices
[LPASS_CDC_CHILD_DEVICES_MAX];
u16 child_count;
struct wcd_ctrl_platform_data plat_data;
struct device *wcd_dev;
struct blocking_notifier_head notifier;
struct device *clk_dev;
rsc_clk_cb_t rsc_clk_cb;
s32 dmic_0_1_clk_cnt;
s32 dmic_2_3_clk_cnt;
s32 dmic_4_5_clk_cnt;
s32 dmic_6_7_clk_cnt;
u8 dmic_0_1_clk_div;
u8 dmic_2_3_clk_div;
u8 dmic_4_5_clk_div;
u8 dmic_6_7_clk_div;
};
struct regmap *lpass_cdc_regmap_init(struct device *dev,
const struct regmap_config *config);
int lpass_cdc_get_macro_id(bool va_no_dec_flag, u16 reg);
extern const struct regmap_config lpass_cdc_regmap_config;
extern u8 *lpass_cdc_reg_access[MAX_MACRO];
extern const u16 macro_id_base_offset[MAX_MACRO];
#endif