SYS.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /* $OpenBSD: SYS.h,v 1.3 2003/06/02 23:28:09 millert Exp $ */
  2. /* $NetBSD: SYS.h,v 1.2 1999/02/15 04:54:36 hubertf Exp $ */
  3. /*-
  4. * Copyright (c) 1992, 1993
  5. * The Regents of the University of California. All rights reserved.
  6. *
  7. * This software was developed by the Computer Systems Engineering group
  8. * at Lawrence Berkeley Laboratory under DARPA contract BG 91-66 and
  9. * contributed to Berkeley.
  10. *
  11. * Redistribution and use in source and binary forms, with or without
  12. * modification, are permitted provided that the following conditions
  13. * are met:
  14. * 1. Redistributions of source code must retain the above copyright
  15. * notice, this list of conditions and the following disclaimer.
  16. * 2. Redistributions in binary form must reproduce the above copyright
  17. * notice, this list of conditions and the following disclaimer in the
  18. * documentation and/or other materials provided with the distribution.
  19. * 3. Neither the name of the University nor the names of its contributors
  20. * may be used to endorse or promote products derived from this software
  21. * without specific prior written permission.
  22. *
  23. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  24. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  25. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  26. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  27. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  28. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  29. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  30. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  31. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  32. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  33. * SUCH DAMAGE.
  34. *
  35. * @(#)SYS.h 8.1 (Berkeley) 6/4/93
  36. *
  37. * from: Header: SYS.h,v 1.2 92/07/03 18:57:00 torek Exp
  38. * $Id: SYS.h,v 1.3 2003/06/02 23:28:09 millert Exp $
  39. */
  40. #include <machine/asm.h>
  41. #include <sys/syscall.h>
  42. #include <machine/trap.h>
  43. #ifdef __STDC__
  44. #define _CAT(x,y) x##y
  45. #else
  46. #define _CAT(x,y) x/**/y
  47. #endif
  48. /*
  49. * ERROR branches to cerror. This is done with a macro so that I can
  50. * change it to be position independent later, if need be.
  51. */
  52. #ifdef PIC
  53. #define ERROR() \
  54. PIC_PROLOGUE(%g1,%g2); \
  55. ld [%g1+cerror],%g2; jmp %g2; nop
  56. #else
  57. #define ERROR() \
  58. sethi %hi(cerror),%g1; or %lo(cerror),%g1,%g1; jmp %g1; nop
  59. #endif
  60. /*
  61. * SYSCALL is used when further action must be taken before returning.
  62. * Note that it adds a `nop' over what we could do, if we only knew what
  63. * came at label 1....
  64. */
  65. #define SYSCALL(x) \
  66. ENTRY(x); mov _CAT(SYS_,x),%g1; t ST_SYSCALL; bcc 1f; nop; ERROR(); 1:
  67. /*
  68. * RSYSCALL is used when the system call should just return. Here
  69. * we use the SYSCALL_G2RFLAG to put the `success' return address in %g2
  70. * and avoid a branch.
  71. */
  72. #define RSYSCALL(x) \
  73. ENTRY(x); mov (_CAT(SYS_,x))|SYSCALL_G2RFLAG,%g1; add %o7,8,%g2; \
  74. t ST_SYSCALL; ERROR()
  75. /*
  76. * PSEUDO(x,y) is like RSYSCALL(y) except that the name is x.
  77. */
  78. #define PSEUDO(x,y) \
  79. ENTRY(x); mov (_CAT(SYS_,y))|SYSCALL_G2RFLAG,%g1; add %o7,8,%g2; \
  80. t ST_SYSCALL; ERROR()
  81. /*
  82. * SYSCALL_NOERROR is like SYSCALL, except it's used for syscalls
  83. * that never fail.
  84. *
  85. * XXX - This should be optimized.
  86. */
  87. #define SYSCALL_NOERROR(x) \
  88. ENTRY(x); mov _CAT(SYS_,x),%g1; t ST_SYSCALL
  89. /*
  90. * RSYSCALL_NOERROR is like RSYSCALL, except it's used for syscalls
  91. * that never fail.
  92. *
  93. * XXX - This should be optimized.
  94. */
  95. #define RSYSCALL_NOERROR(x) \
  96. ENTRY(x); mov (_CAT(SYS_,x))|SYSCALL_G2RFLAG,%g1; add %o7,8,%g2; \
  97. t ST_SYSCALL
  98. .globl cerror