Meng Wang | 43bbb87 | 2018-12-10 12:32:05 +0800 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Laxminath Kasam | 2fe71f5 | 2020-05-15 00:39:51 +0530 | [diff] [blame] | 2 | /* Copyright (c) 2018-2020, The Linux Foundation. All rights reserved. |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 3 | */ |
| 4 | |
| 5 | #ifndef _BOLERO_INTERNAL_H |
| 6 | #define _BOLERO_INTERNAL_H |
| 7 | |
Laxminath Kasam | 89438f3 | 2018-06-07 12:44:17 +0530 | [diff] [blame] | 8 | #include "bolero-cdc-registers.h" |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 9 | |
Vidyakumar Athota | 5d45f4c | 2019-03-10 22:35:07 -0700 | [diff] [blame] | 10 | #define BOLERO_CDC_CHILD_DEVICES_MAX 6 |
Laxminath Kasam | 497a651 | 2018-09-17 16:11:52 +0530 | [diff] [blame] | 11 | |
| 12 | /* from bolero to WCD events */ |
| 13 | enum { |
| 14 | BOLERO_WCD_EVT_TX_CH_HOLD_CLEAR = 1, |
Vatsal Bucha | 53b4e14 | 2018-11-13 19:36:25 +0530 | [diff] [blame] | 15 | BOLERO_WCD_EVT_PA_OFF_PRE_SSR, |
Laxminath Kasam | fb0d683 | 2018-09-22 01:49:52 +0530 | [diff] [blame] | 16 | BOLERO_WCD_EVT_SSR_DOWN, |
| 17 | BOLERO_WCD_EVT_SSR_UP, |
Laxminath Kasam | 069df14 | 2019-09-17 23:43:34 +0530 | [diff] [blame] | 18 | BOLERO_WCD_EVT_PA_ON_POST_FSCLK, |
Laxminath Kasam | 2fe71f5 | 2020-05-15 00:39:51 +0530 | [diff] [blame] | 19 | BOLERO_WCD_EVT_PA_ON_POST_FSCLK_ADIE_LB, |
Laxminath Kasam | 497a651 | 2018-09-17 16:11:52 +0530 | [diff] [blame] | 20 | }; |
| 21 | |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 22 | enum { |
| 23 | REG_NO_ACCESS, |
| 24 | RD_REG, |
| 25 | WR_REG, |
| 26 | RD_WR_REG |
| 27 | }; |
| 28 | |
Laxminath Kasam | 497a651 | 2018-09-17 16:11:52 +0530 | [diff] [blame] | 29 | /* from WCD to bolero events */ |
| 30 | enum { |
| 31 | WCD_BOLERO_EVT_RX_MUTE = 1, /* for RX mute/unmute */ |
| 32 | WCD_BOLERO_EVT_IMPED_TRUE, /* for imped true */ |
| 33 | WCD_BOLERO_EVT_IMPED_FALSE, /* for imped false */ |
Karthikeyan Mani | c14c27a | 2019-06-21 14:11:34 -0700 | [diff] [blame] | 34 | WCD_BOLERO_EVT_RX_COMPANDER_SOFT_RST, |
Vatsal Bucha | d06525f | 2019-10-14 23:14:12 +0530 | [diff] [blame] | 35 | WCD_BOLERO_EVT_BCS_CLK_OFF, |
Vatsal Bucha | 8203a06 | 2020-07-17 19:13:19 +0530 | [diff] [blame] | 36 | WCD_BOLERO_EVT_RX_PA_GAIN_UPDATE, |
Vatsal Bucha | 4b3e523 | 2020-07-14 05:33:06 +0530 | [diff] [blame] | 37 | WCD_BOLERO_EVT_HPHL_HD2_ENABLE, /* to enable hd2 config for hphl */ |
| 38 | WCD_BOLERO_EVT_HPHR_HD2_ENABLE, /* to enable hd2 config for hphr */ |
Laxminath Kasam | 497a651 | 2018-09-17 16:11:52 +0530 | [diff] [blame] | 39 | }; |
| 40 | |
| 41 | struct wcd_ctrl_platform_data { |
| 42 | void *handle; |
| 43 | int (*update_wcd_event)(void *handle, u16 event, u32 data); |
| 44 | int (*register_notifier)(void *handle, |
| 45 | struct notifier_block *nblock, |
| 46 | bool enable); |
| 47 | }; |
| 48 | |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 49 | struct bolero_priv { |
| 50 | struct device *dev; |
Meng Wang | 15c825d | 2018-09-06 10:49:18 +0800 | [diff] [blame] | 51 | struct snd_soc_component *component; |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 52 | struct regmap *regmap; |
| 53 | struct mutex io_lock; |
Laxminath Kasam | 2df2d61 | 2018-05-22 15:45:42 +0530 | [diff] [blame] | 54 | struct mutex clk_lock; |
Karthikeyan Mani | ac555db | 2019-07-09 12:11:23 -0700 | [diff] [blame] | 55 | struct mutex vote_lock; |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 56 | bool va_without_decimation; |
| 57 | bool macros_supported[MAX_MACRO]; |
Laxminath Kasam | fb0d683 | 2018-09-22 01:49:52 +0530 | [diff] [blame] | 58 | bool dev_up; |
| 59 | bool initial_boot; |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 60 | struct macro_ops macro_params[MAX_MACRO]; |
| 61 | struct snd_soc_dai_driver *bolero_dais; |
| 62 | u16 num_dais; |
| 63 | u16 num_macros_registered; |
Laxminath Kasam | 497a651 | 2018-09-17 16:11:52 +0530 | [diff] [blame] | 64 | u16 num_macros; |
Laxminath Kasam | 2df2d61 | 2018-05-22 15:45:42 +0530 | [diff] [blame] | 65 | u16 current_mclk_mux_macro[MAX_MACRO]; |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 66 | struct work_struct bolero_add_child_devices_work; |
Laxminath Kasam | 21c8b22 | 2018-06-21 18:47:22 +0530 | [diff] [blame] | 67 | u32 version; |
Mangesh Kunchamwar | cdd68db | 2019-01-10 16:21:00 +0530 | [diff] [blame] | 68 | struct clk *lpass_core_hw_vote; |
Sudheer Papothi | ba445bf | 2019-04-16 05:05:55 +0530 | [diff] [blame] | 69 | struct clk *lpass_audio_hw_vote; |
Karthikeyan Mani | ac555db | 2019-07-09 12:11:23 -0700 | [diff] [blame] | 70 | int core_hw_vote_count; |
| 71 | int core_audio_vote_count; |
Laxminath Kasam | 21c8b22 | 2018-06-21 18:47:22 +0530 | [diff] [blame] | 72 | |
| 73 | /* Entry for version info */ |
| 74 | struct snd_info_entry *entry; |
| 75 | struct snd_info_entry *version_entry; |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 76 | |
| 77 | int (*read_dev)(struct bolero_priv *priv, |
| 78 | u16 macro_id, u16 reg, u8 *val); |
| 79 | int (*write_dev)(struct bolero_priv *priv, |
| 80 | u16 macro_id, u16 reg, u8 val); |
Laxminath Kasam | 497a651 | 2018-09-17 16:11:52 +0530 | [diff] [blame] | 81 | struct platform_device *pdev_child_devices |
| 82 | [BOLERO_CDC_CHILD_DEVICES_MAX]; |
| 83 | u16 child_count; |
| 84 | struct wcd_ctrl_platform_data plat_data; |
| 85 | struct device *wcd_dev; |
| 86 | struct blocking_notifier_head notifier; |
Vidyakumar Athota | 5d45f4c | 2019-03-10 22:35:07 -0700 | [diff] [blame] | 87 | struct device *clk_dev; |
| 88 | rsc_clk_cb_t rsc_clk_cb; |
Sudheer Papothi | d50a581 | 2019-11-21 07:24:42 +0530 | [diff] [blame] | 89 | s32 dmic_0_1_clk_cnt; |
| 90 | s32 dmic_2_3_clk_cnt; |
| 91 | s32 dmic_4_5_clk_cnt; |
| 92 | s32 dmic_6_7_clk_cnt; |
| 93 | u8 dmic_0_1_clk_div; |
| 94 | u8 dmic_2_3_clk_div; |
| 95 | u8 dmic_4_5_clk_div; |
| 96 | u8 dmic_6_7_clk_div; |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 97 | }; |
| 98 | |
| 99 | struct regmap *bolero_regmap_init(struct device *dev, |
| 100 | const struct regmap_config *config); |
| 101 | int bolero_get_macro_id(bool va_no_dec_flag, u16 reg); |
| 102 | |
| 103 | extern const struct regmap_config bolero_regmap_config; |
| 104 | extern u8 *bolero_reg_access[MAX_MACRO]; |
| 105 | extern u8 bolero_va_top_reg_access[BOLERO_CDC_VA_MACRO_TOP_MAX]; |
Laxminath Kasam | fbd95ed | 2019-11-05 22:07:06 +0530 | [diff] [blame] | 106 | extern u8 bolero_va_reg_access_v2[BOLERO_CDC_VA_MACRO_MAX]; |
| 107 | extern u8 bolero_va_reg_access_v3[BOLERO_CDC_VA_MACRO_MAX]; |
| 108 | extern u8 bolero_tx_reg_access_v2[BOLERO_CDC_TX_MACRO_MAX]; |
Laxminath Kasam | e562a36 | 2018-04-12 00:39:08 +0530 | [diff] [blame] | 109 | extern const u16 macro_id_base_offset[MAX_MACRO]; |
| 110 | |
| 111 | #endif |