memcpy.S 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. * memcpy.S
  3. *
  4. * Copyright(c) 2007-2022 Jianjun Jiang <8192542@qq.com>
  5. * Official site: http://xboot.org
  6. * Mobile phone: +86-18665388956
  7. * QQ: 8192542
  8. *
  9. * Permission is hereby granted, free of charge, to any person obtaining a copy
  10. * of this software and associated documentation files (the "Software"), to deal
  11. * in the Software without restriction, including without limitation the rights
  12. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  13. * copies of the Software, and to permit persons to whom the Software is
  14. * furnished to do so, subject to the following conditions:
  15. *
  16. * The above copyright notice and this permission notice shall be included in all
  17. * copies or substantial portions of the Software.
  18. *
  19. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  20. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  21. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  22. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  23. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  24. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  25. * SOFTWARE.
  26. *
  27. */
  28. #include <linkage.h>
  29. .global memcpy
  30. .type memcpy, %function
  31. .align 3
  32. memcpy:
  33. move t6, a0
  34. sltiu a3, a2, 128
  35. bnez a3, 4f
  36. andi a3, t6, REGSZ - 1
  37. andi a4, a1, REGSZ - 1
  38. bne a3, a4, 4f
  39. beqz a3, 2f
  40. andi a3, a1, ~(REGSZ - 1)
  41. addi a3, a3, REGSZ
  42. sub a4, a3, a1
  43. 1: lb a5, 0(a1)
  44. addi a1, a1, 1
  45. sb a5, 0(t6)
  46. addi t6, t6, 1
  47. bltu a1, a3, 1b
  48. sub a2, a2, a4
  49. 2: andi a4, a2, ~((16 * REGSZ) - 1)
  50. beqz a4, 4f
  51. add a3, a1, a4
  52. 3: LREG a4, 0(a1)
  53. LREG a5, REGSZ(a1)
  54. LREG a6, 2 * REGSZ(a1)
  55. LREG a7, 3 * REGSZ(a1)
  56. LREG t0, 4 * REGSZ(a1)
  57. LREG t1, 5 * REGSZ(a1)
  58. LREG t2, 6 * REGSZ(a1)
  59. LREG t3, 7 * REGSZ(a1)
  60. LREG t4, 8 * REGSZ(a1)
  61. LREG t5, 9 * REGSZ(a1)
  62. SREG a4, 0(t6)
  63. SREG a5, REGSZ(t6)
  64. SREG a6, 2 * REGSZ(t6)
  65. SREG a7, 3 * REGSZ(t6)
  66. SREG t0, 4 * REGSZ(t6)
  67. SREG t1, 5 * REGSZ(t6)
  68. SREG t2, 6 * REGSZ(t6)
  69. SREG t3, 7 * REGSZ(t6)
  70. SREG t4, 8 * REGSZ(t6)
  71. SREG t5, 9 * REGSZ(t6)
  72. LREG a4, 10 * REGSZ(a1)
  73. LREG a5, 11 * REGSZ(a1)
  74. LREG a6, 12 * REGSZ(a1)
  75. LREG a7, 13 * REGSZ(a1)
  76. LREG t0, 14 * REGSZ(a1)
  77. LREG t1, 15 * REGSZ(a1)
  78. addi a1, a1, 16 * REGSZ
  79. SREG a4, 10 * REGSZ(t6)
  80. SREG a5, 11 * REGSZ(t6)
  81. SREG a6, 12 * REGSZ(t6)
  82. SREG a7, 13 * REGSZ(t6)
  83. SREG t0, 14 * REGSZ(t6)
  84. SREG t1, 15 * REGSZ(t6)
  85. addi t6, t6, 16 * REGSZ
  86. bltu a1, a3, 3b
  87. andi a2, a2, (16 * REGSZ) - 1
  88. 4: beqz a2, 6f
  89. add a3, a1, a2
  90. or a5, a1, t6
  91. or a5, a5, a3
  92. andi a5, a5, 3
  93. bnez a5, 5f
  94. 7: lw a4, 0(a1)
  95. addi a1, a1, 4
  96. sw a4, 0(t6)
  97. addi t6, t6, 4
  98. bltu a1, a3, 7b
  99. ret
  100. 5: lb a4, 0(a1)
  101. addi a1, a1, 1
  102. sb a4, 0(t6)
  103. addi t6, t6, 1
  104. bltu a1, a3, 5b
  105. 6: ret