forked from luck/tmp_suning_uos_patched
ASoC: mediatek: remove snd_pcm_ops
snd_pcm_ops is no longer needed. Let's use component driver callback. Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Link: https://lore.kernel.org/r/87k19n90du.wl-kuninori.morimoto.gx@renesas.com Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
9a0b72b71d
commit
1fddf424b3
|
@ -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
|
||||||
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)
|
||||||
}
|
}
|
||||||
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 @@
|
||||||
#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;
|
||||||
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)
|
||||||
}
|
}
|
||||||
|
|
||||||
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)
|
||||||
}
|
}
|
||||||
|
|
||||||
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)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user