]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
[PATCH] fix rio_copy_to_card() for OLDPCI case
authorAl Viro <viro@zeniv.linux.org.uk>
Sat, 27 May 2006 05:48:08 +0000 (01:48 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Sat, 27 May 2006 06:26:49 +0000 (02:26 -0400)
It replaced old rio_pcicopy().  That puppy did _not_ do readb() (unlike
rio_memcpy_toio()) and current implementation is simply broken - readb(NULL)
is never a valid thing to do.

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
drivers/char/rio/rio_linux.c
drivers/char/rio/rio_linux.h

index 8f96b20090e8da8d3cd3e60630ef36cdf8bb8318..aa43436d5d1b7b331f077bb5f4b2bb12dc9817ba 100644 (file)
@@ -335,7 +335,7 @@ int RIODelay_ni(struct Port *PortP, int njiffies)
 
 void rio_copy_to_card(void *from, void __iomem *to, int len)
 {
-       rio_memcpy_toio(NULL, to, from, len);
+       rio_copy_toio(to, from, len);
 }
 
 int rio_minor(struct tty_struct *tty)
index 99c7447b6113100da43eae67351a1d659096a11b..55b9c97e8477c59fb3b39d924d9b51ba1a83ab68 100644 (file)
@@ -138,12 +138,23 @@ static inline void __iomem *rio_memcpy_toio(void __iomem *dummy, void __iomem *d
 
        while (n--) {
                writeb(*src++, dst++);
-               (void) readb(dummy);    /* WTF? */
+               (void) readb(dummy);
        }
 
        return dest;
 }
 
+static inline void __iomem *rio_copy_toio(void __iomem *dest, void *source, int n)
+{
+       char __iomem *dst = dest;
+       char *src = source;
+
+       while (n--)
+               writeb(*src++, dst++);
+
+       return dest;
+}
+
 
 static inline void *rio_memcpy_fromio(void *dest, void __iomem *source, int n)
 {
@@ -158,6 +169,7 @@ static inline void *rio_memcpy_fromio(void *dest, void __iomem *source, int n)
 
 #else
 #define rio_memcpy_toio(dummy,dest,source,n)   memcpy_toio(dest, source, n)
+#define rio_copy_toio                         memcpy_toio
 #define rio_memcpy_fromio                      memcpy_fromio
 #endif