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

From: Guennadi Liakhovetski
Date: Tue Aug 30 2011 - 07:40:43 EST


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.

Thanks
Guennadi
---
Guennadi Liakhovetski, Ph.D.
Freelance Open-Source Software Developer
http://www.open-technology.de/
--
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/