From: Jorge Ventura <jorge.araujo.ventura-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
To: linux-spi-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: Re: spi-omap2-mcspi hangs when DMA and PIO are used simultaneously
Date: Sat, 12 Apr 2014 19:09:09 -0500 [thread overview]
Message-ID: <20140413000908.GA13392@myventura.us> (raw)
In-Reply-To: <FEB1293C1A07484EA4E9721B32981131EAEF80-yXqyApvAXouIQmiDNMet8wC/G2K4zDHf@public.gmane.org>
Sorry the delay.
I was using the Kernel 3.13.6 patched for beaglebone, where the patch
you suggested is needed but doesn't succeed. I decided to check the
mainline 3.14.0 and figured out that the patch is already applied. I
installed that one and repeated all tests to confirm the position of
problem in the source code. The problem is still exactly
the same as described in my first e-mail and the mcspi module is in the
instruction spi-omap2-mcspi.c:480 waiting for the callback function
completion.
The changes in the DMA_MIN_BYTES to force DMA or PIO only still works the
same way.
Thank you,
Ventura
On Sat, Apr 12, 2014 at 04:33:38AM +0000, Poddar, Sourav wrote:
> Hi,
> [Sorry fot top posting]
>
> Can you try this patch?
> https://patchwork.kernel.org/patch/3511311/
>
> ________________________________________
> From: linux-spi-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org [linux-spi-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org] on behalf of Jorge Ventura [jorge.araujo.ventura-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org]
> Sent: Saturday, April 12, 2014 8:49 AM
> To: linux-spi-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
> Cc: jorge.araujo.ventura-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org
> Subject: spi-omap2-mcspi hangs when DMA and PIO are used simultaneously
>
> I am struggling with this problem for several weeks with no success.
>
> I am using spi-omap2-mcspi to drive a network card based on enc28j60 and everything works perfect if I define
> DMA_MIN_BYTES = 0 (force to use DMA only) or DMA_MIN_BYTES = 99999 (force to use PIO only).
> But if I use the original value of 160, the board can send out 10 to 20 pings approximately
> and if for any reason the drive switch from PIO to DMA what will be decided by the size of data,
> some workqueue tasks hung and the card stops.
>
> I am running with "lockdep" and "detect hung tasks" and I can see that four tasks are stopped,
> three from enc28j60 and one from spi-omap2-mcspi.
>
> The mcspi is stopped in spi-omap2.mcspi.c:480 to wait the completion of omap2_mcspi_rx_callback
> that it never happens.
>
> 468 if (tx) {
> 469 tx->callback = omap2_mcspi_rx_callback;
> 470 tx->callback_param = spi;
> 471 dmaengine_submit(tx);
> 472 } else {
> 473 /* FIXME: fall back to PIO? */
> 474 }
> 475 }
> 476
> 477 dma_async_issue_pending(mcspi_dma->dma_rx);
> 478 omap2_mcspi_set_dma_req(spi, 1, 1);
> 479
> 480 wait_for_completion(&mcspi_dma->dma_rx_completion);
> 481 dma_unmap_single(mcspi->dev, xfer->rx_dma, count,
> 482 DMA_FROM_DEVICE);
>
> Any help/suggestion is welcome. Need more information, please let me know, I have much
> more details.
>
> Thank you.
> --
> To unsubscribe from this list: send the line "unsubscribe linux-spi" in
> the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-spi" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2014-04-13 0:09 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-04-12 3:19 spi-omap2-mcspi hangs when DMA and PIO are used simultaneously Jorge Ventura
[not found] ` <20140412031902.GA28289-BSeKu0bcreVcK3SlQUq7iQ@public.gmane.org>
2014-04-12 4:33 ` Poddar, Sourav
[not found] ` <FEB1293C1A07484EA4E9721B32981131EAEF80-yXqyApvAXouIQmiDNMet8wC/G2K4zDHf@public.gmane.org>
2014-04-13 0:09 ` Jorge Ventura [this message]
2014-04-21 13:20 ` Jorge Ventura
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=20140413000908.GA13392@myventura.us \
--to=jorge.araujo.ventura-re5jqeeqqe8avxtiumwx3w@public.gmane.org \
--cc=linux-spi-u79uwXL29TY76Z2rM5mHXA@public.gmane.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).