linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
From: jassisinghbrar@gmail.com (Jassi Brar)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH V4 06/14] ARM: SAMSUNG: Add common DMA operations
Date: Wed, 27 Jul 2011 13:27:56 +0530	[thread overview]
Message-ID: <CABb+yY2i1rnvqWTFQUnMSrX7_h9KHnNL9xPZ2aHv8hO5Y7j+uA@mail.gmail.com> (raw)
In-Reply-To: <000401cc4c1c$71d63240$558296c0$%kim@samsung.com>

On Wed, Jul 27, 2011 at 10:47 AM, Boojin Kim <boojin.kim@samsung.com> wrote:
> Jassi Brar wrote:
>> Sent: Wednesday, July 27, 2011 10:34 AM
>> To: Boojin Kim
>> Cc: linux-arm-kernel at lists.infradead.org; linux-samsung-
>> soc at vger.kernel.org; Vinod Koul; Dan Williams; Kukjin Kim; Grant
>> Likely; Mark Brown
>> Subject: Re: [PATCH V4 06/14] ARM: SAMSUNG: Add common DMA operations
>>
>> On Tue, Jul 26, 2011 at 3:05 PM, Boojin Kim <boojin.kim@samsung.com>
>> wrote:
>> > Jassi Brar Wrote:
>> >> Sent: Monday, July 25, 2011 8:52 PM
>> >> To: Boojin Kim
>> >> Cc: linux-arm-kernel at lists.infradead.org; linux-samsung-
>> >> soc at vger.kernel.org; Vinod Koul; Dan Williams; Kukjin Kim; Grant
>> >> Likely; Mark Brown
>> >> Subject: Re: [PATCH V4 06/14] ARM: SAMSUNG: Add common DMA
>> operations
>> >>
>> >> On Mon, Jul 25, 2011 at 6:58 AM, Boojin Kim
>> <boojin.kim@samsung.com>
>> >> wrote:
>> >>
>> >> > +
>> >> > +static bool pl330_filter(struct dma_chan *chan, void *param)
>> >> > +{
>> >> > + ? ? ? struct dma_pl330_peri *peri = (struct dma_pl330_peri
>> *)chan-
>> >> >private;
>> >> > + ? ? ? unsigned dma_ch = (unsigned)param;
>> >> > +
>> >> > + ? ? ? if (peri->peri_id != dma_ch)
>> >> > + ? ? ? ? ? ? ? return false;
>> >> > +
>> >> > + ? ? ? return true;
>> >> > +}
>> >> This is what I meant... if we keep chan_id for paltform assigned
>> IDs,
>> >> these filter functions could simply become
>> >>
>> >> static bool pl330_filter(struct dma_chan *chan, void *param)
>> >> {
>> >> ? ? ? ? return chan->chan_id == param
>> >> }
>> >>
>> >> And ideally in the long run, we could just drop the filter callback
>> >> and add expected channel ID to the request_channel call.
>> > The chan_id is set by dmaengine. So, We don't use it to hold the
>> user specific
>> > Id.
>> Not for long.
>> See ?https://lkml.org/lkml/2011/7/26/245
>>
>>
>> >> > +
>> >> > +static inline int s3c_dma_trigger(unsigned ch)
>> >> > +{
>> >> > + ? ? ? return s3c2410_dma_ctrl(ch, S3C2410_DMAOP_START);
>> >> > +}
>> >> > +
>> >> > +static inline int s3c_dma_started(unsigned ch)
>> >> > +{
>> >> > + ? ? ? return s3c2410_dma_ctrl(ch, S3C2410_DMAOP_STARTED);
>> >> > +}
>> >> > +
>> >> > +static inline int s3c_dma_flush(unsigned ch)
>> >> > +{
>> >> > + ? ? ? return s3c2410_dma_ctrl(ch, S3C2410_DMAOP_FLUSH);
>> >> > +}
>> >> > +
>> >> > +static inline int s3c_dma_stop(unsigned ch)
>> >> > +{
>> >> > + ? ? ? return s3c2410_dma_ctrl(ch, S3C2410_DMAOP_STOP);
>> >> > +}
>> >> > +
>> >> > +static struct samsung_dma_ops s3c_dma_ops = {
>> >> > + ? ? ? .request ? ? ? ?= s3c_dma_request,
>> >> > + ? ? ? .release ? ? ? ?= s3c_dma_release,
>> >> > + ? ? ? .prepare ? ? ? ?= s3c_dma_prepare,
>> >> > + ? ? ? .trigger ? ? ? ?= s3c_dma_trigger,
>> >> > + ? ? ? .started ? ? ? ?= s3c_dma_started,
>> >> > + ? ? ? .flush ? ? ? ? ?= s3c_dma_flush,
>> >> > + ? ? ? .stop ? ? ? ? ? = s3c_dma_stop,
>> >>
>> >> These last 4 should be gnereallized into one callback with OP
>> argument.
>> > I don't have any idea about it. Can you explain it in more detail?
>>
>> static int s3c_dma_control(unsigned ch, enum s3c2410_chan_op/*or
>> similar*/ op)
>> ?{
>> ? ? ? ? return s3c2410_dma_ctrl(ch, op);
>> ?}
>>
>> static struct samsung_dma_ops s3c_dma_ops = {
>> ? ? ? ? .request ? ? ? ?= s3c_dma_request,
>> ? ? ? ? .release ? ? ? ?= s3c_dma_release,
>> ? ? ? ? .prepare ? ? ? ?= s3c_dma_prepare,
>> ? ? ? ? .control ? ? ? ?= s3c_dma_control,
> 'Struct samsung_dma_ops' is used for both 'S3C-DMA-OPS' for 's3c dma' and
> 'DMA-OPS' for 'dmaengine'.
> If I modify "Struct samsung_dma_ops" as your guide, It gives un-expectable
> effect to DMA-OPS.
> Actually, We don't want the client with 'DMA-OPS' uses 'enum s3c2410_chan_op'
> operation anymore.

" enum s3c2410_chan_op /* or similar */ "  <<<<  note 'or similar'

Defining a callback for each value of the argument doesn't make sense.

  reply	other threads:[~2011-07-27  7:57 UTC|newest]

Thread overview: 73+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-07-25  1:28 [RESEND] [PATCH V4 0/14] To use DMA generic APIs for Samsung DMA Boojin Kim
2011-07-25  1:28 ` [PATCH V4 01/14] DMA: PL330: Add support runtime PM for PL330 DMAC Boojin Kim
2011-07-26  6:03   ` Chanwoo Choi
2011-07-25  1:28 ` [PATCH V4 02/14] DMA: PL330: Update PL330 DMA API driver Boojin Kim
2011-07-25  8:57   ` Jassi Brar
2011-07-25  9:48     ` Boojin Kim
2011-07-25  1:28 ` [PATCH V4 03/14] DMA: PL330: Support DMA_SLAVE_CONFIG command Boojin Kim
2011-07-25 10:26   ` Vinod Koul
2011-07-25 12:51     ` Boojin Kim
2011-07-25 13:48       ` Vinod Koul
2011-07-26 13:04         ` Boojin Kim
2011-07-26 13:12           ` Russell King - ARM Linux
2011-07-25  1:28 ` [PATCH V4 04/14] DMA: PL330: Add DMA_CYCLIC capability Boojin Kim
2011-07-25  9:27   ` Russell King - ARM Linux
2011-07-25 10:31     ` Boojin Kim
2011-07-25 10:36       ` Russell King - ARM Linux
2011-07-25 10:48         ` Vinod Koul
2011-07-25 10:57           ` Russell King - ARM Linux
2011-07-25 11:01             ` Vinod Koul
2011-07-25 11:39               ` Russell King - ARM Linux
2011-07-25 12:01                 ` Vinod Koul
2011-07-26  7:57                   ` [PATCH] Improve slave/cyclic DMA engine documentation (was: [PATCH V4 04/14] DMA: PL330: Add DMA_CYCLIC capability) Russell King - ARM Linux
2011-07-26  9:35                     ` Vinod Koul
2011-07-26 14:37                       ` Jassi Brar
2011-07-26 17:20                         ` Russell King - ARM Linux
2011-07-26 17:55                           ` Jassi Brar
2011-07-26 18:03                             ` Grant Likely
2011-07-26 18:16                             ` Russell King - ARM Linux
2011-07-27  2:38                             ` Vinod Koul
2011-07-27  9:01                       ` Russell King - ARM Linux
2011-07-27  9:06                         ` Koul, Vinod
2011-07-26 13:25                     ` Russell King - ARM Linux
2011-07-25 12:36           ` [PATCH V4 04/14] DMA: PL330: Add DMA_CYCLIC capability Boojin Kim
2011-07-25 12:34         ` Boojin Kim
2011-07-25 11:24   ` Jassi Brar
2011-07-26 12:28     ` Boojin Kim
2011-07-25  1:28 ` [PATCH V4 05/14] ARM: SAMSUNG: Update to use PL330-DMA driver Boojin Kim
2011-07-25 10:52   ` Vinod Koul
2011-07-25 11:31   ` Jassi Brar
2011-07-25  1:28 ` [PATCH V4 06/14] ARM: SAMSUNG: Add common DMA operations Boojin Kim
2011-07-25  9:36   ` Russell King - ARM Linux
2011-07-25  9:57     ` Boojin Kim
2011-07-25 11:51   ` Jassi Brar
2011-07-26  8:02     ` Russell King - ARM Linux
2011-07-26 17:43       ` Jassi Brar
2011-07-26 18:14         ` Russell King - ARM Linux
2011-07-26 19:54           ` Jassi Brar
2011-07-26  9:35     ` Boojin Kim
2011-07-27  1:33       ` Jassi Brar
2011-07-27  5:17         ` Boojin Kim
2011-07-27  7:57           ` Jassi Brar [this message]
2011-07-28  0:38             ` Boojin Kim
2011-07-25  1:28 ` [PATCH V4 07/14] ARM: EXYNOS4: Use generic DMA PL330 driver Boojin Kim
2011-07-25 11:59   ` Jassi Brar
2011-07-25 12:59     ` Boojin Kim
2011-07-25  1:28 ` [PATCH V4 08/14] ARM: S5PV210: " Boojin Kim
2011-07-25  1:28 ` [PATCH V4 09/14] ARM: S5PC100: " Boojin Kim
2011-07-25  1:28 ` [PATCH V4 10/14] ARM: S5P64X0: " Boojin Kim
2011-07-25  1:28 ` [PATCH V4 11/14] ARM: SAMSUNG: Remove S3C-PL330-DMA driver Boojin Kim
2011-07-25  1:28 ` [PATCH V4 12/14] spi/s3c64xx: Add support DMA engine API Boojin Kim
2011-07-25  9:40   ` Russell King - ARM Linux
2011-07-25 10:34     ` Boojin Kim
2011-07-25 11:17   ` Vinod Koul
2011-07-26  9:31     ` Boojin Kim
2011-07-26 10:14       ` Vinod Koul
2011-07-27  5:05         ` Boojin Kim
2011-07-25  1:28 ` [PATCH V4 13/14] ASoC: Samsung: Update DMA interface Boojin Kim
2011-07-25  1:28 ` [PATCH V4 14/14] ARM: SAMSUNG: Remove Samsung specific enum type for dma direction Boojin Kim
2011-07-25 12:08   ` Jassi Brar
2011-07-25 21:15     ` Grant Likely
2011-07-28  1:23       ` Boojin Kim
2011-07-25 10:17 ` [RESEND] [PATCH V4 0/14] To use DMA generic APIs for Samsung DMA Vinod Koul
2011-07-25 11:09   ` Vinod Koul

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=CABb+yY2i1rnvqWTFQUnMSrX7_h9KHnNL9xPZ2aHv8hO5Y7j+uA@mail.gmail.com \
    --to=jassisinghbrar@gmail.com \
    --cc=linux-arm-kernel@lists.infradead.org \
    /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: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).