Commit 1fddf424 authored by Kuninori Morimoto's avatar Kuninori Morimoto Committed by Mark Brown

ASoC: mediatek: remove snd_pcm_ops

snd_pcm_ops is no longer needed.
Let's use component driver callback.
Signed-off-by: default avatarKuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Link: https://lore.kernel.org/r/87k19n90du.wl-kuninori.morimoto.gx@renesas.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 9a0b72b7
...@@ -77,11 +77,10 @@ int mtk_afe_add_sub_dai_control(struct snd_soc_component *component) ...@@ -77,11 +77,10 @@ int mtk_afe_add_sub_dai_control(struct snd_soc_component *component)
} }
EXPORT_SYMBOL_GPL(mtk_afe_add_sub_dai_control); EXPORT_SYMBOL_GPL(mtk_afe_add_sub_dai_control);
static snd_pcm_uframes_t mtk_afe_pcm_pointer snd_pcm_uframes_t mtk_afe_pcm_pointer(struct snd_soc_component *component,
(struct snd_pcm_substream *substream) struct snd_pcm_substream *substream)
{ {
struct snd_soc_pcm_runtime *rtd = substream->private_data; struct snd_soc_pcm_runtime *rtd = substream->private_data;
struct snd_soc_component *component = snd_soc_rtdcom_lookup(rtd, AFE_PCM_NAME);
struct mtk_base_afe *afe = snd_soc_component_get_drvdata(component); struct mtk_base_afe *afe = snd_soc_component_get_drvdata(component);
struct mtk_base_afe_memif *memif = &afe->memif[rtd->cpu_dai->id]; struct mtk_base_afe_memif *memif = &afe->memif[rtd->cpu_dai->id];
const struct mtk_base_memif_data *memif_data = memif->data; const struct mtk_base_memif_data *memif_data = memif->data;
...@@ -111,18 +110,13 @@ static snd_pcm_uframes_t mtk_afe_pcm_pointer ...@@ -111,18 +110,13 @@ static snd_pcm_uframes_t mtk_afe_pcm_pointer
POINTER_RETURN_FRAMES: POINTER_RETURN_FRAMES:
return bytes_to_frames(substream->runtime, pcm_ptr_bytes); return bytes_to_frames(substream->runtime, pcm_ptr_bytes);
} }
EXPORT_SYMBOL_GPL(mtk_afe_pcm_pointer);
const struct snd_pcm_ops mtk_afe_pcm_ops = { int mtk_afe_pcm_new(struct snd_soc_component *component,
.ioctl = snd_pcm_lib_ioctl, struct snd_soc_pcm_runtime *rtd)
.pointer = mtk_afe_pcm_pointer,
};
EXPORT_SYMBOL_GPL(mtk_afe_pcm_ops);
int mtk_afe_pcm_new(struct snd_soc_pcm_runtime *rtd)
{ {
size_t size; size_t size;
struct snd_pcm *pcm = rtd->pcm; struct snd_pcm *pcm = rtd->pcm;
struct snd_soc_component *component = snd_soc_rtdcom_lookup(rtd, AFE_PCM_NAME);
struct mtk_base_afe *afe = snd_soc_component_get_drvdata(component); struct mtk_base_afe *afe = snd_soc_component_get_drvdata(component);
size = afe->mtk_afe_hardware->buffer_bytes_max; size = afe->mtk_afe_hardware->buffer_bytes_max;
...@@ -132,17 +126,19 @@ int mtk_afe_pcm_new(struct snd_soc_pcm_runtime *rtd) ...@@ -132,17 +126,19 @@ int mtk_afe_pcm_new(struct snd_soc_pcm_runtime *rtd)
} }
EXPORT_SYMBOL_GPL(mtk_afe_pcm_new); EXPORT_SYMBOL_GPL(mtk_afe_pcm_new);
void mtk_afe_pcm_free(struct snd_pcm *pcm) void mtk_afe_pcm_free(struct snd_soc_component *component,
struct snd_pcm *pcm)
{ {
snd_pcm_lib_preallocate_free_for_all(pcm); snd_pcm_lib_preallocate_free_for_all(pcm);
} }
EXPORT_SYMBOL_GPL(mtk_afe_pcm_free); EXPORT_SYMBOL_GPL(mtk_afe_pcm_free);
const struct snd_soc_component_driver mtk_afe_pcm_platform = { const struct snd_soc_component_driver mtk_afe_pcm_platform = {
.name = AFE_PCM_NAME, .name = AFE_PCM_NAME,
.ops = &mtk_afe_pcm_ops, .ioctl = snd_soc_pcm_lib_ioctl,
.pcm_new = mtk_afe_pcm_new, .pointer = mtk_afe_pcm_pointer,
.pcm_free = mtk_afe_pcm_free, .pcm_construct = mtk_afe_pcm_new,
.pcm_destruct = mtk_afe_pcm_free,
}; };
EXPORT_SYMBOL_GPL(mtk_afe_pcm_platform); EXPORT_SYMBOL_GPL(mtk_afe_pcm_platform);
......
...@@ -10,7 +10,6 @@ ...@@ -10,7 +10,6 @@
#define _MTK_AFE_PLATFORM_DRIVER_H_ #define _MTK_AFE_PLATFORM_DRIVER_H_
#define AFE_PCM_NAME "mtk-afe-pcm" #define AFE_PCM_NAME "mtk-afe-pcm"
extern const struct snd_pcm_ops mtk_afe_pcm_ops;
extern const struct snd_soc_component_driver mtk_afe_pcm_platform; extern const struct snd_soc_component_driver mtk_afe_pcm_platform;
struct mtk_base_afe; struct mtk_base_afe;
...@@ -18,9 +17,12 @@ struct snd_pcm; ...@@ -18,9 +17,12 @@ struct snd_pcm;
struct snd_soc_component; struct snd_soc_component;
struct snd_soc_pcm_runtime; struct snd_soc_pcm_runtime;
snd_pcm_uframes_t mtk_afe_pcm_pointer(struct snd_soc_component *component,
int mtk_afe_pcm_new(struct snd_soc_pcm_runtime *rtd); struct snd_pcm_substream *substream);
void mtk_afe_pcm_free(struct snd_pcm *pcm); int mtk_afe_pcm_new(struct snd_soc_component *component,
struct snd_soc_pcm_runtime *rtd);
void mtk_afe_pcm_free(struct snd_soc_component *component,
struct snd_pcm *pcm);
int mtk_afe_combine_sub_dai(struct mtk_base_afe *afe); int mtk_afe_combine_sub_dai(struct mtk_base_afe *afe);
int mtk_afe_add_sub_dai_control(struct snd_soc_component *component); int mtk_afe_add_sub_dai_control(struct snd_soc_component *component);
......
...@@ -710,11 +710,12 @@ static int mt6797_afe_component_probe(struct snd_soc_component *component) ...@@ -710,11 +710,12 @@ static int mt6797_afe_component_probe(struct snd_soc_component *component)
} }
static const struct snd_soc_component_driver mt6797_afe_component = { static const struct snd_soc_component_driver mt6797_afe_component = {
.name = AFE_PCM_NAME, .name = AFE_PCM_NAME,
.ops = &mtk_afe_pcm_ops, .probe = mt6797_afe_component_probe,
.pcm_new = mtk_afe_pcm_new, .ioctl = snd_soc_pcm_lib_ioctl,
.pcm_free = mtk_afe_pcm_free, .pointer = mtk_afe_pcm_pointer,
.probe = mt6797_afe_component_probe, .pcm_construct = mtk_afe_pcm_new,
.pcm_destruct = mtk_afe_pcm_free,
}; };
static int mt6797_dai_memif_register(struct mtk_base_afe *afe) static int mt6797_dai_memif_register(struct mtk_base_afe *afe)
......
...@@ -1048,11 +1048,12 @@ static int mt8183_afe_component_probe(struct snd_soc_component *component) ...@@ -1048,11 +1048,12 @@ static int mt8183_afe_component_probe(struct snd_soc_component *component)
} }
static const struct snd_soc_component_driver mt8183_afe_component = { static const struct snd_soc_component_driver mt8183_afe_component = {
.name = AFE_PCM_NAME, .name = AFE_PCM_NAME,
.ops = &mtk_afe_pcm_ops, .probe = mt8183_afe_component_probe,
.pcm_new = mtk_afe_pcm_new, .ioctl = snd_soc_pcm_lib_ioctl,
.pcm_free = mtk_afe_pcm_free, .pointer = mtk_afe_pcm_pointer,
.probe = mt8183_afe_component_probe, .pcm_construct = mtk_afe_pcm_new,
.pcm_destruct = mtk_afe_pcm_free,
}; };
static int mt8183_dai_memif_register(struct mtk_base_afe *afe) static int mt8183_dai_memif_register(struct mtk_base_afe *afe)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment