// SPDX-License-Identifier: GPL-2.0-only /* * Copyright (c) 2021 The Linux Foundation. All rights reserved. * * lpass-cdc-dma.c -- ALSA SoC CDC DMA CPU DAI driver for QTi LPASS
*/
switch (dai_id) { case LPASS_CDC_DMA_RX0 ... LPASS_CDC_DMA_RX9:
*dmactl = drvdata->rxtx_rd_dmactl;
*id = pcm_data->dma_ch; break; case LPASS_CDC_DMA_TX0 ... LPASS_CDC_DMA_TX8:
*dmactl = drvdata->rxtx_wr_dmactl;
*id = pcm_data->dma_ch - v->rxtx_wrdma_channel_start; break; case LPASS_CDC_DMA_VA_TX0 ... LPASS_CDC_DMA_VA_TX8:
*dmactl = drvdata->va_wr_dmactl;
*id = pcm_data->dma_ch - v->va_wrdma_channel_start; break; default:
dev_err(soc_runtime->dev, "invalid dai id for dma ctl: %d\n", dai_id); break;
}
}
staticint __lpass_get_codec_dma_intf_type(int dai_id)
{ int ret;
switch (dai_id) { case LPASS_CDC_DMA_RX0: case LPASS_CDC_DMA_TX0: case LPASS_CDC_DMA_VA_TX0:
ret = LPASS_CDC_DMA_INTERFACE1; break; case LPASS_CDC_DMA_RX1: case LPASS_CDC_DMA_TX1: case LPASS_CDC_DMA_VA_TX1:
ret = LPASS_CDC_DMA_INTERFACE2; break; case LPASS_CDC_DMA_RX2: case LPASS_CDC_DMA_TX2: case LPASS_CDC_DMA_VA_TX2:
ret = LPASS_CDC_DMA_INTERFACE3; break; case LPASS_CDC_DMA_RX3: case LPASS_CDC_DMA_TX3: case LPASS_CDC_DMA_VA_TX3:
ret = LPASS_CDC_DMA_INTERFACE4; break; case LPASS_CDC_DMA_RX4: case LPASS_CDC_DMA_TX4: case LPASS_CDC_DMA_VA_TX4:
ret = LPASS_CDC_DMA_INTERFACE5; break; case LPASS_CDC_DMA_RX5: case LPASS_CDC_DMA_TX5: case LPASS_CDC_DMA_VA_TX5:
ret = LPASS_CDC_DMA_INTERFACE6; break; case LPASS_CDC_DMA_RX6: case LPASS_CDC_DMA_TX6: case LPASS_CDC_DMA_VA_TX6:
ret = LPASS_CDC_DMA_INTERFACE7; break; case LPASS_CDC_DMA_RX7: case LPASS_CDC_DMA_TX7: case LPASS_CDC_DMA_VA_TX7:
ret = LPASS_CDC_DMA_INTERFACE8; break; case LPASS_CDC_DMA_RX8: case LPASS_CDC_DMA_TX8: case LPASS_CDC_DMA_VA_TX8:
ret = LPASS_CDC_DMA_INTERFACE9; break; case LPASS_CDC_DMA_RX9:
ret = LPASS_CDC_DMA_INTERFACE10; break; default:
ret = -EINVAL; break;
} return ret;
}
switch (channels) { case 1:
regval = LPASS_CDC_DMA_INTF_ONE_CHANNEL; break; case 2:
regval = LPASS_CDC_DMA_INTF_TWO_CHANNEL; break; case 4:
regval = LPASS_CDC_DMA_INTF_FOUR_CHANNEL; break; case 6:
regval = LPASS_CDC_DMA_INTF_SIX_CHANNEL; break; case 8:
regval = LPASS_CDC_DMA_INTF_EIGHT_CHANNEL; break; default:
dev_err(soc_runtime->dev, "invalid PCM config\n"); return -EINVAL;
}
__lpass_get_dmactl_handle(substream, dai, &dmactl, &id); if (!dmactl) return -EINVAL;
ret = regmap_fields_write(dmactl->codec_channel, id, regval); if (ret) {
dev_err(soc_runtime->dev, "error writing to dmactl codec_channel reg field: %d\n", ret); return ret;
} return 0;
}
staticint lpass_cdc_dma_daiops_trigger(struct snd_pcm_substream *substream, int cmd, struct snd_soc_dai *dai)
{ struct snd_soc_pcm_runtime *soc_runtime = snd_soc_substream_to_rtd(substream); struct lpaif_dmactl *dmactl = NULL; int ret = 0, id;
switch (cmd) { case SNDRV_PCM_TRIGGER_START: case SNDRV_PCM_TRIGGER_RESUME: case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
__lpass_platform_codec_intf_init(dai, substream); break; case SNDRV_PCM_TRIGGER_STOP: case SNDRV_PCM_TRIGGER_SUSPEND: case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
__lpass_get_dmactl_handle(substream, dai, &dmactl, &id); if (!dmactl) return -EINVAL;
ret = regmap_fields_write(dmactl->codec_enable, id, LPAIF_DMACTL_ENABLE_OFF); if (ret) {
dev_err(soc_runtime->dev, "error writing to dmactl codec_enable reg: %d\n", ret); return ret;
} break; default:
ret = -EINVAL;
dev_err(soc_runtime->dev, "%s: invalid %d interface\n", __func__, cmd); break;
} return ret;
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.