hwrng: mxc-rnga - fix data_present API
authorBenoît Thébaudeau <benoit.thebaudeau@advansee.com>
Wed, 13 Jun 2012 16:15:34 +0000 (18:15 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Wed, 27 Jun 2012 06:42:00 +0000 (14:42 +0800)
Commit 45001e9, which added support for RNGA, ignored the previous commit
984e976, which changed the data_present API.

Cc: Matt Mackall <mpm@selenic.com>
Cc: Sascha Hauer <kernel@pengutronix.de>
Cc: Alan Carvalho de Assis <acassis@gmail.com>
Cc: <linux-arm-kernel@lists.infradead.org>
Signed-off-by: Benoît Thébaudeau <benoit.thebaudeau@advansee.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
drivers/char/hw_random/mxc-rnga.c

index 187c6be..85074de 100644 (file)
@@ -24,6 +24,7 @@
 #include <linux/ioport.h>
 #include <linux/platform_device.h>
 #include <linux/hw_random.h>
+#include <linux/delay.h>
 #include <linux/io.h>
 
 /* RNGA Registers */
 
 static struct platform_device *rng_dev;
 
-static int mxc_rnga_data_present(struct hwrng *rng)
+static int mxc_rnga_data_present(struct hwrng *rng, int wait)
 {
-       int level;
        void __iomem *rng_base = (void __iomem *)rng->priv;
-
-       /* how many random numbers is in FIFO? [0-16] */
-       level = ((__raw_readl(rng_base + RNGA_STATUS) &
-                       RNGA_STATUS_LEVEL_MASK) >> 8);
-
-       return level > 0 ? 1 : 0;
+       int i;
+
+       for (i = 0; i < 20; i++) {
+               /* how many random numbers are in FIFO? [0-16] */
+               int level = (__raw_readl(rng_base + RNGA_STATUS) &
+                               RNGA_STATUS_LEVEL_MASK) >> 8;
+               if (level || !wait)
+                       return !!level;
+               udelay(10);
+       }
+       return 0;
 }
 
 static int mxc_rnga_data_read(struct hwrng *rng, u32 * data)