memcpy.S 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * linux/arch/arm/lib/memcpy.S
  4. *
  5. * Author: Nicolas Pitre
  6. * Created: Sep 28, 2005
  7. * Copyright: MontaVista Software, Inc.
  8. */
  9. #include <linux/linkage.h>
  10. #include <asm/assembler.h>
  11. #include <asm/unwind.h>
  12. #define LDR1W_SHIFT 0
  13. #define STR1W_SHIFT 0
  14. .macro ldr1w ptr reg abort
  15. W(ldr) \reg, [\ptr], #4
  16. .endm
  17. .macro ldr4w ptr reg1 reg2 reg3 reg4 abort
  18. ldmia \ptr!, {\reg1, \reg2, \reg3, \reg4}
  19. .endm
  20. .macro ldr8w ptr reg1 reg2 reg3 reg4 reg5 reg6 reg7 reg8 abort
  21. ldmia \ptr!, {\reg1, \reg2, \reg3, \reg4, \reg5, \reg6, \reg7, \reg8}
  22. .endm
  23. .macro ldr1b ptr reg cond=al abort
  24. ldrb\cond \reg, [\ptr], #1
  25. .endm
  26. .macro str1w ptr reg abort
  27. W(str) \reg, [\ptr], #4
  28. .endm
  29. .macro str8w ptr reg1 reg2 reg3 reg4 reg5 reg6 reg7 reg8 abort
  30. stmia \ptr!, {\reg1, \reg2, \reg3, \reg4, \reg5, \reg6, \reg7, \reg8}
  31. .endm
  32. .macro str1b ptr reg cond=al abort
  33. strb\cond \reg, [\ptr], #1
  34. .endm
  35. .macro enter regs:vararg
  36. UNWIND( .save {r0, \regs} )
  37. stmdb sp!, {r0, \regs}
  38. .endm
  39. .macro exit regs:vararg
  40. ldmfd sp!, {r0, \regs}
  41. .endm
  42. .text
  43. /* Prototype: void *memcpy(void *dest, const void *src, size_t n); */
  44. ENTRY(__memcpy)
  45. ENTRY(mmiocpy)
  46. WEAK(memcpy)
  47. #include "copy_template.S"
  48. ENDPROC(memcpy)
  49. ENDPROC(mmiocpy)
  50. ENDPROC(__memcpy)