123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- /* 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
|