Re: [PATCH] serial: sh-sci: don't filter on DMA device, use onlychannel ID

From: Vinod Koul
Date: Mon Sep 05 2011 - 09:15:41 EST


On Mon, 2011-09-05 at 10:04 +0200, Guennadi Liakhovetski wrote:
> Hi Vinod
>
> On Tue, 30 Aug 2011, Guennadi Liakhovetski wrote:
>
> > On Tue, 30 Aug 2011, Vinod Koul wrote:
> >
> > > On Tue, 2011-08-30 at 13:20 +0200, Guennadi Liakhovetski wrote:
> > > > On Tue, 30 Aug 2011, Vinod Koul wrote:
> > > >
> > > > > On Tue, 2011-08-30 at 09:54 +0200, Guennadi Liakhovetski wrote:
> > > > > > On Mon, 29 Aug 2011, Vinod Koul wrote:
> > > > > > > > >> You should not assign chan->private.
> > > > > > > > >> Please move this to dma_slave_control API
> > > > > > > > >
> > > > > > > > > I haven't seen any reply to this comment and this patch seems to still be
> > > > > > > > > outstanding, is there an updated version of this patch that I've missed?
> > > > > > > I don't recall seeing any updated version fixing this
> > > > > >
> > > > > > As a matter of fact, when you say "use dma_slave_control API," you
> > > > > > actually mean the dma_slave_config, right? Then, how is one supposed to
> > > > > > use it in this case? Shall we be issuing a DMA_SLAVE_CONFIG call inside of
> > > > > > the filter and check the return code? The problem is, that not all DMA
> > > > > > controllers on sh-mobile SoCs can service the same slave devices. So, if
> > > > > > we don't check in the filter we might well get an unsuitable DMA channel.
> > > > > Here you are assigning to chan->private your specific values, which
> > > > > should be moved to the dma_slave_config.
> > > > > But here you are removing the checks, and accepting the first channel
> > > > > you got, so how do you find channel is suitable or not.
> > > >
> > > > That's done in the driver's .device_alloc_chan_resources() method. It
> > > > checkx the .private pointer, tries to find a suitable channel, if it fails
> > > > - it returns -EINVAL. See
> > > > drivers/dma/shdma.c::sh_dmae_alloc_chan_resources():
> > > >
> > > > if (param) {
> > > > const struct sh_dmae_slave_config *cfg;
> > > >
> > > > cfg = sh_dmae_find_slave(sh_chan, param);
> > > > if (!cfg) {
> > > > ret = -EINVAL;
> > > > goto efindslave;
> > > > }
> > > Now am doubly confused. Are you saying that you are using
> > > alloc_chan_resources for doing filtering??
> >
> > Let's look at __dma_request_channel(). It iterates over DMA devices and
> > calls private_candidate() for each of them, which in turn calls the filter
> > function for each free channel on the current device. As soon as the
> > filter returns "true" for one of channels, a private candidate is found.
> > And in my filter I do exactly this - assign the .private pointer and
> > return "true." Next dma_chan_get() is called, which in turn calls driver's
> > .device_alloc_chan_resources() method. There we check the previously set
> > .private pointer to see, if this slave can be served by this DMA device.
> > On sh-mobile you can freely configure single DMA channels for different
> > slaves, as long as this slave is at all supported by the current DMA
> > controller device. If this slave can be supported - all is good, we use
> > the private data to configure the channel. If not - we return an error and
> > __dma_request_channel() iterates to the next DMA controller device, which
> > is exactly what we need.
>
> Haven't heard back from you after this my reply. Does this mean, that
> you're now satisfied with my explanation and are going to apply my patch?
>
Sorry for the delay, we had a v long weekend here in India :)
I am still not fully convinced yet. Why do you need the private pointer
to be assigned in filter function? Once you return true for a channel in
filter function, you should be able to use the channel properly.
Assuming that you are calling for correct channel and you have set your
private pointer (i don't understand for why/what), then above check
seems to be bogus, why should you check again
in .device_alloc_chan_resources?

> Thanks
> Guennadi
> ---
> Guennadi Liakhovetski, Ph.D.
> Freelance Open-Source Software Developer
> http://www.open-technology.de/


--
~Vinod

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/