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/contrib/openzfs/include/os/linux/spl/sys/user.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 /*
    2  *  Copyright (C) 2015 Cluster Inc.
    3  *  Produced at ClusterHQ Inc (cf, DISCLAIMER).
    4  *  Written by Richard Yao <richard.yao@clusterhq.com>.
    5  *
    6  *  This file is part of the SPL, Solaris Porting Layer.
    7  *
    8  *  The SPL is free software; you can redistribute it and/or modify it
    9  *  under the terms of the GNU General Public License as published by the
   10  *  Free Software Foundation; either version 2 of the License, or (at your
   11  *  option) any later version.
   12  *
   13  *  The SPL is distributed in the hope that it will be useful, but WITHOUT
   14  *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
   15  *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
   16  *  for more details.
   17  *
   18  *  You should have received a copy of the GNU General Public License along
   19  *  with the SPL.  If not, see <http://www.gnu.org/licenses/>.
   20  */
   21 
   22 #ifndef _SPL_USER_H
   23 #define _SPL_USER_H
   24 
   25 /*
   26  * We have uf_info_t for areleasef(). We implement areleasef() using a global
   27  * linked list of all open file descriptors with the task structs referenced,
   28  * so accessing the correct descriptor from areleasef() only requires knowing
   29  * about the Linux task_struct. Since this is internal to our compatibility
   30  * layer, we make it an opaque type.
   31  *
   32  * XXX: If the descriptor changes under us and we do not do a getf() between
   33  * the change and using it, we would get an incorrect reference.
   34  */
   35 
   36 struct uf_info;
   37 typedef struct uf_info uf_info_t;
   38 
   39 #define P_FINFO(x) ((uf_info_t *)x)
   40 
   41 #endif /* SPL_USER_H */

Cache object: 4fc0bad82e51b00916930cf3d8b1b589


[ 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.