|  | #ifndef __ASM_MEMCPY_UTILS | 
|  | #define __ASM_MEMCPY_UTILS | 
|  |  | 
|  | #include <linux/linkage.h> | 
|  | #include <asm/asi.h> | 
|  | #include <asm/visasm.h> | 
|  |  | 
|  | ENTRY(__restore_asi_fp) | 
|  | VISExitHalf | 
|  | retl | 
|  | wr	%g0, ASI_AIUS, %asi | 
|  | ENDPROC(__restore_asi_fp) | 
|  |  | 
|  | ENTRY(__restore_asi) | 
|  | retl | 
|  | wr	%g0, ASI_AIUS, %asi | 
|  | ENDPROC(__restore_asi) | 
|  |  | 
|  | ENTRY(memcpy_retl_o2) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | mov	%o2, %o0 | 
|  | ENDPROC(memcpy_retl_o2) | 
|  | ENTRY(memcpy_retl_o2_plus_1) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 1, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_1) | 
|  | ENTRY(memcpy_retl_o2_plus_3) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 3, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_3) | 
|  | ENTRY(memcpy_retl_o2_plus_4) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_4) | 
|  | ENTRY(memcpy_retl_o2_plus_5) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_5) | 
|  | ENTRY(memcpy_retl_o2_plus_6) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 6, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_6) | 
|  | ENTRY(memcpy_retl_o2_plus_7) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 7, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_7) | 
|  | ENTRY(memcpy_retl_o2_plus_8) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 8, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_8) | 
|  | ENTRY(memcpy_retl_o2_plus_15) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 15, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_15) | 
|  | ENTRY(memcpy_retl_o2_plus_15_8) | 
|  | add	%o2, 15, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 8, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_15_8) | 
|  | ENTRY(memcpy_retl_o2_plus_16) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 16, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_16) | 
|  | ENTRY(memcpy_retl_o2_plus_24) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 24, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_24) | 
|  | ENTRY(memcpy_retl_o2_plus_31) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 31, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_31) | 
|  | ENTRY(memcpy_retl_o2_plus_32) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 32, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_32) | 
|  | ENTRY(memcpy_retl_o2_plus_31_32) | 
|  | add	%o2, 31, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 32, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_31_32) | 
|  | ENTRY(memcpy_retl_o2_plus_31_24) | 
|  | add	%o2, 31, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 24, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_31_24) | 
|  | ENTRY(memcpy_retl_o2_plus_31_16) | 
|  | add	%o2, 31, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 16, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_31_16) | 
|  | ENTRY(memcpy_retl_o2_plus_31_8) | 
|  | add	%o2, 31, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 8, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_31_8) | 
|  | ENTRY(memcpy_retl_o2_plus_63) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 63, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63) | 
|  | ENTRY(memcpy_retl_o2_plus_63_64) | 
|  | add	%o2, 63, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 64, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63_64) | 
|  | ENTRY(memcpy_retl_o2_plus_63_56) | 
|  | add	%o2, 63, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 56, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63_56) | 
|  | ENTRY(memcpy_retl_o2_plus_63_48) | 
|  | add	%o2, 63, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 48, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63_48) | 
|  | ENTRY(memcpy_retl_o2_plus_63_40) | 
|  | add	%o2, 63, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 40, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63_40) | 
|  | ENTRY(memcpy_retl_o2_plus_63_32) | 
|  | add	%o2, 63, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 32, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63_32) | 
|  | ENTRY(memcpy_retl_o2_plus_63_24) | 
|  | add	%o2, 63, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 24, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63_24) | 
|  | ENTRY(memcpy_retl_o2_plus_63_16) | 
|  | add	%o2, 63, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 16, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63_16) | 
|  | ENTRY(memcpy_retl_o2_plus_63_8) | 
|  | add	%o2, 63, %o2 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, 8, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_63_8) | 
|  | ENTRY(memcpy_retl_o2_plus_o5) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_1) | 
|  | add	%o5, 1, %o5 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_1) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_4) | 
|  | add	%o5, 4, %o5 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_4) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_8) | 
|  | add	%o5, 8, %o5 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_8) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_16) | 
|  | add	%o5, 16, %o5 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_16) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_24) | 
|  | add	%o5, 24, %o5 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_24) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_32) | 
|  | add	%o5, 32, %o5 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_32) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_64) | 
|  | add	%o5, 32, %o5 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_64) | 
|  | ENTRY(memcpy_retl_o2_plus_g1) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %g1, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_g1) | 
|  | ENTRY(memcpy_retl_o2_plus_g1_plus_1) | 
|  | add	%g1, 1, %g1 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %g1, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_g1_plus_1) | 
|  | ENTRY(memcpy_retl_o2_plus_g1_plus_8) | 
|  | add	%g1, 8, %g1 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %g1, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_g1_plus_8) | 
|  | ENTRY(memcpy_retl_o2_plus_o4) | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_8) | 
|  | add	%o4, 8, %o4 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_8) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_16) | 
|  | add	%o4, 16, %o4 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_16) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_24) | 
|  | add	%o4, 24, %o4 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_24) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_32) | 
|  | add	%o4, 32, %o4 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_32) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_40) | 
|  | add	%o4, 40, %o4 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_40) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_48) | 
|  | add	%o4, 48, %o4 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_48) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_56) | 
|  | add	%o4, 56, %o4 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_56) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_64) | 
|  | add	%o4, 64, %o4 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_64) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_64) | 
|  | add	%o5, 64, %o5 | 
|  | ba,pt	%xcc, __restore_asi | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_64) | 
|  | ENTRY(memcpy_retl_o2_plus_o3_fp) | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o3, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o3_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o3_plus_1_fp) | 
|  | add	%o3, 1, %o3 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o3, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o3_plus_1_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o3_plus_4_fp) | 
|  | add	%o3, 4, %o3 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o3, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o3_plus_4_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_fp) | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_8_fp) | 
|  | add	%o4, 8, %o4 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_8_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_16_fp) | 
|  | add	%o4, 16, %o4 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_16_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_24_fp) | 
|  | add	%o4, 24, %o4 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_24_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_32_fp) | 
|  | add	%o4, 32, %o4 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_32_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_40_fp) | 
|  | add	%o4, 40, %o4 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_40_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_48_fp) | 
|  | add	%o4, 48, %o4 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_48_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_56_fp) | 
|  | add	%o4, 56, %o4 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_56_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o4_plus_64_fp) | 
|  | add	%o4, 64, %o4 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o4, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o4_plus_64_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_fp) | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_64_fp) | 
|  | add	%o5, 64, %o5 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_64_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_56_fp) | 
|  | add	%o5, 56, %o5 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_56_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_48_fp) | 
|  | add	%o5, 48, %o5 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_48_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_40_fp) | 
|  | add	%o5, 40, %o5 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_40_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_32_fp) | 
|  | add	%o5, 32, %o5 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_32_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_24_fp) | 
|  | add	%o5, 24, %o5 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_24_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_16_fp) | 
|  | add	%o5, 16, %o5 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_16_fp) | 
|  | ENTRY(memcpy_retl_o2_plus_o5_plus_8_fp) | 
|  | add	%o5, 8, %o5 | 
|  | ba,pt	%xcc, __restore_asi_fp | 
|  | add	%o2, %o5, %o0 | 
|  | ENDPROC(memcpy_retl_o2_plus_o5_plus_8_fp) | 
|  |  | 
|  | #endif |