Re: [PATCH v4 2/2] dmaengine: add a driver for AMBA AXI NBPF DMAC IP cores

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Vinod,

On Mon, 28 Jul 2014, Vinod Koul wrote:

> On Sat, Jul 26, 2014 at 09:32:18PM +0200, Guennadi Liakhovetski wrote:
> > On Fri, 25 Jul 2014, Vinod Koul wrote:
> > 
> > > On Fri, Jul 25, 2014 at 05:00:53PM +0200, Guennadi Liakhovetski wrote:
> > > > Hi Vinod,
> > > > 
> > > > On Fri, 25 Jul 2014, Vinod Koul wrote:
> > > > 
> > > > Thanks for your review. However, I find the following a bit odd. As you 
> > > > remember, you already reviewed v2 of this driver:
> > > > 
> > > > http://www.spinics.net/lists/dmaengine/msg00880.html
> > > > 
> > > > and provided your comments to it, which I addressed in versions 3 and 4. 
> > > > Code, that you're commenting on here, hasn't (significantly) changed since 
> > > > v1. During your v2 review it didn't seem offending to you, now it does. 
> > > > Does this mean, that if / once I fix these issues, your next review might 
> > > > find some more _old_ code snippets, that you decide aren't appropriate?
> > > > 
> > > > This isn't the first time such a thing is happening with various reviewers 
> > > > and patch submitters. I think a reasonable approach is to "trust your own 
> > > > review." Once I've reviewed a piece of code and found it ok, I _normally_ 
> > > > won't ask a patch author to modify code, that didn't change since my 
> > > > previous review. Simple. Of course, sometimes it does happen, that the 
> > > > first review skips some important flaws, but then I consider that my 
> > > > fault, if I didn't find them during the first round and try to find a 
> > > > solution to minimise the damage to the author. Now, to specific comments.
> > > I agree you can blame me for not spotting them earlier and yes criticism is
> > > fair. But then overall goal is to ensure that code is better, so even if
> > > comment comes late we should accept it.
> > 
> > Apparently, our approaches differ somewhat here. I explained already what 
> > I normally do in such cases.
> > 
> > > > > On Sat, Jul 19, 2014 at 12:48:51PM +0200, Guennadi Liakhovetski wrote:
> > > > > > This patch adds a driver for NBPF DMAC IP cores from Renesas, designed for
> > > > > > the AMBA AXI bus.
> > > > > > 
> > > > > 
> > > > > > +struct nbpf_desc {
> > > > > > +	struct dma_async_tx_descriptor async_tx;
> > > > > > +	bool user_wait;
> > > > > sounds odd?
> > > > 
> > > > Maybe it's not the best name, I can gladly try to improve it, but I'm sure 
> > > > I'm not the best "namer," so, the same can be said about more or less 
> > > > every identifier in all my code - it could be improved. However, I don't 
> > > > think it's critical enough to delay mainlining until the next kernel 
> > > > version?
> > > No it is not critical at all!
> > > 
> > > > > > +static int nbpf_chan_probe(struct nbpf_device *nbpf, int n)
> > > > > > +{
> > > > > > +	struct dma_device *dma_dev = &nbpf->dma_dev;
> > > > > > +	struct nbpf_channel *chan = nbpf->chan + n;
> > > > > > +	int ret;
> > > > > > +
> > > > > > +	chan->nbpf = nbpf;
> > > > > > +	chan->base = nbpf->base + NBPF_REG_CHAN_OFFSET + NBPF_REG_CHAN_SIZE * n;
> > > > > > +	INIT_LIST_HEAD(&chan->desc_page);
> > > > > > +	spin_lock_init(&chan->lock);
> > > > > > +	chan->dma_chan.device = dma_dev;
> > > > > > +	dma_cookie_init(&chan->dma_chan);
> > > > > > +	nbpf_chan_prepare_default(chan);
> > > > > > +
> > > > > > +	dev_dbg(dma_dev->dev, "%s(): channel %d: -> %p\n", __func__, n, chan->base);
> > > > > > +
> > > > > > +	snprintf(chan->name, sizeof(chan->name), "nbpf %d", n);
> > > > > > +
> > > > > > +	ret = devm_request_threaded_irq(dma_dev->dev, chan->irq,
> > > > > > +			nbpf_chan_irq, nbpf_chan_irqt, IRQF_SHARED,
> > > > > > +			chan->name, chan);
> > > > > devm_request_irq and friends arent apt here. You are in .remove and get an
> > > > > irq, what prevents that race?
> > > > 
> > > > How is this your comment different for DMA drivers from any other drivers? 
> > > > Of course you have to make sure no more interrupts are arriving once in 
> > > > .remove() you lost the ability to handle IRQs. So, AFAIU, it's always a 
> > > > per-case study: you have to look at .remove() and consider, what happens 
> > > > if IRQ hits at any point inside it - if at all possible. Besides, DMA 
> > > > engine drivers are additionally protected by incremented module 
> > > > use-counts, once a channel is in use? As soon as a channel is released 
> > > > your driver has to make sure no more IRQs are occurring. Besides, there's 
> > > > a dmaengine_get()... So, I think, we really need to first find a race 
> > > > possibility, and then fix it. Besides, you could try
> > > > 
> > > > grep -rl devm_request_irq drivers/dma/*.c
> > > And please also see there were regression on few of them, recently dw was
> > > fixed for this case. Similarly few other drivers were fixed for their
> > > behaviour in tasklet kill, syncronizing the irq and freeing up behaviour.
> > > 
> > > So now back to this driver, since you are using devm_ the irq is not freed,
> > > so how does it prevent race.
> > 
> > How is it not freed? Of course it is freed, but later - after .release() 
> > has completed.
> Looking at the code again, I think we need to free irq (you can call
> devm_free_irq()) and call syncronize_irq so that anything pending is
> flushed.  So if you can send follow up patch doing these in .remove, we can
> merge these

This is a nice offer, thanks! But to accept it I'd like to understand: why 
do you think we need that? In my previous email I presented to you a 
theoretical and improbable race situation, that I can foresee. You erased 
it in your reply, but it was dealing with the 
.device_free_chan_resources() method, so, your suspected race is a 
different one. Could you please explain to me, why do you think interrupts 
are possible during .release()? Aren't all channels guaranteed to have 
been freed by that time?

Thanks
Guennadi
--
To unsubscribe from this list: send the line "unsubscribe dmaengine" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Kernel]     [Linux ARM (vger)]     [Linux ARM MSM]     [Linux Omap]     [Linux Arm]     [Linux Tegra]     [Fedora ARM]     [Linux for Samsung SOC]     [eCos]     [Linux PCI]     [Linux Fastboot]     [Gcc Help]     [Git]     [DCCP]     [IETF Announce]     [Security]     [Linux MIPS]     [Yosemite Campsites]

  Powered by Linux