Lines Matching +full:mt8188 +full:- +full:topckgen

1 // SPDX-License-Identifier: GPL-2.0
8 * Chun-Chia Chiu <chun-chia.chiu@mediatek.com>
11 #include <linux/arm-smccc.h>
13 #include <linux/dma-mapping.h>
24 #include "mt8188-afe-common.h"
25 #include "mt8188-afe-clk.h"
26 #include "mt8188-reg.h"
27 #include "../common/mtk-afe-platform-driver.h"
28 #include "../common/mtk-afe-fe-dai.h"
88 return -EINVAL; in mt8188_afe_fs_timing()
94 struct snd_soc_pcm_runtime *rtd = substream->private_data; in mt8188_memif_fs()
101 int id = asoc_rtd_to_cpu(rtd, 0)->id; in mt8188_memif_fs()
104 return -EINVAL; in mt8188_memif_fs()
108 return -EINVAL; in mt8188_memif_fs()
111 memif = &afe->memif[id]; in mt8188_memif_fs()
113 switch (memif->data->id) { in mt8188_memif_fs()
124 afe_priv = afe->platform_priv; in mt8188_memif_fs()
125 memif_priv = afe_priv->dai_priv[id]; in mt8188_memif_fs()
126 if (memif_priv->fs_timing) in mt8188_memif_fs()
127 fs = memif_priv->fs_timing; in mt8188_memif_fs()
233 int id = -EINVAL; in mt8188_afe_found_cm()
235 if (mt8188_afe_memif_is_ul(dai->id) == 0) in mt8188_afe_found_cm()
238 switch (dai->id) { in mt8188_afe_found_cm()
253 dev_dbg(afe->dev, "%s, memif %d cannot find CM!\n", __func__, dai->id); in mt8188_afe_found_cm()
265 return -EINVAL; in mt8188_afe_config_cm()
267 regmap_update_bits(afe->regmap, in mt8188_afe_config_cm()
268 cm->reg, in mt8188_afe_config_cm()
269 cm->sel_maskbit << cm->sel_shift, in mt8188_afe_config_cm()
270 cm->sel_default << cm->sel_shift); in mt8188_afe_config_cm()
272 regmap_update_bits(afe->regmap, in mt8188_afe_config_cm()
273 cm->reg, in mt8188_afe_config_cm()
274 cm->ch_num_maskbit << cm->ch_num_shift, in mt8188_afe_config_cm()
275 (channels - 1) << cm->ch_num_shift); in mt8188_afe_config_cm()
277 regmap_update_bits(afe->regmap, in mt8188_afe_config_cm()
278 cm->reg, in mt8188_afe_config_cm()
279 cm->update_cnt_maskbit << cm->update_cnt_shift, in mt8188_afe_config_cm()
280 cm->update_cnt_default << cm->update_cnt_shift); in mt8188_afe_config_cm()
290 return -EINVAL; in mt8188_afe_enable_cm()
292 regmap_update_bits(afe->regmap, in mt8188_afe_enable_cm()
293 cm->reg, in mt8188_afe_enable_cm()
294 cm->en_maskbit << cm->en_shift, in mt8188_afe_enable_cm()
295 enable << cm->en_shift); in mt8188_afe_enable_cm()
303 struct snd_soc_pcm_runtime *rtd = substream->private_data; in mt8188_afe_fe_startup()
304 struct snd_pcm_runtime *runtime = substream->runtime; in mt8188_afe_fe_startup()
306 int id = asoc_rtd_to_cpu(rtd, 0)->id; in mt8188_afe_fe_startup()
322 dev_dbg(afe->dev, "hw_constraint_minmax failed\n"); in mt8188_afe_fe_startup()
337 struct snd_soc_pcm_runtime *rtd = substream->private_data; in mt8188_afe_fe_hw_params()
339 int id = asoc_rtd_to_cpu(rtd, 0)->id; in mt8188_afe_fe_hw_params()
340 struct mtk_base_afe_memif *memif = &afe->memif[id]; in mt8188_afe_fe_hw_params()
341 const struct mtk_base_memif_data *data = memif->data; in mt8188_afe_fe_hw_params()
347 if (data->ch_num_reg >= 0) { in mt8188_afe_fe_hw_params()
348 regmap_update_bits(afe->regmap, data->ch_num_reg, in mt8188_afe_fe_hw_params()
349 data->ch_num_maskbit << data->ch_num_shift, in mt8188_afe_fe_hw_params()
350 channels << data->ch_num_shift); in mt8188_afe_fe_hw_params()
361 struct snd_soc_pcm_runtime *rtd = substream->private_data; in mt8188_afe_fe_trigger()
362 struct snd_pcm_runtime * const runtime = substream->runtime; in mt8188_afe_fe_trigger()
363 int id = asoc_rtd_to_cpu(rtd, 0)->id; in mt8188_afe_fe_trigger()
364 struct mtk_base_afe_memif *memif = &afe->memif[id]; in mt8188_afe_fe_trigger()
365 struct mtk_base_afe_irq *irqs = &afe->irqs[memif->irq_usage]; in mt8188_afe_fe_trigger()
366 const struct mtk_base_irq_data *irq_data = irqs->irq_data; in mt8188_afe_fe_trigger()
367 unsigned int counter = runtime->period_size; in mt8188_afe_fe_trigger()
378 dev_err(afe->dev, "%s(), error, id %d, memif enable, ret %d\n", in mt8188_afe_fe_trigger()
384 regmap_update_bits(afe->regmap, irq_data->irq_cnt_reg, in mt8188_afe_fe_trigger()
385 irq_data->irq_cnt_maskbit << irq_data->irq_cnt_shift, in mt8188_afe_fe_trigger()
386 counter << irq_data->irq_cnt_shift); in mt8188_afe_fe_trigger()
389 fs = afe->irq_fs(substream, runtime->rate); in mt8188_afe_fe_trigger()
392 return -EINVAL; in mt8188_afe_fe_trigger()
394 if (irq_data->irq_fs_reg >= 0) in mt8188_afe_fe_trigger()
395 regmap_update_bits(afe->regmap, irq_data->irq_fs_reg, in mt8188_afe_fe_trigger()
396 irq_data->irq_fs_maskbit << irq_data->irq_fs_shift, in mt8188_afe_fe_trigger()
397 fs << irq_data->irq_fs_shift); in mt8188_afe_fe_trigger()
400 if (substream->stream == SNDRV_PCM_STREAM_CAPTURE) { in mt8188_afe_fe_trigger()
404 (runtime->channels * runtime->sample_bits - 1)) / in mt8188_afe_fe_trigger()
405 (runtime->channels * runtime->sample_bits) + 1; in mt8188_afe_fe_trigger()
407 udelay(sample_delay * 1000000 / runtime->rate); in mt8188_afe_fe_trigger()
411 regmap_set_bits(afe->regmap, irq_data->irq_en_reg, in mt8188_afe_fe_trigger()
412 BIT(irq_data->irq_en_shift)); in mt8188_afe_fe_trigger()
420 dev_err(afe->dev, "%s(), error, id %d, memif enable, ret %d\n", in mt8188_afe_fe_trigger()
425 regmap_clear_bits(afe->regmap, irq_data->irq_en_reg, in mt8188_afe_fe_trigger()
426 BIT(irq_data->irq_en_shift)); in mt8188_afe_fe_trigger()
428 regmap_write(afe->regmap, irq_data->irq_clr_reg, in mt8188_afe_fe_trigger()
429 BIT(irq_data->irq_clr_shift)); in mt8188_afe_fe_trigger()
432 return -EINVAL; in mt8188_afe_fe_trigger()
1606 struct mt8188_afe_private *afe_priv = afe->platform_priv; in mt8188_memif_1x_en_sel_put()
1608 unsigned int dai_id = kcontrol->id.device; in mt8188_memif_1x_en_sel_put()
1609 long val = ucontrol->value.integer.value[0]; in mt8188_memif_1x_en_sel_put()
1612 memif_priv = afe_priv->dai_priv[dai_id]; in mt8188_memif_1x_en_sel_put()
1614 if (val == memif_priv->asys_timing_sel) in mt8188_memif_1x_en_sel_put()
1619 memif_priv->asys_timing_sel = val; in mt8188_memif_1x_en_sel_put()
1630 struct mt8188_afe_private *afe_priv = afe->platform_priv; in mt8188_asys_irq_1x_en_sel_put()
1631 unsigned int id = kcontrol->id.device; in mt8188_asys_irq_1x_en_sel_put()
1632 long val = ucontrol->value.integer.value[0]; in mt8188_asys_irq_1x_en_sel_put()
1635 if (val == afe_priv->irq_priv[id].asys_timing_sel) in mt8188_asys_irq_1x_en_sel_put()
1640 afe_priv->irq_priv[id].asys_timing_sel = val; in mt8188_asys_irq_1x_en_sel_put()
1650 struct mt8188_afe_private *afe_priv = afe->platform_priv; in mt8188_memif_fs_timing_sel_get()
1652 unsigned int dai_id = kcontrol->id.device; in mt8188_memif_fs_timing_sel_get()
1653 struct soc_enum *e = (struct soc_enum *)kcontrol->private_value; in mt8188_memif_fs_timing_sel_get()
1655 memif_priv = afe_priv->dai_priv[dai_id]; in mt8188_memif_fs_timing_sel_get()
1657 ucontrol->value.enumerated.item[0] = in mt8188_memif_fs_timing_sel_get()
1658 snd_soc_enum_val_to_item(e, memif_priv->fs_timing); in mt8188_memif_fs_timing_sel_get()
1668 struct mt8188_afe_private *afe_priv = afe->platform_priv; in mt8188_memif_fs_timing_sel_put()
1670 unsigned int dai_id = kcontrol->id.device; in mt8188_memif_fs_timing_sel_put()
1671 struct soc_enum *e = (struct soc_enum *)kcontrol->private_value; in mt8188_memif_fs_timing_sel_put()
1672 unsigned int *item = ucontrol->value.enumerated.item; in mt8188_memif_fs_timing_sel_put()
1675 if (item[0] >= e->items) in mt8188_memif_fs_timing_sel_put()
1676 return -EINVAL; in mt8188_memif_fs_timing_sel_put()
1678 memif_priv = afe_priv->dai_priv[dai_id]; in mt8188_memif_fs_timing_sel_put()
1680 prev_item = snd_soc_enum_val_to_item(e, memif_priv->fs_timing); in mt8188_memif_fs_timing_sel_put()
1685 memif_priv->fs_timing = snd_soc_enum_item_to_val(e, item[0]); in mt8188_memif_fs_timing_sel_put()
1913 .mono_reg = -1,
1915 .int_odd_flag_reg = -1,
1940 .mono_reg = -1,
1942 .int_odd_flag_reg = -1,
1967 .mono_reg = -1,
1969 .int_odd_flag_reg = -1,
1991 .fs_reg = -1,
1994 .mono_reg = -1,
1996 .int_odd_flag_reg = -1,
2021 .mono_reg = -1,
2023 .int_odd_flag_reg = -1,
2048 .mono_reg = -1,
2050 .int_odd_flag_reg = -1,
2075 .mono_reg = -1,
2077 .int_odd_flag_reg = -1,
2099 .fs_reg = -1,
2112 .ch_num_reg = -1,
2139 .ch_num_reg = -1,
2166 .ch_num_reg = -1,
2193 .ch_num_reg = -1,
2220 .ch_num_reg = -1,
2234 .fs_reg = -1,
2247 .ch_num_reg = -1,
2274 .ch_num_reg = -1,
2301 .ch_num_reg = -1,
2328 .ch_num_reg = -1,
2341 .irq_cnt_reg = -1,
2344 .irq_fs_reg = -1,
2355 .irq_cnt_reg = -1,
2358 .irq_fs_reg = -1,
2372 .irq_fs_reg = -1,
2383 .irq_cnt_reg = -1,
2386 .irq_fs_reg = -1,
2400 .irq_fs_reg = -1,
2411 .irq_cnt_reg = -1,
2414 .irq_fs_reg = -1,
2670 /* these auto-gen reg has read-only bit, so put it as volatile */ in mt8188_is_volatile_reg()
2940 ret = regmap_read(afe->regmap, AFE_IRQ_STATUS, &val); in mt8188_afe_irq_handler()
2942 dev_err(afe->dev, "%s irq status err\n", __func__); in mt8188_afe_irq_handler()
2948 ret = regmap_read(afe->regmap, AFE_IRQ_MASK, &mcu_irq_mask); in mt8188_afe_irq_handler()
2950 dev_err(afe->dev, "%s read irq mask err\n", __func__); in mt8188_afe_irq_handler()
2960 struct mtk_base_afe_memif *memif = &afe->memif[i]; in mt8188_afe_irq_handler()
2963 if (memif->irq_usage < 0) in mt8188_afe_irq_handler()
2966 irq_data = afe->irqs[memif->irq_usage].irq_data; in mt8188_afe_irq_handler()
2968 irq_status_bits = BIT(irq_data->irq_status_shift); in mt8188_afe_irq_handler()
2969 irq_clr_bits = BIT(irq_data->irq_clr_shift); in mt8188_afe_irq_handler()
2974 if (irq_data->irq_clr_reg == ASYS_IRQ_CLR) in mt8188_afe_irq_handler()
2979 snd_pcm_period_elapsed(memif->substream); in mt8188_afe_irq_handler()
2985 regmap_write(afe->regmap, ASYS_IRQ_CLR, asys_irq_clr_bits); in mt8188_afe_irq_handler()
2987 regmap_write(afe->regmap, AFE_IRQ_MCU_CLR, afe_irq_clr_bits); in mt8188_afe_irq_handler()
2995 struct mt8188_afe_private *afe_priv = afe->platform_priv; in mt8188_afe_runtime_suspend()
2997 if (!afe->regmap || afe_priv->pm_runtime_bypass_reg_ctl) in mt8188_afe_runtime_suspend()
3002 regcache_cache_only(afe->regmap, true); in mt8188_afe_runtime_suspend()
3003 regcache_mark_dirty(afe->regmap); in mt8188_afe_runtime_suspend()
3014 struct mt8188_afe_private *afe_priv = afe->platform_priv; in mt8188_afe_runtime_resume()
3023 if (!afe->regmap || afe_priv->pm_runtime_bypass_reg_ctl) in mt8188_afe_runtime_resume()
3026 regcache_cache_only(afe->regmap, false); in mt8188_afe_runtime_resume()
3027 regcache_sync(afe->regmap); in mt8188_afe_runtime_resume()
3039 snd_soc_component_init_regmap(component, afe->regmap); in mt8188_afe_component_probe()
3055 struct mt8188_afe_private *afe_priv = afe->platform_priv; in init_memif_priv_data()
3060 memif_priv = devm_kzalloc(afe->dev, in init_memif_priv_data()
3064 return -ENOMEM; in init_memif_priv_data()
3066 afe_priv->dai_priv[i] = memif_priv; in init_memif_priv_data()
3076 dai = devm_kzalloc(afe->dev, sizeof(*dai), GFP_KERNEL); in mt8188_dai_memif_register()
3078 return -ENOMEM; in mt8188_dai_memif_register()
3080 list_add(&dai->list, &afe->sub_dais); in mt8188_dai_memif_register()
3082 dai->dai_drivers = mt8188_memif_dai_driver; in mt8188_dai_memif_register()
3083 dai->num_dai_drivers = ARRAY_SIZE(mt8188_memif_dai_driver); in mt8188_dai_memif_register()
3085 dai->dapm_widgets = mt8188_memif_widgets; in mt8188_dai_memif_register()
3086 dai->num_dapm_widgets = ARRAY_SIZE(mt8188_memif_widgets); in mt8188_dai_memif_register()
3087 dai->dapm_routes = mt8188_memif_routes; in mt8188_dai_memif_register()
3088 dai->num_dapm_routes = ARRAY_SIZE(mt8188_memif_routes); in mt8188_dai_memif_register()
3089 dai->controls = mt8188_memif_controls; in mt8188_dai_memif_register()
3090 dai->num_controls = ARRAY_SIZE(mt8188_memif_controls); in mt8188_dai_memif_register()
3118 return regmap_multi_reg_write(afe->regmap, in mt8188_afe_init_registers()
3127 struct mt8188_afe_private *afe_priv = afe->platform_priv; in mt8188_afe_parse_of()
3129 afe_priv->topckgen = syscon_regmap_lookup_by_phandle(afe->dev->of_node, in mt8188_afe_parse_of()
3130 "mediatek,topckgen"); in mt8188_afe_parse_of()
3131 if (IS_ERR(afe_priv->topckgen)) in mt8188_afe_parse_of()
3132 return dev_err_probe(afe->dev, PTR_ERR(afe_priv->topckgen), in mt8188_afe_parse_of()
3133 "%s() Cannot find topckgen controller\n", in mt8188_afe_parse_of()
3198 struct device *dev = &pdev->dev; in mt8188_afe_pcm_dev_probe()
3207 ret = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(33)); in mt8188_afe_pcm_dev_probe()
3211 afe = devm_kzalloc(&pdev->dev, sizeof(*afe), GFP_KERNEL); in mt8188_afe_pcm_dev_probe()
3213 return -ENOMEM; in mt8188_afe_pcm_dev_probe()
3215 afe->platform_priv = devm_kzalloc(&pdev->dev, sizeof(*afe_priv), in mt8188_afe_pcm_dev_probe()
3217 if (!afe->platform_priv) in mt8188_afe_pcm_dev_probe()
3218 return -ENOMEM; in mt8188_afe_pcm_dev_probe()
3220 afe_priv = afe->platform_priv; in mt8188_afe_pcm_dev_probe()
3221 afe->dev = &pdev->dev; in mt8188_afe_pcm_dev_probe()
3223 afe->base_addr = devm_platform_ioremap_resource(pdev, 0); in mt8188_afe_pcm_dev_probe()
3224 if (IS_ERR(afe->base_addr)) in mt8188_afe_pcm_dev_probe()
3225 return dev_err_probe(dev, PTR_ERR(afe->base_addr), in mt8188_afe_pcm_dev_probe()
3228 infra_ao = syscon_regmap_lookup_by_phandle(dev->of_node, in mt8188_afe_pcm_dev_probe()
3264 spin_lock_init(&afe_priv->afe_ctrl_lock); in mt8188_afe_pcm_dev_probe()
3266 mutex_init(&afe->irq_alloc_lock); in mt8188_afe_pcm_dev_probe()
3269 afe->irqs_size = MT8188_AFE_IRQ_NUM; in mt8188_afe_pcm_dev_probe()
3270 afe->irqs = devm_kcalloc(dev, afe->irqs_size, sizeof(*afe->irqs), in mt8188_afe_pcm_dev_probe()
3272 if (!afe->irqs) in mt8188_afe_pcm_dev_probe()
3273 return -ENOMEM; in mt8188_afe_pcm_dev_probe()
3275 for (i = 0; i < afe->irqs_size; i++) in mt8188_afe_pcm_dev_probe()
3276 afe->irqs[i].irq_data = &irq_data[i]; in mt8188_afe_pcm_dev_probe()
3279 afe->memif_size = MT8188_AFE_MEMIF_NUM; in mt8188_afe_pcm_dev_probe()
3280 afe->memif = devm_kcalloc(dev, afe->memif_size, sizeof(*afe->memif), in mt8188_afe_pcm_dev_probe()
3282 if (!afe->memif) in mt8188_afe_pcm_dev_probe()
3283 return -ENOMEM; in mt8188_afe_pcm_dev_probe()
3285 for (i = 0; i < afe->memif_size; i++) { in mt8188_afe_pcm_dev_probe()
3286 afe->memif[i].data = &memif_data[i]; in mt8188_afe_pcm_dev_probe()
3287 afe->memif[i].irq_usage = mt8188_afe_memif_const_irqs[i]; in mt8188_afe_pcm_dev_probe()
3288 afe->memif[i].const_irq = 1; in mt8188_afe_pcm_dev_probe()
3289 afe->irqs[afe->memif[i].irq_usage].irq_occupyed = true; in mt8188_afe_pcm_dev_probe()
3298 IRQF_TRIGGER_NONE, "asys-isr", (void *)afe); in mt8188_afe_pcm_dev_probe()
3300 return dev_err_probe(dev, ret, "could not request_irq for asys-isr\n"); in mt8188_afe_pcm_dev_probe()
3303 INIT_LIST_HEAD(&afe->sub_dais); in mt8188_afe_pcm_dev_probe()
3316 afe->mtk_afe_hardware = &mt8188_afe_hardware; in mt8188_afe_pcm_dev_probe()
3317 afe->memif_fs = mt8188_memif_fs; in mt8188_afe_pcm_dev_probe()
3318 afe->irq_fs = mt8188_irq_fs; in mt8188_afe_pcm_dev_probe()
3320 afe->runtime_resume = mt8188_afe_runtime_resume; in mt8188_afe_pcm_dev_probe()
3321 afe->runtime_suspend = mt8188_afe_runtime_suspend; in mt8188_afe_pcm_dev_probe()
3325 ret = mt8188_afe_parse_of(afe, pdev->dev.of_node); in mt8188_afe_pcm_dev_probe()
3334 afe_priv->pm_runtime_bypass_reg_ctl = true; in mt8188_afe_pcm_dev_probe()
3339 afe->regmap = devm_regmap_init_mmio(&pdev->dev, afe->base_addr, in mt8188_afe_pcm_dev_probe()
3341 if (IS_ERR(afe->regmap)) { in mt8188_afe_pcm_dev_probe()
3342 ret = PTR_ERR(afe->regmap); in mt8188_afe_pcm_dev_probe()
3346 ret = regmap_register_patch(afe->regmap, mt8188_cg_patch, in mt8188_afe_pcm_dev_probe()
3355 afe->dai_drivers, afe->num_dai_drivers); in mt8188_afe_pcm_dev_probe()
3363 pm_runtime_put_sync(&pdev->dev); in mt8188_afe_pcm_dev_probe()
3364 afe_priv->pm_runtime_bypass_reg_ctl = false; in mt8188_afe_pcm_dev_probe()
3366 regcache_cache_only(afe->regmap, true); in mt8188_afe_pcm_dev_probe()
3367 regcache_mark_dirty(afe->regmap); in mt8188_afe_pcm_dev_probe()
3377 { .compatible = "mediatek,mt8188-afe", },
3389 .name = "mt8188-audio",
3399 MODULE_AUTHOR("Chun-Chia.Chiu <chun-chia.chiu@mediatek.com>");