csumpartialcopyuser.S 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. * linux/arch/arm/lib/csumpartialcopyuser.S
  3. *
  4. * Copyright (C) 1995-1998 Russell King
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. *
  10. * 27/03/03 Ian Molton Clean up CONFIG_CPU
  11. *
  12. */
  13. #include <linux/linkage.h>
  14. #include <asm/assembler.h>
  15. #include <asm/errno.h>
  16. #include <asm/asm-offsets.h>
  17. .text
  18. .macro save_regs
  19. stmfd sp!, {r1, r2, r4 - r8, lr}
  20. .endm
  21. .macro load_regs
  22. ldmfd sp!, {r1, r2, r4 - r8, pc}
  23. .endm
  24. .macro load1b, reg1
  25. 9999: ldrbt \reg1, [r0], $1
  26. .section __ex_table, "a"
  27. .align 3
  28. .long 9999b, 6001f
  29. .previous
  30. .endm
  31. .macro load2b, reg1, reg2
  32. 9999: ldrbt \reg1, [r0], $1
  33. 9998: ldrbt \reg2, [r0], $1
  34. .section __ex_table, "a"
  35. .long 9999b, 6001f
  36. .long 9998b, 6001f
  37. .previous
  38. .endm
  39. .macro load1l, reg1
  40. 9999: ldrt \reg1, [r0], $4
  41. .section __ex_table, "a"
  42. .align 3
  43. .long 9999b, 6001f
  44. .previous
  45. .endm
  46. .macro load2l, reg1, reg2
  47. 9999: ldrt \reg1, [r0], $4
  48. 9998: ldrt \reg2, [r0], $4
  49. .section __ex_table, "a"
  50. .long 9999b, 6001f
  51. .long 9998b, 6001f
  52. .previous
  53. .endm
  54. .macro load4l, reg1, reg2, reg3, reg4
  55. 9999: ldrt \reg1, [r0], $4
  56. 9998: ldrt \reg2, [r0], $4
  57. 9997: ldrt \reg3, [r0], $4
  58. 9996: ldrt \reg4, [r0], $4
  59. .section __ex_table, "a"
  60. .long 9999b, 6001f
  61. .long 9998b, 6001f
  62. .long 9997b, 6001f
  63. .long 9996b, 6001f
  64. .previous
  65. .endm
  66. /*
  67. * unsigned int
  68. * csum_partial_copy_from_user(const char *src, char *dst, int len, int sum, int *err_ptr)
  69. * r0 = src, r1 = dst, r2 = len, r3 = sum, [sp] = *err_ptr
  70. * Returns : r0 = checksum, [[sp, #0], #0] = 0 or -EFAULT
  71. */
  72. #define FN_ENTRY ENTRY(csum_partial_copy_from_user)
  73. #define FN_EXIT ENDPROC(csum_partial_copy_from_user)
  74. #include "csumpartialcopygeneric.S"
  75. /*
  76. * FIXME: minor buglet here
  77. * We don't return the checksum for the data present in the buffer. To do
  78. * so properly, we would have to add in whatever registers were loaded before
  79. * the fault, which, with the current asm above is not predictable.
  80. */
  81. .section .fixup,"ax"
  82. .align 4
  83. 6001: mov r4, #-EFAULT
  84. ldr r5, [fp, #4] @ *err_ptr
  85. str r4, [r5]
  86. ldmia sp, {r1, r2} @ retrieve dst, len
  87. add r2, r2, r1
  88. mov r0, #0 @ zero the buffer
  89. 6002: teq r2, r1
  90. strneb r0, [r1], #1
  91. bne 6002b
  92. load_regs
  93. .previous