copy_to_user.S 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (C) 2012 ARM Ltd.
  4. */
  5. #include <linux/linkage.h>
  6. #include <asm/asm-uaccess.h>
  7. #include <asm/assembler.h>
  8. #include <asm/cache.h>
  9. /*
  10. * Copy to user space from a kernel buffer (alignment handled by the hardware)
  11. *
  12. * Parameters:
  13. * x0 - to
  14. * x1 - from
  15. * x2 - n
  16. * Returns:
  17. * x0 - bytes not copied
  18. */
  19. .macro ldrb1 reg, ptr, val
  20. ldrb \reg, [\ptr], \val
  21. .endm
  22. .macro strb1 reg, ptr, val
  23. user_ldst 9998f, sttrb, \reg, \ptr, \val
  24. .endm
  25. .macro ldrh1 reg, ptr, val
  26. ldrh \reg, [\ptr], \val
  27. .endm
  28. .macro strh1 reg, ptr, val
  29. user_ldst 9997f, sttrh, \reg, \ptr, \val
  30. .endm
  31. .macro ldr1 reg, ptr, val
  32. ldr \reg, [\ptr], \val
  33. .endm
  34. .macro str1 reg, ptr, val
  35. user_ldst 9997f, sttr, \reg, \ptr, \val
  36. .endm
  37. .macro ldp1 reg1, reg2, ptr, val
  38. ldp \reg1, \reg2, [\ptr], \val
  39. .endm
  40. .macro stp1 reg1, reg2, ptr, val
  41. user_stp 9997f, \reg1, \reg2, \ptr, \val
  42. .endm
  43. .macro cpy1 dst, src, count
  44. .arch_extension mops
  45. USER_CPY(9997f, 1, cpyfpwt [\dst]!, [\src]!, \count!)
  46. USER_CPY(9996f, 1, cpyfmwt [\dst]!, [\src]!, \count!)
  47. USER_CPY(9996f, 1, cpyfewt [\dst]!, [\src]!, \count!)
  48. .endm
  49. end .req x5
  50. srcin .req x15
  51. SYM_FUNC_START(__arch_copy_to_user)
  52. add end, x0, x2
  53. mov srcin, x1
  54. #include "copy_template.S"
  55. mov x0, #0
  56. ret
  57. // Exception fixups
  58. 9996: b.cs 9997f
  59. // Registers are in Option A format
  60. add dst, dst, count
  61. 9997: cmp dst, dstin
  62. b.ne 9998f
  63. // Before being absolutely sure we couldn't copy anything, try harder
  64. ldrb tmp1w, [srcin]
  65. USER(9998f, sttrb tmp1w, [dst])
  66. add dst, dst, #1
  67. 9998: sub x0, end, dst // bytes not copied
  68. ret
  69. SYM_FUNC_END(__arch_copy_to_user)
  70. EXPORT_SYMBOL(__arch_copy_to_user)