[SPARC64]: Fix some Niagara memcpy() bugs.
authorDavid S. Miller <davem@sunset.davemloft.net>
Sat, 11 Feb 2006 18:30:41 +0000 (10:30 -0800)
committerDavid S. Miller <davem@sunset.davemloft.net>
Mon, 20 Mar 2006 09:12:20 +0000 (01:12 -0800)
We need to restore the %asi register properly.
For the kernel this means get_fs(), for user this
means ASI_PNF.

Also, NGcopy_to_user.S was including U3memcpy.S instead
of NGmemcpy.S, oops :-)

Signed-off-by: David S. Miller <davem@davemloft.net>
arch/sparc64/lib/NGcopy_to_user.S
arch/sparc64/lib/NGmemcpy.S

index 4a12395b4502715afcb597538d376ac306b1b7cd..34112d5054ef9895e21d365284ce76b0042bbab0 100644 (file)
@@ -37,4 +37,4 @@
         nop
 #endif
 
-#include "U3memcpy.S"
+#include "NGmemcpy.S"
index a39aa3bd434529bf1525b380956bd0b6727ea370..8e522b3dc095e2100760c87425488de66ecbfad7 100644 (file)
@@ -5,11 +5,15 @@
 
 #ifdef __KERNEL__
 #include <asm/asi.h>
+#include <asm/thread_info.h>
 #define GLOBAL_SPARE   %g7
-#define RESTORE_ASI    wr      %g0, ASI_AIUS, %asi
+#define RESTORE_ASI(TMP)       \
+       ldub    [%g6 + TI_CURRENT_DS], TMP;  \
+       wr      TMP, 0x0, %asi;
 #else
 #define GLOBAL_SPARE   %g5
-#define RESTORE_ASI
+#define RESTORE_ASI(TMP)       \
+       wr      %g0, ASI_PNF, %asi
 #endif
 
 #ifndef STORE_ASI
@@ -246,7 +250,7 @@ FUNC_NAME:  /* %o0=dst, %o1=src, %o2=len */
        /* %o2 contains any final bytes still needed to be copied
         * over. If anything is left, we copy it one byte at a time.
         */
-       RESTORE_ASI
+       RESTORE_ASI(%o3)
        brz,pt          %o2, 85f
         sub            %o0, %o1, %o3
        ba,a,pt         %XCC, 90f