From: Peter Ujfalusi <peter.ujfalusi@ti.com> To: Mark Brown <broonie@opensource.wolfsonmicro.com>, Liam Girdwood <lrg@ti.com>, Tony Lindgren <tony@atomide.com>, Russell King <rmk+kernel@arm.linux.org.uk>, Vinod Koul <vinod.koul@intel.com>, Dan Williams <djbw@fb.com>, Jarkko Nikula <jarkko.nikula@bitmer.com> Cc: alsa-devel@alsa-project.org, linux-omap@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Janusz Krzysztofik <jkrzyszt@tis.icnet.pl>, Ricardo Neri <ricardo.neri@ti.com>, Lars-Peter Clausen <lars@metafoo.de> Subject: [PATCH v3 02/15] dmaengine: omap: Add support for pause/resume in cyclic dma mode Date: Fri, 14 Sep 2012 15:05:45 +0300 [thread overview] Message-ID: <1347624358-25582-3-git-send-email-peter.ujfalusi@ti.com> (raw) In-Reply-To: <1347624358-25582-1-git-send-email-peter.ujfalusi@ti.com> The audio stack used omap_stop_dma/omap_start_dma to pause/resume the DMA. This method has been used for years on OMAP based products. We only allow pause/resume when the DMA has been configured in cyclic mode which is used by the audio stack. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com> CC: Russell King <rmk+kernel@arm.linux.org.uk> --- drivers/dma/omap-dma.c | 30 +++++++++++++++++++++++++----- 1 file changed, 25 insertions(+), 5 deletions(-) diff --git a/drivers/dma/omap-dma.c b/drivers/dma/omap-dma.c index b77a40d..71d7869 100644 --- a/drivers/dma/omap-dma.c +++ b/drivers/dma/omap-dma.c @@ -34,6 +34,7 @@ struct omap_chan { struct dma_slave_config cfg; unsigned dma_sig; bool cyclic; + bool paused; int dma_ch; struct omap_desc *desc; @@ -470,11 +471,14 @@ static int omap_dma_terminate_all(struct omap_chan *c) */ if (c->desc) { c->desc = NULL; - omap_stop_dma(c->dma_ch); + /* Avoid stopping the dma twice */ + if (!c->paused) + omap_stop_dma(c->dma_ch); } if (c->cyclic) { c->cyclic = false; + c->paused = false; omap_dma_unlink_lch(c->dma_ch, c->dma_ch); } @@ -487,14 +491,30 @@ static int omap_dma_terminate_all(struct omap_chan *c) static int omap_dma_pause(struct omap_chan *c) { - /* FIXME: not supported by platform private API */ - return -EINVAL; + /* Pause/Resume only allowed with cyclic mode */ + if (!c->cyclic) + return -EINVAL; + + if (!c->paused) { + omap_stop_dma(c->dma_ch); + c->paused = true; + } + + return 0; } static int omap_dma_resume(struct omap_chan *c) { - /* FIXME: not supported by platform private API */ - return -EINVAL; + /* Pause/Resume only allowed with cyclic mode */ + if (!c->cyclic) + return -EINVAL; + + if (c->paused) { + omap_start_dma(c->dma_ch); + c->paused = false; + } + + return 0; } static int omap_dma_control(struct dma_chan *chan, enum dma_ctrl_cmd cmd, -- 1.7.12
WARNING: multiple messages have this Message-ID (diff)
From: peter.ujfalusi@ti.com (Peter Ujfalusi) To: linux-arm-kernel@lists.infradead.org Subject: [PATCH v3 02/15] dmaengine: omap: Add support for pause/resume in cyclic dma mode Date: Fri, 14 Sep 2012 15:05:45 +0300 [thread overview] Message-ID: <1347624358-25582-3-git-send-email-peter.ujfalusi@ti.com> (raw) In-Reply-To: <1347624358-25582-1-git-send-email-peter.ujfalusi@ti.com> The audio stack used omap_stop_dma/omap_start_dma to pause/resume the DMA. This method has been used for years on OMAP based products. We only allow pause/resume when the DMA has been configured in cyclic mode which is used by the audio stack. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com> CC: Russell King <rmk+kernel@arm.linux.org.uk> --- drivers/dma/omap-dma.c | 30 +++++++++++++++++++++++++----- 1 file changed, 25 insertions(+), 5 deletions(-) diff --git a/drivers/dma/omap-dma.c b/drivers/dma/omap-dma.c index b77a40d..71d7869 100644 --- a/drivers/dma/omap-dma.c +++ b/drivers/dma/omap-dma.c @@ -34,6 +34,7 @@ struct omap_chan { struct dma_slave_config cfg; unsigned dma_sig; bool cyclic; + bool paused; int dma_ch; struct omap_desc *desc; @@ -470,11 +471,14 @@ static int omap_dma_terminate_all(struct omap_chan *c) */ if (c->desc) { c->desc = NULL; - omap_stop_dma(c->dma_ch); + /* Avoid stopping the dma twice */ + if (!c->paused) + omap_stop_dma(c->dma_ch); } if (c->cyclic) { c->cyclic = false; + c->paused = false; omap_dma_unlink_lch(c->dma_ch, c->dma_ch); } @@ -487,14 +491,30 @@ static int omap_dma_terminate_all(struct omap_chan *c) static int omap_dma_pause(struct omap_chan *c) { - /* FIXME: not supported by platform private API */ - return -EINVAL; + /* Pause/Resume only allowed with cyclic mode */ + if (!c->cyclic) + return -EINVAL; + + if (!c->paused) { + omap_stop_dma(c->dma_ch); + c->paused = true; + } + + return 0; } static int omap_dma_resume(struct omap_chan *c) { - /* FIXME: not supported by platform private API */ - return -EINVAL; + /* Pause/Resume only allowed with cyclic mode */ + if (!c->cyclic) + return -EINVAL; + + if (c->paused) { + omap_start_dma(c->dma_ch); + c->paused = false; + } + + return 0; } static int omap_dma_control(struct dma_chan *chan, enum dma_ctrl_cmd cmd, -- 1.7.12
next prev parent reply other threads:[~2012-09-14 12:05 UTC|newest] Thread overview: 82+ messages / expand[flat|nested] mbox.gz Atom feed top 2012-09-14 12:05 [PATCH v3 00/15] ASoC: OMAP: Convert to use dmaengine Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 01/15] dmaengine: omap: Support for element mode in cyclic DMA Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi [this message] 2012-09-14 12:05 ` [PATCH v3 02/15] dmaengine: omap: Add support for pause/resume in cyclic dma mode Peter Ujfalusi 2012-09-17 3:13 ` Vinod Koul 2012-09-17 3:13 ` Vinod Koul 2012-09-17 3:13 ` Vinod Koul 2012-09-17 8:41 ` Peter Ujfalusi 2012-09-17 8:41 ` Peter Ujfalusi 2012-09-18 8:28 ` Russell King - ARM Linux 2012-09-18 8:28 ` Russell King - ARM Linux 2012-09-18 8:28 ` Russell King - ARM Linux 2012-09-17 9:55 ` Vinod Koul 2012-09-17 9:55 ` Vinod Koul 2012-09-17 9:55 ` Vinod Koul 2012-09-14 12:05 ` [PATCH v3 03/15] dmaengine: Add flags parameter to dmaengine_prep_dma_cyclic() Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-17 9:58 ` Vinod Koul 2012-09-17 9:58 ` Vinod Koul 2012-09-22 15:09 ` Mark Brown 2012-09-22 15:09 ` Mark Brown 2012-09-22 15:09 ` Mark Brown 2012-09-14 12:05 ` [PATCH v3 04/15] dmaengine: Pass flags via device_prep_dma_cyclic() callback Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-17 9:59 ` Vinod Koul 2012-09-17 9:59 ` Vinod Koul 2012-09-17 9:59 ` Vinod Koul 2012-09-17 10:06 ` Nicolas Ferre 2012-09-17 10:06 ` Nicolas Ferre 2012-09-17 10:06 ` Nicolas Ferre 2012-09-19 2:45 ` Shawn Guo 2012-09-19 2:45 ` Shawn Guo 2012-09-19 2:45 ` Shawn Guo 2012-09-14 12:05 ` [PATCH v3 05/15] dmaengine: omap-dma: Add support to suppress interrupts in cyclic mode Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-17 10:00 ` Vinod Koul 2012-09-17 10:00 ` Vinod Koul 2012-09-14 12:05 ` [PATCH v3 06/15] ASoC: omap-mcbsp: Use sDMA packet mode instead of frame mode Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 07/15] ASoC: omap-pcm: Select sDMA synchronization based on packet_size Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 08/15] ASoC: OMAP: Remove sync_mode from omap_pcm_dma_data struct Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 09/15] ASoC: omap-pcm: Prepare to configure the DMA data_type based on stream properties Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 10/15] ARM: OMAP4: hwmod_data: Add resource names to McPDM memory ranges Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 11/15] ASoC: omap-mcpdm: Use platform_get_resource_* to get resources Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 12/15] ASoC: OMAP: mcbsp, mcpdm, dmic: Let omap-pcm to pick the dma_type Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 13/15] ASoC: omap-pcm, omap-dmic: Change the use of omap_pcm_dma_data->data_type Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 14/15] ASoC: OMAP: mcbsp, mcpdm, dmic, hdmi: Set dma_data at startup time Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-14 12:05 ` [PATCH v3 15/15] ASoC: omap-pcm: Convert to use dmaengine Peter Ujfalusi 2012-09-14 12:05 ` Peter Ujfalusi 2012-09-15 21:38 ` [alsa-devel] [PATCH v3 00/15] ASoC: OMAP: " Janusz Krzysztofik 2012-09-15 21:38 ` Janusz Krzysztofik 2012-09-15 21:38 ` Janusz Krzysztofik 2012-09-17 3:17 ` Vinod Koul 2012-09-17 3:17 ` Vinod Koul 2012-09-17 3:17 ` Vinod Koul 2012-09-17 8:44 ` [alsa-devel] " Peter Ujfalusi 2012-09-17 8:44 ` Peter Ujfalusi 2012-09-17 8:44 ` Peter Ujfalusi 2012-09-17 9:51 ` Vinod Koul 2012-09-17 9:51 ` Vinod Koul 2012-09-17 9:51 ` Vinod Koul 2012-09-24 23:36 ` [alsa-devel] " Ricardo Neri 2012-09-24 23:36 ` Ricardo Neri 2012-09-24 23:36 ` Ricardo Neri
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=1347624358-25582-3-git-send-email-peter.ujfalusi@ti.com \ --to=peter.ujfalusi@ti.com \ --cc=alsa-devel@alsa-project.org \ --cc=broonie@opensource.wolfsonmicro.com \ --cc=djbw@fb.com \ --cc=jarkko.nikula@bitmer.com \ --cc=jkrzyszt@tis.icnet.pl \ --cc=lars@metafoo.de \ --cc=linux-arm-kernel@lists.infradead.org \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-omap@vger.kernel.org \ --cc=lrg@ti.com \ --cc=ricardo.neri@ti.com \ --cc=rmk+kernel@arm.linux.org.uk \ --cc=tony@atomide.com \ --cc=vinod.koul@intel.com \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.