The Design and Implementation of the FreeBSD Operating System, Second Edition
Now available: The Design and Implementation of the FreeBSD Operating System (Second Edition)


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]

FreeBSD/Linux Kernel Cross Reference
sys/sys/syscallvar.h

Version: -  FREEBSD  -  FREEBSD-13-STABLE  -  FREEBSD-13-0  -  FREEBSD-12-STABLE  -  FREEBSD-12-0  -  FREEBSD-11-STABLE  -  FREEBSD-11-0  -  FREEBSD-10-STABLE  -  FREEBSD-10-0  -  FREEBSD-9-STABLE  -  FREEBSD-9-0  -  FREEBSD-8-STABLE  -  FREEBSD-8-0  -  FREEBSD-7-STABLE  -  FREEBSD-7-0  -  FREEBSD-6-STABLE  -  FREEBSD-6-0  -  FREEBSD-5-STABLE  -  FREEBSD-5-0  -  FREEBSD-4-STABLE  -  FREEBSD-3-STABLE  -  FREEBSD22  -  l41  -  OPENBSD  -  linux-2.6  -  MK84  -  PLAN9  -  xnu-8792 
SearchContext: -  none  -  3  -  10 

    1 /*      $NetBSD: syscallvar.h,v 1.12 2018/04/19 21:19:07 christos Exp $ */
    2 
    3 /*-
    4  * Copyright (c) 2008 The NetBSD Foundation, Inc.
    5  * All rights reserved.
    6  *
    7  * This code is derived from software developed for The NetBSD Foundation
    8  * by Andrew Doran.
    9  *
   10  * Redistribution and use in source and binary forms, with or without
   11  * modification, are permitted provided that the following conditions
   12  * are met:
   13  * 1. Redistributions of source code must retain the above copyright
   14  *    notice, this list of conditions and the following disclaimer.
   15  * 2. Redistributions in binary form must reproduce the above copyright
   16  *    notice, this list of conditions and the following disclaimer in the
   17  *    documentation and/or other materials provided with the distribution.
   18  *
   19  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
   20  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
   21  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
   22  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
   23  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
   24  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
   25  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
   26  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
   27  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
   28  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
   29  * POSSIBILITY OF SUCH DAMAGE.
   30  */
   31 
   32 #ifndef _SYS_SYSCALLVAR_H_
   33 #define _SYS_SYSCALLVAR_H_
   34 
   35 #ifndef _KERNEL
   36 #error nothing of interest to userspace here
   37 #endif
   38 
   39 #if defined(_KERNEL) && defined(_KERNEL_OPT)
   40 #include "opt_dtrace.h"
   41 #endif
   42 
   43 #include <sys/systm.h>
   44 #include <sys/proc.h>
   45 
   46 extern struct emul emul_netbsd;
   47 
   48 struct syscall_package {
   49         u_short         sp_code;
   50         u_short         sp_flags;
   51         sy_call_t       *sp_call;
   52 };
   53 
   54 void    syscall_init(void);
   55 int     syscall_establish(const struct emul *, const struct syscall_package *);
   56 int     syscall_disestablish(const struct emul *, const struct syscall_package *);
   57 
   58 static __inline int
   59 sy_call(const struct sysent *sy, struct lwp *l, const void *uap,
   60         register_t *rval)
   61 {
   62         int error;
   63 
   64         l->l_sysent = sy;
   65         error = (*sy->sy_call)(l, uap, rval);
   66         l->l_sysent = NULL;
   67 
   68         return error;
   69 }
   70 
   71 static __inline int
   72 sy_invoke(const struct sysent *sy, struct lwp *l, const void *uap,
   73         register_t *rval, int code)
   74 {
   75         const bool do_trace = l->l_proc->p_trace_enabled &&
   76             (sy->sy_flags & SYCALL_INDIRECT) == 0;
   77         int error;
   78 
   79 #ifdef KDTRACE_HOOKS
   80 #define KDTRACE_ENTRY(a)        (a)
   81 #else
   82 #define KDTRACE_ENTRY(a)        (0)
   83 #endif
   84         if (__predict_true(!(do_trace || KDTRACE_ENTRY(sy->sy_entry)))
   85             || (error = trace_enter(code, sy, uap)) == 0) {
   86                 rval[0] = 0;
   87 #if !defined(__mips__) && !defined(__m68k__)
   88                 /*
   89                  * Due to the mips userland code for SYS_break needing v1 to be
   90                  * preserved, we can't clear this on mips. 
   91                  */
   92                 rval[1] = 0;
   93 #endif
   94                 error = sy_call(sy, l, uap, rval);
   95         }
   96 
   97         if (__predict_false(do_trace || KDTRACE_ENTRY(sy->sy_return))) {
   98                 trace_exit(code, sy, uap, rval, error);
   99         }
  100         return error;
  101 }
  102 
  103 /* inclusion in the kernel currently depends on SYSCALL_DEBUG */
  104 extern const char * const syscallnames[];
  105 extern const char * const altsyscallnames[];
  106 
  107 #endif  /* _SYS_SYSCALLVAR_H_ */

Cache object: be62a58f385d84b750d4cafb02074b58


[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ] [ list types ] [ track identifier ]


This page is part of the FreeBSD/Linux Linux Kernel Cross-Reference, and was automatically generated using a modified version of the LXR engine.