* Re: [PATCH] dma: pl330: Add support for DMA_PAUSE command [not found] ` <CAHbNUh1bmBniGVtvK4PpmpaKOnwG=MgtupkTEnjD6SS3r_-yjw@mail.gmail.com> @ 2014-05-15 19:21 ` Lars-Peter Clausen 2014-05-16 5:49 ` Takashi Iwai 2014-05-19 3:10 ` Tushar Behera 0 siblings, 2 replies; 7+ messages in thread From: Lars-Peter Clausen @ 2014-05-15 19:21 UTC (permalink / raw) To: Tushar Behera Cc: Linux-ALSA, Vinod Koul, Jassi Brar, Linux Kernel Mailing List, Takashi Iwai, dmaengine, Dan Williams On 05/15/2014 02:01 PM, Tushar Behera wrote: > On 14 May 2014 17:54, Lars-Peter Clausen <lars@metafoo.de> wrote: >> On 05/14/2014 02:07 PM, Tushar Behera wrote: >>> >>> On 14 May 2014 17:29, Jassi Brar <jassisinghbrar@gmail.com> wrote: >>>> >>>> On Wed, May 14, 2014 at 8:53 AM, Tushar Behera <tushar.behera@linaro.org> >>>> wrote: >>>>> >>>>> While playing back audio, pmc_dmaengine requests the DMA channel to >>>>> stop DMA transmission through DMA_PAUSE command. >>>>> >>>>> Currently PL330 driver doesn't support DMA pause command, leaving >>>>> the DMA state inconsistent when the system resumes. Instead, it would >>>>> be better to terminate the DMA transfer during suspend and restart >>>>> again during resume. >>>>> >>>>> Tested with audio playback across a suspend-resume cycle. >>>>> >>>> What is pmc_dmaengine? How does DMA_PAUSE help, when there is no >>>> DMA_RESUME? >>>> >>> >>> Sorry, it is a typo. >>> >>> sound/core/pcm_dmaengine.c:snd_dmaengine_pcm_trigger() --> >>> dmaengine_pause() is called during system suspend. >> >> >> It is only called if the DMA driver has support for pausing and resuming DMA >> transfers. Or at least that is the intention. >> >> - Lars > > During suspend, snd_dmaengine_pcm_trigger():SNDRV_PCM_TRIGGER_SUSPEND > is called which unconditionally calls dmaengine_pause(). Should we > update snd_dmaengine_pcm_trigger() to check for DMA pause/resume > support and call dmaengine_pause() or dmaengine_terminate_all() > accordingly? As far as I understand it we do not have to do anything for TRIGGER_SUSPEND if we do not set the SNDRV_PCM_INFO_RESUME flag. It looks like TRIGGER_SUSPEND is called unconditionally during suspend. But since the error code is ignored it should be fine if we just call dmaengine_pause() and that return -ENOSYS or similar. Are you seeing an actual issue that you are trying to fix with your patch? - Lars ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] dma: pl330: Add support for DMA_PAUSE command 2014-05-15 19:21 ` [PATCH] dma: pl330: Add support for DMA_PAUSE command Lars-Peter Clausen @ 2014-05-16 5:49 ` Takashi Iwai 2014-05-16 10:51 ` Lars-Peter Clausen 2014-05-19 3:10 ` Tushar Behera 1 sibling, 1 reply; 7+ messages in thread From: Takashi Iwai @ 2014-05-16 5:49 UTC (permalink / raw) To: Lars-Peter Clausen Cc: Linux-ALSA, Vinod Koul, Jassi Brar, Linux Kernel Mailing List, dmaengine, Dan Williams, Tushar Behera At Thu, 15 May 2014 21:21:12 +0200, Lars-Peter Clausen wrote: > > On 05/15/2014 02:01 PM, Tushar Behera wrote: > > On 14 May 2014 17:54, Lars-Peter Clausen <lars@metafoo.de> wrote: > >> On 05/14/2014 02:07 PM, Tushar Behera wrote: > >>> > >>> On 14 May 2014 17:29, Jassi Brar <jassisinghbrar@gmail.com> wrote: > >>>> > >>>> On Wed, May 14, 2014 at 8:53 AM, Tushar Behera <tushar.behera@linaro.org> > >>>> wrote: > >>>>> > >>>>> While playing back audio, pmc_dmaengine requests the DMA channel to > >>>>> stop DMA transmission through DMA_PAUSE command. > >>>>> > >>>>> Currently PL330 driver doesn't support DMA pause command, leaving > >>>>> the DMA state inconsistent when the system resumes. Instead, it would > >>>>> be better to terminate the DMA transfer during suspend and restart > >>>>> again during resume. > >>>>> > >>>>> Tested with audio playback across a suspend-resume cycle. > >>>>> > >>>> What is pmc_dmaengine? How does DMA_PAUSE help, when there is no > >>>> DMA_RESUME? > >>>> > >>> > >>> Sorry, it is a typo. > >>> > >>> sound/core/pcm_dmaengine.c:snd_dmaengine_pcm_trigger() --> > >>> dmaengine_pause() is called during system suspend. > >> > >> > >> It is only called if the DMA driver has support for pausing and resuming DMA > >> transfers. Or at least that is the intention. > >> > >> - Lars > > > > During suspend, snd_dmaengine_pcm_trigger():SNDRV_PCM_TRIGGER_SUSPEND > > is called which unconditionally calls dmaengine_pause(). Should we > > update snd_dmaengine_pcm_trigger() to check for DMA pause/resume > > support and call dmaengine_pause() or dmaengine_terminate_all() > > accordingly? > > As far as I understand it we do not have to do anything for TRIGGER_SUSPEND > if we do not set the SNDRV_PCM_INFO_RESUME flag. It looks like > TRIGGER_SUSPEND is called unconditionally during suspend. But since the > error code is ignored it should be fine if we just call dmaengine_pause() > and that return -ENOSYS or similar. Well, TRIGGER_SUSPEND is issued by PCM core no matter whether SNDRV_PCM_INFO_RESUME flag is set or not. The resume behavior depends on the flag (SNDRV_PCM_TRIGGER_RESUME is issued if the flag is set, otherwise the normal setup is done by alsa-lib at resume), but the suspend is always triggered in the same way. So, PCM core assumes that the driver stops the stream somehow by SNDRV_PCM_TRIGGER_SUSPEND. Takashi ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] dma: pl330: Add support for DMA_PAUSE command 2014-05-16 5:49 ` Takashi Iwai @ 2014-05-16 10:51 ` Lars-Peter Clausen 2014-05-19 8:37 ` [alsa-devel] " Takashi Iwai 0 siblings, 1 reply; 7+ messages in thread From: Lars-Peter Clausen @ 2014-05-16 10:51 UTC (permalink / raw) To: Takashi Iwai Cc: Linux-ALSA, Vinod Koul, Jassi Brar, Linux Kernel Mailing List, dmaengine, Dan Williams, Tushar Behera On 05/16/2014 07:49 AM, Takashi Iwai wrote: > At Thu, 15 May 2014 21:21:12 +0200, > Lars-Peter Clausen wrote: >> >> On 05/15/2014 02:01 PM, Tushar Behera wrote: >>> On 14 May 2014 17:54, Lars-Peter Clausen <lars@metafoo.de> wrote: >>>> On 05/14/2014 02:07 PM, Tushar Behera wrote: >>>>> >>>>> On 14 May 2014 17:29, Jassi Brar <jassisinghbrar@gmail.com> wrote: >>>>>> >>>>>> On Wed, May 14, 2014 at 8:53 AM, Tushar Behera <tushar.behera@linaro.org> >>>>>> wrote: >>>>>>> >>>>>>> While playing back audio, pmc_dmaengine requests the DMA channel to >>>>>>> stop DMA transmission through DMA_PAUSE command. >>>>>>> >>>>>>> Currently PL330 driver doesn't support DMA pause command, leaving >>>>>>> the DMA state inconsistent when the system resumes. Instead, it would >>>>>>> be better to terminate the DMA transfer during suspend and restart >>>>>>> again during resume. >>>>>>> >>>>>>> Tested with audio playback across a suspend-resume cycle. >>>>>>> >>>>>> What is pmc_dmaengine? How does DMA_PAUSE help, when there is no >>>>>> DMA_RESUME? >>>>>> >>>>> >>>>> Sorry, it is a typo. >>>>> >>>>> sound/core/pcm_dmaengine.c:snd_dmaengine_pcm_trigger() --> >>>>> dmaengine_pause() is called during system suspend. >>>> >>>> >>>> It is only called if the DMA driver has support for pausing and resuming DMA >>>> transfers. Or at least that is the intention. >>>> >>>> - Lars >>> >>> During suspend, snd_dmaengine_pcm_trigger():SNDRV_PCM_TRIGGER_SUSPEND >>> is called which unconditionally calls dmaengine_pause(). Should we >>> update snd_dmaengine_pcm_trigger() to check for DMA pause/resume >>> support and call dmaengine_pause() or dmaengine_terminate_all() >>> accordingly? >> >> As far as I understand it we do not have to do anything for TRIGGER_SUSPEND >> if we do not set the SNDRV_PCM_INFO_RESUME flag. It looks like >> TRIGGER_SUSPEND is called unconditionally during suspend. But since the >> error code is ignored it should be fine if we just call dmaengine_pause() >> and that return -ENOSYS or similar. > > Well, TRIGGER_SUSPEND is issued by PCM core no matter whether > SNDRV_PCM_INFO_RESUME flag is set or not. The resume behavior depends > on the flag (SNDRV_PCM_TRIGGER_RESUME is issued if the flag is set, > otherwise the normal setup is done by alsa-lib at resume), but the > suspend is always triggered in the same way. > > So, PCM core assumes that the driver stops the stream somehow by > SNDRV_PCM_TRIGGER_SUSPEND. Ok, so we should call terminate_all() when we get a SNDRV_PCM_TRIGGER_SUSPEND if the dmaengine driver does not support pauseing the transfer. Thanks for the clarification. On a related note it seems like it is still possible to get PAUSE_PUSH/PAUSE_RELEASE events even if SNDRV_PCM_INFO_PAUSE is not set. Do you have an idea what should be the right thing to do in such a case? Return -ENOSYS? - Lars ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [alsa-devel] [PATCH] dma: pl330: Add support for DMA_PAUSE command 2014-05-16 10:51 ` Lars-Peter Clausen @ 2014-05-19 8:37 ` Takashi Iwai 2014-05-19 8:43 ` Lars-Peter Clausen 0 siblings, 1 reply; 7+ messages in thread From: Takashi Iwai @ 2014-05-19 8:37 UTC (permalink / raw) To: Lars-Peter Clausen Cc: Linux-ALSA, Vinod Koul, Jassi Brar, Linux Kernel Mailing List, dmaengine, Dan Williams, Tushar Behera At Fri, 16 May 2014 12:51:51 +0200, Lars-Peter Clausen wrote: > > On 05/16/2014 07:49 AM, Takashi Iwai wrote: > > At Thu, 15 May 2014 21:21:12 +0200, > > Lars-Peter Clausen wrote: > >> > >> On 05/15/2014 02:01 PM, Tushar Behera wrote: > >>> On 14 May 2014 17:54, Lars-Peter Clausen <lars@metafoo.de> wrote: > >>>> On 05/14/2014 02:07 PM, Tushar Behera wrote: > >>>>> > >>>>> On 14 May 2014 17:29, Jassi Brar <jassisinghbrar@gmail.com> wrote: > >>>>>> > >>>>>> On Wed, May 14, 2014 at 8:53 AM, Tushar Behera <tushar.behera@linaro.org> > >>>>>> wrote: > >>>>>>> > >>>>>>> While playing back audio, pmc_dmaengine requests the DMA channel to > >>>>>>> stop DMA transmission through DMA_PAUSE command. > >>>>>>> > >>>>>>> Currently PL330 driver doesn't support DMA pause command, leaving > >>>>>>> the DMA state inconsistent when the system resumes. Instead, it would > >>>>>>> be better to terminate the DMA transfer during suspend and restart > >>>>>>> again during resume. > >>>>>>> > >>>>>>> Tested with audio playback across a suspend-resume cycle. > >>>>>>> > >>>>>> What is pmc_dmaengine? How does DMA_PAUSE help, when there is no > >>>>>> DMA_RESUME? > >>>>>> > >>>>> > >>>>> Sorry, it is a typo. > >>>>> > >>>>> sound/core/pcm_dmaengine.c:snd_dmaengine_pcm_trigger() --> > >>>>> dmaengine_pause() is called during system suspend. > >>>> > >>>> > >>>> It is only called if the DMA driver has support for pausing and resuming DMA > >>>> transfers. Or at least that is the intention. > >>>> > >>>> - Lars > >>> > >>> During suspend, snd_dmaengine_pcm_trigger():SNDRV_PCM_TRIGGER_SUSPEND > >>> is called which unconditionally calls dmaengine_pause(). Should we > >>> update snd_dmaengine_pcm_trigger() to check for DMA pause/resume > >>> support and call dmaengine_pause() or dmaengine_terminate_all() > >>> accordingly? > >> > >> As far as I understand it we do not have to do anything for TRIGGER_SUSPEND > >> if we do not set the SNDRV_PCM_INFO_RESUME flag. It looks like > >> TRIGGER_SUSPEND is called unconditionally during suspend. But since the > >> error code is ignored it should be fine if we just call dmaengine_pause() > >> and that return -ENOSYS or similar. > > > > Well, TRIGGER_SUSPEND is issued by PCM core no matter whether > > SNDRV_PCM_INFO_RESUME flag is set or not. The resume behavior depends > > on the flag (SNDRV_PCM_TRIGGER_RESUME is issued if the flag is set, > > otherwise the normal setup is done by alsa-lib at resume), but the > > suspend is always triggered in the same way. > > > > So, PCM core assumes that the driver stops the stream somehow by > > SNDRV_PCM_TRIGGER_SUSPEND. > > Ok, so we should call terminate_all() when we get a > SNDRV_PCM_TRIGGER_SUSPEND if the dmaengine driver does not support pauseing > the transfer. Thanks for the clarification. > > On a related note it seems like it is still possible to get > PAUSE_PUSH/PAUSE_RELEASE events even if SNDRV_PCM_INFO_PAUSE is not set. Do > you have an idea what should be the right thing to do in such a case? Return > -ENOSYS? That's weird. We have already a check in snd_pcm_pre_pause() in pcm_native.c to filter only for substreams with SNDRV_PCM_INFO_PAUSE flag. Could you check in which code path it is triggered? thanks, Takashi ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [alsa-devel] [PATCH] dma: pl330: Add support for DMA_PAUSE command 2014-05-19 8:37 ` [alsa-devel] " Takashi Iwai @ 2014-05-19 8:43 ` Lars-Peter Clausen 0 siblings, 0 replies; 7+ messages in thread From: Lars-Peter Clausen @ 2014-05-19 8:43 UTC (permalink / raw) To: Takashi Iwai Cc: Linux-ALSA, Vinod Koul, Jassi Brar, Linux Kernel Mailing List, dmaengine, Dan Williams, Tushar Behera On 05/19/2014 10:37 AM, Takashi Iwai wrote: > At Fri, 16 May 2014 12:51:51 +0200, > Lars-Peter Clausen wrote: >> >> On 05/16/2014 07:49 AM, Takashi Iwai wrote: >>> At Thu, 15 May 2014 21:21:12 +0200, >>> Lars-Peter Clausen wrote: >>>> >>>> On 05/15/2014 02:01 PM, Tushar Behera wrote: >>>>> On 14 May 2014 17:54, Lars-Peter Clausen <lars@metafoo.de> wrote: >>>>>> On 05/14/2014 02:07 PM, Tushar Behera wrote: >>>>>>> >>>>>>> On 14 May 2014 17:29, Jassi Brar <jassisinghbrar@gmail.com> wrote: >>>>>>>> >>>>>>>> On Wed, May 14, 2014 at 8:53 AM, Tushar Behera <tushar.behera@linaro.org> >>>>>>>> wrote: >>>>>>>>> >>>>>>>>> While playing back audio, pmc_dmaengine requests the DMA channel to >>>>>>>>> stop DMA transmission through DMA_PAUSE command. >>>>>>>>> >>>>>>>>> Currently PL330 driver doesn't support DMA pause command, leaving >>>>>>>>> the DMA state inconsistent when the system resumes. Instead, it would >>>>>>>>> be better to terminate the DMA transfer during suspend and restart >>>>>>>>> again during resume. >>>>>>>>> >>>>>>>>> Tested with audio playback across a suspend-resume cycle. >>>>>>>>> >>>>>>>> What is pmc_dmaengine? How does DMA_PAUSE help, when there is no >>>>>>>> DMA_RESUME? >>>>>>>> >>>>>>> >>>>>>> Sorry, it is a typo. >>>>>>> >>>>>>> sound/core/pcm_dmaengine.c:snd_dmaengine_pcm_trigger() --> >>>>>>> dmaengine_pause() is called during system suspend. >>>>>> >>>>>> >>>>>> It is only called if the DMA driver has support for pausing and resuming DMA >>>>>> transfers. Or at least that is the intention. >>>>>> >>>>>> - Lars >>>>> >>>>> During suspend, snd_dmaengine_pcm_trigger():SNDRV_PCM_TRIGGER_SUSPEND >>>>> is called which unconditionally calls dmaengine_pause(). Should we >>>>> update snd_dmaengine_pcm_trigger() to check for DMA pause/resume >>>>> support and call dmaengine_pause() or dmaengine_terminate_all() >>>>> accordingly? >>>> >>>> As far as I understand it we do not have to do anything for TRIGGER_SUSPEND >>>> if we do not set the SNDRV_PCM_INFO_RESUME flag. It looks like >>>> TRIGGER_SUSPEND is called unconditionally during suspend. But since the >>>> error code is ignored it should be fine if we just call dmaengine_pause() >>>> and that return -ENOSYS or similar. >>> >>> Well, TRIGGER_SUSPEND is issued by PCM core no matter whether >>> SNDRV_PCM_INFO_RESUME flag is set or not. The resume behavior depends >>> on the flag (SNDRV_PCM_TRIGGER_RESUME is issued if the flag is set, >>> otherwise the normal setup is done by alsa-lib at resume), but the >>> suspend is always triggered in the same way. >>> >>> So, PCM core assumes that the driver stops the stream somehow by >>> SNDRV_PCM_TRIGGER_SUSPEND. >> >> Ok, so we should call terminate_all() when we get a >> SNDRV_PCM_TRIGGER_SUSPEND if the dmaengine driver does not support pauseing >> the transfer. Thanks for the clarification. >> >> On a related note it seems like it is still possible to get >> PAUSE_PUSH/PAUSE_RELEASE events even if SNDRV_PCM_INFO_PAUSE is not set. Do >> you have an idea what should be the right thing to do in such a case? Return >> -ENOSYS? > > That's weird. We have already a check in snd_pcm_pre_pause() in > pcm_native.c to filter only for substreams with SNDRV_PCM_INFO_PAUSE > flag. > > Could you check in which code path it is triggered? Uhm, yes, I was only looking at the code, but couldn't find the check that makes sure that the PAUSE_PUSH/PAUSE_RELEASE events are only triggered if SNDRV_PCM_INFO_PAUSE is set. Looks like I need a pair of glasses. Thanks and sorry for the noise, - Lars ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] dma: pl330: Add support for DMA_PAUSE command 2014-05-15 19:21 ` [PATCH] dma: pl330: Add support for DMA_PAUSE command Lars-Peter Clausen 2014-05-16 5:49 ` Takashi Iwai @ 2014-05-19 3:10 ` Tushar Behera 2014-05-19 5:57 ` Lars-Peter Clausen 1 sibling, 1 reply; 7+ messages in thread From: Tushar Behera @ 2014-05-19 3:10 UTC (permalink / raw) To: Lars-Peter Clausen Cc: Jassi Brar, Linux Kernel Mailing List, dmaengine, Vinod Koul, Dan Williams, Linux-ALSA, Takashi Iwai On 16 May 2014 00:51, Lars-Peter Clausen <lars@metafoo.de> wrote: > On 05/15/2014 02:01 PM, Tushar Behera wrote: >> >> On 14 May 2014 17:54, Lars-Peter Clausen <lars@metafoo.de> wrote: >>> >>> On 05/14/2014 02:07 PM, Tushar Behera wrote: >>>> >>>> >>>> On 14 May 2014 17:29, Jassi Brar <jassisinghbrar@gmail.com> wrote: >>>>> >>>>> >>>>> On Wed, May 14, 2014 at 8:53 AM, Tushar Behera >>>>> <tushar.behera@linaro.org> >>>>> wrote: >>>>>> >>>>>> >>>>>> While playing back audio, pmc_dmaengine requests the DMA channel to >>>>>> stop DMA transmission through DMA_PAUSE command. >>>>>> >>>>>> Currently PL330 driver doesn't support DMA pause command, leaving >>>>>> the DMA state inconsistent when the system resumes. Instead, it would >>>>>> be better to terminate the DMA transfer during suspend and restart >>>>>> again during resume. >>>>>> >>>>>> Tested with audio playback across a suspend-resume cycle. >>>>>> >>>>> What is pmc_dmaengine? How does DMA_PAUSE help, when there is no >>>>> DMA_RESUME? >>>>> >>>> >>>> Sorry, it is a typo. >>>> >>>> sound/core/pcm_dmaengine.c:snd_dmaengine_pcm_trigger() --> >>>> dmaengine_pause() is called during system suspend. >>> >>> >>> >>> It is only called if the DMA driver has support for pausing and resuming >>> DMA >>> transfers. Or at least that is the intention. >>> >>> - Lars >> >> >> During suspend, snd_dmaengine_pcm_trigger():SNDRV_PCM_TRIGGER_SUSPEND >> is called which unconditionally calls dmaengine_pause(). Should we >> update snd_dmaengine_pcm_trigger() to check for DMA pause/resume >> support and call dmaengine_pause() or dmaengine_terminate_all() >> accordingly? > > > As far as I understand it we do not have to do anything for TRIGGER_SUSPEND > if we do not set the SNDRV_PCM_INFO_RESUME flag. It looks like > TRIGGER_SUSPEND is called unconditionally during suspend. But since the > error code is ignored it should be fine if we just call dmaengine_pause() > and that return -ENOSYS or similar. > > Are you seeing an actual issue that you are trying to fix with your patch? > > - Lars > Without this patch applied, if audio is playing back while suspend is triggered, it doesn't playback after resume. Stopping the stream and replaying works. -- Tushar Behera ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] dma: pl330: Add support for DMA_PAUSE command 2014-05-19 3:10 ` Tushar Behera @ 2014-05-19 5:57 ` Lars-Peter Clausen 0 siblings, 0 replies; 7+ messages in thread From: Lars-Peter Clausen @ 2014-05-19 5:57 UTC (permalink / raw) To: Tushar Behera Cc: Jassi Brar, Linux Kernel Mailing List, dmaengine, Vinod Koul, Dan Williams, Linux-ALSA, Takashi Iwai On 05/19/2014 05:10 AM, Tushar Behera wrote: > On 16 May 2014 00:51, Lars-Peter Clausen <lars@metafoo.de> wrote: >> On 05/15/2014 02:01 PM, Tushar Behera wrote: >>> >>> On 14 May 2014 17:54, Lars-Peter Clausen <lars@metafoo.de> wrote: >>>> >>>> On 05/14/2014 02:07 PM, Tushar Behera wrote: >>>>> >>>>> >>>>> On 14 May 2014 17:29, Jassi Brar <jassisinghbrar@gmail.com> wrote: >>>>>> >>>>>> >>>>>> On Wed, May 14, 2014 at 8:53 AM, Tushar Behera >>>>>> <tushar.behera@linaro.org> >>>>>> wrote: >>>>>>> >>>>>>> >>>>>>> While playing back audio, pmc_dmaengine requests the DMA channel to >>>>>>> stop DMA transmission through DMA_PAUSE command. >>>>>>> >>>>>>> Currently PL330 driver doesn't support DMA pause command, leaving >>>>>>> the DMA state inconsistent when the system resumes. Instead, it would >>>>>>> be better to terminate the DMA transfer during suspend and restart >>>>>>> again during resume. >>>>>>> >>>>>>> Tested with audio playback across a suspend-resume cycle. >>>>>>> >>>>>> What is pmc_dmaengine? How does DMA_PAUSE help, when there is no >>>>>> DMA_RESUME? >>>>>> >>>>> >>>>> Sorry, it is a typo. >>>>> >>>>> sound/core/pcm_dmaengine.c:snd_dmaengine_pcm_trigger() --> >>>>> dmaengine_pause() is called during system suspend. >>>> >>>> >>>> >>>> It is only called if the DMA driver has support for pausing and resuming >>>> DMA >>>> transfers. Or at least that is the intention. >>>> >>>> - Lars >>> >>> >>> During suspend, snd_dmaengine_pcm_trigger():SNDRV_PCM_TRIGGER_SUSPEND >>> is called which unconditionally calls dmaengine_pause(). Should we >>> update snd_dmaengine_pcm_trigger() to check for DMA pause/resume >>> support and call dmaengine_pause() or dmaengine_terminate_all() >>> accordingly? >> >> >> As far as I understand it we do not have to do anything for TRIGGER_SUSPEND >> if we do not set the SNDRV_PCM_INFO_RESUME flag. It looks like >> TRIGGER_SUSPEND is called unconditionally during suspend. But since the >> error code is ignored it should be fine if we just call dmaengine_pause() >> and that return -ENOSYS or similar. >> >> Are you seeing an actual issue that you are trying to fix with your patch? >> >> - Lars >> > > Without this patch applied, if audio is playing back while suspend is > triggered, it doesn't playback after resume. Stopping the stream and > replaying works. > Ok, I think your second suggestion was correct. Call dmaengine_terminate_all() instead of damengine_pause() in snd_dmaengine_pcm_trigger() if the dmaengine driver does not support pausing the transfer. - Lars ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2014-05-19 8:43 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <1400037830-21211-1-git-send-email-tushar.behera@linaro.org>
[not found] ` <CABb+yY3YocX=8Dv7DysM4tcx=NTCCGGipz_gpMfpKDnAw7R8iw@mail.gmail.com>
[not found] ` <CAHbNUh0fVND_oGLXWzsyKzbmJc_=FqhZTAnVHE4GGZ5aaJQbEg@mail.gmail.com>
[not found] ` <5373607D.2000200@metafoo.de>
[not found] ` <CAHbNUh1bmBniGVtvK4PpmpaKOnwG=MgtupkTEnjD6SS3r_-yjw@mail.gmail.com>
2014-05-15 19:21 ` [PATCH] dma: pl330: Add support for DMA_PAUSE command Lars-Peter Clausen
2014-05-16 5:49 ` Takashi Iwai
2014-05-16 10:51 ` Lars-Peter Clausen
2014-05-19 8:37 ` [alsa-devel] " Takashi Iwai
2014-05-19 8:43 ` Lars-Peter Clausen
2014-05-19 3:10 ` Tushar Behera
2014-05-19 5:57 ` Lars-Peter Clausen
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox