From: sjg@chromium.org (Simon Glass)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 4/7] spi: s3c64xx: Use jiffies instead of loops for timeout
Date: Tue, 18 Sep 2012 11:21:56 -0700 [thread overview]
Message-ID: <1347992519-6904-5-git-send-email-sjg@chromium.org> (raw)
In-Reply-To: <1347992519-6904-1-git-send-email-sjg@chromium.org>
The current timeout uses loops, but does not actually use an empty loop. In
fact it checks SPI registers which are pretty slow to read. As a result the
timeout ends up being several seconds most of the time.
Change this to use jiffies instead.
Signed-off-by: Simon Glass <sjg@chromium.org>
---
drivers/spi/spi-s3c64xx.c | 37 ++++++++++++++++++++++---------------
1 files changed, 22 insertions(+), 15 deletions(-)
diff --git a/drivers/spi/spi-s3c64xx.c b/drivers/spi/spi-s3c64xx.c
index 95a1bfc..db79d87 100644
--- a/drivers/spi/spi-s3c64xx.c
+++ b/drivers/spi/spi-s3c64xx.c
@@ -427,6 +427,7 @@ static inline void enable_cs(struct s3c64xx_spi_driver_data *sdd,
static int wait_for_xfer(struct s3c64xx_spi_driver_data *sdd,
struct spi_transfer *xfer, int dma_mode)
{
+ struct device *dev = &sdd->pdev->dev;
void __iomem *regs = sdd->regs;
unsigned long val;
int ms;
@@ -439,16 +440,21 @@ static int wait_for_xfer(struct s3c64xx_spi_driver_data *sdd,
val = msecs_to_jiffies(ms) + 10;
val = wait_for_completion_timeout(&sdd->xfer_completion, val);
} else {
+ ulong deadline;
u32 status;
- val = msecs_to_loops(ms);
+
+ deadline = jiffies + msecs_to_jiffies(ms);
do {
status = readl(regs + S3C64XX_SPI_STATUS);
- } while (RX_FIFO_LVL(status, sdd) < xfer->len && --val);
+ if (time_after(jiffies, deadline)) {
+ dev_warn(dev, "RX timeout level=%d, need=%d\n",
+ RX_FIFO_LVL(status, sdd), xfer->len);
+ return -EIO;
+ }
+ cpu_relax();
+ } while (RX_FIFO_LVL(status, sdd) < xfer->len);
}
- if (!val)
- return -EIO;
-
if (dma_mode) {
u32 status;
@@ -460,17 +466,18 @@ static int wait_for_xfer(struct s3c64xx_spi_driver_data *sdd,
* Xfer involved Rx(with or without Tx).
*/
if (xfer->rx_buf == NULL) {
- val = msecs_to_loops(10);
- status = readl(regs + S3C64XX_SPI_STATUS);
- while ((TX_FIFO_LVL(status, sdd)
- || !S3C64XX_SPI_ST_TX_DONE(status, sdd))
- && --val) {
- cpu_relax();
- status = readl(regs + S3C64XX_SPI_STATUS);
- }
+ ulong deadline;
- if (!val)
- return -EIO;
+ deadline = jiffies + msecs_to_jiffies(10);
+ do {
+ status = readl(regs + S3C64XX_SPI_STATUS);
+ if (time_after(jiffies, deadline)) {
+ dev_warn(dev, "TX timeout level=%d\n",
+ TX_FIFO_LVL(status, sdd));
+ return -EIO;
+ }
+ } while (TX_FIFO_LVL(status, sdd) ||
+ !S3C64XX_SPI_ST_TX_DONE(status, sdd));
}
} else {
/* If it was only Tx */
--
1.7.7.3
next prev parent reply other threads:[~2012-09-18 18:21 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-09-18 18:21 [PATCH 0/7] Add support for Exynos5 ISP SPI ports Simon Glass
2012-09-18 18:21 ` [PATCH 1/7] PM / Domains: add generic function 'pm_genpd_of_add_device_by_name' Simon Glass
2012-09-18 18:21 ` [PATCH 2/7] spi: s3c64xx: Fix enum dma_data_direction warning Simon Glass
2012-09-18 18:21 ` [PATCH 3/7] spi: s3c64xx: Add support for ISP SPI ports Simon Glass
2012-09-18 18:21 ` Simon Glass [this message]
2012-09-18 18:21 ` [PATCH 5/7] spi: s3c64xx: Allow use with SPI ports without dma Simon Glass
2012-09-18 18:21 ` [PATCH 6/7] spi: s3c64xx: Tidy up SPI chip select handling Simon Glass
2012-09-18 18:21 ` [PATCH 7/7] spi: s3c64xx: Write to PACKET_CNT after reset Simon Glass
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=1347992519-6904-5-git-send-email-sjg@chromium.org \
--to=sjg@chromium.org \
--cc=linux-arm-kernel@lists.infradead.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).