syscall-eabi.S 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /* Copyright (C) 2005 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. The GNU C Library is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU Lesser General Public
  5. License as published by the Free Software Foundation; either
  6. version 2.1 of the License, or (at your option) any later version.
  7. The GNU C Library is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  10. Lesser General Public License for more details.
  11. You should have received a copy of the GNU Lesser General Public
  12. License along with the GNU C Library; if not, see
  13. <http://www.gnu.org/licenses/>. */
  14. #include <sys/syscall.h>
  15. #include <bits/arm_asm.h>
  16. /* In the EABI syscall interface, we don't need a special syscall to
  17. implement syscall(). It won't work reliably with 64-bit arguments
  18. (but that is true on many modern platforms). */
  19. .text
  20. .global syscall
  21. .type syscall,%function
  22. .align 4
  23. #if defined(THUMB1_ONLY)
  24. .thumb_func
  25. syscall:
  26. push {r4, r5, r6, r7}
  27. mov ip, r0
  28. mov r0, r1
  29. mov r1, r2
  30. mov r2, r3
  31. add r7, sp, #(4 * 4)
  32. ldmia r7!, {r3, r4, r5, r6}
  33. mov r7, ip
  34. swi 0x0
  35. pop {r4, r5, r6, r7}
  36. ldr r1, =0xfffff000
  37. cmp r0, r1
  38. bcs 1f
  39. bx lr
  40. 1:
  41. push {r3, lr}
  42. bl __syscall_error
  43. POP_RET
  44. .pool
  45. #else
  46. syscall:
  47. mov ip, sp
  48. stmfd sp!, {r4, r5, r6, r7}
  49. mov r7, r0
  50. mov r0, r1
  51. mov r1, r2
  52. mov r2, r3
  53. ldmfd ip, {r3, r4, r5, r6}
  54. swi 0x0
  55. ldmfd sp!, {r4, r5, r6, r7}
  56. cmn r0, #4096
  57. IT(t, cc)
  58. #if defined(__USE_BX__)
  59. bxcc lr
  60. #else
  61. movcc pc, lr
  62. #endif
  63. b __syscall_error
  64. #endif
  65. .size syscall,.-syscall