syscalls-mips.S 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /*
  2. * Copyright (c) 2000, 2001, 2002, 2003, 2004, 2005, 2008, 2009
  3. * The President and Fellows of Harvard College.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. * 1. Redistributions of source code must retain the above copyright
  9. * notice, this list of conditions and the following disclaimer.
  10. * 2. Redistributions in binary form must reproduce the above copyright
  11. * notice, this list of conditions and the following disclaimer in the
  12. * documentation and/or other materials provided with the distribution.
  13. * 3. Neither the name of the University nor the names of its contributors
  14. * may be used to endorse or promote products derived from this software
  15. * without specific prior written permission.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE UNIVERSITY AND CONTRIBUTORS ``AS IS'' AND
  18. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  19. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  20. * ARE DISCLAIMED. IN NO EVENT SHALL THE UNIVERSITY OR CONTRIBUTORS BE LIABLE
  21. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  22. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  23. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  24. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  25. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  26. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  27. * SUCH DAMAGE.
  28. */
  29. /*
  30. * This file is copied to syscalls.S, and then the actual syscalls are
  31. * appended as lines of the form
  32. * SYSCALL(symbol, number)
  33. *
  34. * Warning: gccs before 3.0 run cpp in -traditional mode on .S files.
  35. * So if you use an older gcc you'll need to change the token pasting
  36. * in SYSCALL().
  37. */
  38. #include <kern/syscall.h>
  39. #include <machine/regdefs.h>
  40. /*
  41. * Definition for each syscall.
  42. * All we do is load the syscall number into v0, the register the
  43. * kernel expects to find it in, and jump to the shared syscall code.
  44. * (Note that the addiu instruction is in the jump's delay slot.)
  45. */
  46. #define SYSCALL(sym, num) \
  47. .set noreorder ; \
  48. .globl sym ; \
  49. .type sym,@function ; \
  50. .ent sym ; \
  51. sym: ; \
  52. j __syscall ; \
  53. addiu v0, $0, SYS_##sym ; \
  54. .end sym ; \
  55. .set reorder
  56. /*
  57. * Now, the shared system call code.
  58. * The MIPS syscall ABI is as follows:
  59. *
  60. * On entry, call number in v0. The rest is like a normal function
  61. * call: four args in a0-a3, the other args on the stack.
  62. *
  63. * On successful return, zero in a3 register; return value in v0
  64. * (v0 and v1 for a 64-bit return value).
  65. *
  66. * On error return, nonzero in a3 register; errno value in v0.
  67. *
  68. * The use of a3 as a return register to hold the success flag is
  69. * gross, but I didn't make it up.
  70. *
  71. * Note that by longstanding Unix convention and POSIX decree, errno
  72. * is not to be set unless the call actually fails.
  73. */
  74. .set noreorder
  75. .text
  76. .type __syscall,@function
  77. .ent __syscall
  78. __syscall:
  79. syscall /* make system call */
  80. beq a3, $0, 1f /* if a3 is zero, call succeeded */
  81. nop /* delay slot */
  82. sw v0, errno /* call failed: store errno */
  83. li v1, -1 /* and force return value to -1 */
  84. li v0, -1
  85. 1:
  86. j ra /* return */
  87. nop /* delay slot */
  88. .end __syscall
  89. .set reorder