Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1760305AbcLBLD3 (ORCPT ); Fri, 2 Dec 2016 06:03:29 -0500 Received: from mail-lf0-f46.google.com ([209.85.215.46]:33222 "EHLO mail-lf0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750862AbcLBLD1 (ORCPT ); Fri, 2 Dec 2016 06:03:27 -0500 Date: Fri, 2 Dec 2016 13:03:22 +0200 From: Ivan Khoronzhuk To: Grygorii Strashko Cc: "David S. Miller" , netdev@vger.kernel.org, Mugunthan V N , Sekhar Nori , linux-kernel@vger.kernel.org, linux-omap@vger.kernel.org Subject: Re: [PATCH 2/7] net: ethernet: ti: cpdma: fix desc re-queuing Message-ID: <20161202110321.GA1213@khorivan> References: <20161201233432.6182-1-grygorii.strashko@ti.com> <20161201233432.6182-3-grygorii.strashko@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20161201233432.6182-3-grygorii.strashko@ti.com> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1460 Lines: 37 On Thu, Dec 01, 2016 at 05:34:27PM -0600, Grygorii Strashko wrote: > The currently processing cpdma descriptor with EOQ flag set may > contain two values in Next Descriptor Pointer field: > - valid pointer: means CPDMA missed addition of new desc in queue; It shouldn't happen in normal circumstances, right? So, why it happens only for egress channels? And Does that mean there is some resynchronization between submit and process function, or this is h/w issue? > - null: no more descriptors in queue. > In the later case, it's not required to write to HDP register, but now > CPDMA does it. > > Hence, add additional check for Next Descriptor Pointer != null in > cpdma_chan_process() function before writing in HDP register. > > Signed-off-by: Grygorii Strashko > --- > drivers/net/ethernet/ti/davinci_cpdma.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/net/ethernet/ti/davinci_cpdma.c b/drivers/net/ethernet/ti/davinci_cpdma.c > index 0924014..379314f 100644 > --- a/drivers/net/ethernet/ti/davinci_cpdma.c > +++ b/drivers/net/ethernet/ti/davinci_cpdma.c > @@ -1152,7 +1152,7 @@ static int __cpdma_chan_process(struct cpdma_chan *chan) > chan->count--; > chan->stats.good_dequeue++; > > - if (status & CPDMA_DESC_EOQ) { > + if ((status & CPDMA_DESC_EOQ) && chan->head) { > chan->stats.requeue++; > chan_write(chan, hdp, desc_phys(pool, chan->head)); > } > -- > 2.10.1 >