mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-06 10:58:48 +09:00
UPSTREAM: ASoC: soc-pcm: align BE 'atomicity' with that of the FE
[ Upstream commitbbf7d3b1c4] Since the flow for DPCM is based on taking a lock for the FE first, we need to make sure during the connection between a BE and an FE that they both use the same 'atomicity', otherwise we may sleep in atomic context. If the FE is nonatomic, this patch forces the BE to be nonatomic as well. That should have no negative impact since the BE 'inherits' the FE properties. However, if the FE is atomic and the BE is not, then the configuration is flagged as invalid. Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> [ removed FE stream lock by tiwai ] Signed-off-by: Takashi Iwai <tiwai@suse.de> Reviewed-by: Kai Vehmanen <kai.vehmanen@linux.intel.com> Reviewed-by: Bard Liao <yung-chuan.liao@linux.intel.com> Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com> Link: https://lore.kernel.org/r/20211207173745.15850-3-pierre-louis.bossart@linux.intel.com Signed-off-by: Mark Brown <broonie@kernel.org> Fixes:aa9ff6a495("ASoC: soc-compress: Reposition and add pcm_mutex") Signed-off-by: Yixuan Jiang <yixuanjiang@google.com> Cc: stable@vger.kernel.org # 5.15+ Bug: 277241308 Link: https://lore.kernel.org/all/20230511120841.2096524-3-yixuanjiang@google.com Change-Id: I91c5894d2a22b86c2d8af2d19d9f4364210abd36 Signed-off-by: Yixuan Jiang <yixuanjiang@google.com>
This commit is contained in:
committed by
Matthias Männich
parent
13344864f0
commit
06e574fc9a
@@ -1123,6 +1123,8 @@ static snd_pcm_uframes_t soc_pcm_pointer(struct snd_pcm_substream *substream)
|
||||
static int dpcm_be_connect(struct snd_soc_pcm_runtime *fe,
|
||||
struct snd_soc_pcm_runtime *be, int stream)
|
||||
{
|
||||
struct snd_pcm_substream *fe_substream;
|
||||
struct snd_pcm_substream *be_substream;
|
||||
struct snd_soc_dpcm *dpcm;
|
||||
unsigned long flags;
|
||||
|
||||
@@ -1132,6 +1134,20 @@ static int dpcm_be_connect(struct snd_soc_pcm_runtime *fe,
|
||||
return 0;
|
||||
}
|
||||
|
||||
fe_substream = snd_soc_dpcm_get_substream(fe, stream);
|
||||
be_substream = snd_soc_dpcm_get_substream(be, stream);
|
||||
|
||||
if (!fe_substream->pcm->nonatomic && be_substream->pcm->nonatomic) {
|
||||
dev_err(be->dev, "%s: FE is atomic but BE is nonatomic, invalid configuration\n",
|
||||
__func__);
|
||||
return -EINVAL;
|
||||
}
|
||||
if (fe_substream->pcm->nonatomic && !be_substream->pcm->nonatomic) {
|
||||
dev_warn(be->dev, "%s: FE is nonatomic but BE is not, forcing BE as nonatomic\n",
|
||||
__func__);
|
||||
be_substream->pcm->nonatomic = 1;
|
||||
}
|
||||
|
||||
dpcm = kzalloc(sizeof(struct snd_soc_dpcm), GFP_ATOMIC);
|
||||
if (!dpcm)
|
||||
return -ENOMEM;
|
||||
|
||||
Reference in New Issue
Block a user