Home | History | Annotate | Line # | Download | only in specfs
specdev.h revision 1.23.2.1
      1  1.23.2.1     skrll /*	$NetBSD: specdev.h,v 1.23.2.1 2004/08/03 10:54:10 skrll Exp $	*/
      2       1.8       cgd 
      3       1.1       cgd /*
      4       1.7   mycroft  * Copyright (c) 1990, 1993
      5       1.7   mycroft  *	The Regents of the University of California.  All rights reserved.
      6       1.1       cgd  *
      7       1.1       cgd  * Redistribution and use in source and binary forms, with or without
      8       1.1       cgd  * modification, are permitted provided that the following conditions
      9       1.1       cgd  * are met:
     10       1.1       cgd  * 1. Redistributions of source code must retain the above copyright
     11       1.1       cgd  *    notice, this list of conditions and the following disclaimer.
     12       1.1       cgd  * 2. Redistributions in binary form must reproduce the above copyright
     13       1.1       cgd  *    notice, this list of conditions and the following disclaimer in the
     14       1.1       cgd  *    documentation and/or other materials provided with the distribution.
     15  1.23.2.1     skrll  * 3. Neither the name of the University nor the names of its contributors
     16       1.1       cgd  *    may be used to endorse or promote products derived from this software
     17       1.1       cgd  *    without specific prior written permission.
     18       1.1       cgd  *
     19       1.1       cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20       1.1       cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21       1.1       cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22       1.1       cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23       1.1       cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24       1.1       cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25       1.1       cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26       1.1       cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27       1.1       cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28       1.1       cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29       1.1       cgd  * SUCH DAMAGE.
     30       1.1       cgd  *
     31      1.17      fvdl  *	@(#)specdev.h	8.6 (Berkeley) 5/21/95
     32       1.1       cgd  */
     33      1.23      matt #ifndef _MISCFS_SPECFS_SPECDEV_H_
     34      1.23      matt #define _MISCFS_SPECFS_SPECDEV_H_
     35       1.1       cgd 
     36       1.1       cgd /*
     37       1.1       cgd  * This structure defines the information maintained about
     38       1.1       cgd  * special devices. It is allocated in checkalias and freed
     39       1.1       cgd  * in vgone.
     40       1.1       cgd  */
     41  1.23.2.1     skrll struct spec_cow_entry {
     42  1.23.2.1     skrll 	SLIST_ENTRY(spec_cow_entry) ce_list;
     43  1.23.2.1     skrll 	int (*ce_func)(void *, struct buf *);
     44  1.23.2.1     skrll 	void *ce_cookie;
     45  1.23.2.1     skrll };
     46  1.23.2.1     skrll 
     47       1.1       cgd struct specinfo {
     48       1.1       cgd 	struct	vnode **si_hashchain;
     49       1.1       cgd 	struct	vnode *si_specnext;
     50      1.18      fvdl 	struct	mount *si_mountpoint;
     51       1.1       cgd 	dev_t	si_rdev;
     52      1.15    kleink 	struct	lockf *si_lockf;
     53  1.23.2.1     skrll 	struct simplelock si_cow_slock;
     54  1.23.2.1     skrll 	SLIST_HEAD(, spec_cow_entry) si_cow_head;
     55  1.23.2.1     skrll 	int si_cow_req;
     56  1.23.2.1     skrll 	int si_cow_count;
     57       1.1       cgd };
     58       1.1       cgd /*
     59       1.1       cgd  * Exported shorthand
     60       1.1       cgd  */
     61      1.15    kleink #define v_rdev		v_specinfo->si_rdev
     62      1.15    kleink #define v_hashchain	v_specinfo->si_hashchain
     63      1.15    kleink #define v_specnext	v_specinfo->si_specnext
     64      1.15    kleink #define v_speclockf	v_specinfo->si_lockf
     65      1.18      fvdl #define v_specmountpoint v_specinfo->si_mountpoint
     66  1.23.2.1     skrll #define v_spec_cow_slock v_specinfo->si_cow_slock
     67  1.23.2.1     skrll #define v_spec_cow_head	v_specinfo->si_cow_head
     68  1.23.2.1     skrll #define v_spec_cow_req	v_specinfo->si_cow_req
     69  1.23.2.1     skrll #define v_spec_cow_count v_specinfo->si_cow_count
     70  1.23.2.1     skrll 
     71  1.23.2.1     skrll #define SPEC_COW_LOCK(si, s) \
     72  1.23.2.1     skrll 	do { \
     73  1.23.2.1     skrll 		(s) = splbio(); \
     74  1.23.2.1     skrll 		simple_lock(&(si)->si_cow_slock) ; \
     75  1.23.2.1     skrll 	} while (/*CONSTCOND*/0)
     76  1.23.2.1     skrll 
     77  1.23.2.1     skrll #define SPEC_COW_UNLOCK(si, s) \
     78  1.23.2.1     skrll 	do { \
     79  1.23.2.1     skrll 		simple_unlock(&(si)->si_cow_slock) ; \
     80  1.23.2.1     skrll 		splx((s)); \
     81  1.23.2.1     skrll 	} while (/*CONSTCOND*/0)
     82       1.1       cgd 
     83       1.1       cgd /*
     84       1.1       cgd  * Special device management
     85       1.1       cgd  */
     86       1.1       cgd #define	SPECHSZ	64
     87       1.1       cgd #if	((SPECHSZ&(SPECHSZ-1)) == 0)
     88       1.1       cgd #define	SPECHASH(rdev)	(((rdev>>5)+(rdev))&(SPECHSZ-1))
     89       1.1       cgd #else
     90       1.1       cgd #define	SPECHASH(rdev)	(((unsigned)((rdev>>5)+(rdev)))%SPECHSZ)
     91       1.1       cgd #endif
     92       1.1       cgd 
     93      1.21      matt extern	struct vnode *speclisth[SPECHSZ];
     94       1.1       cgd 
     95       1.1       cgd /*
     96       1.1       cgd  * Prototypes for special file operations on vnodes.
     97       1.1       cgd  */
     98      1.11  christos extern	int (**spec_vnodeop_p) __P((void *));
     99       1.1       cgd struct	nameidata;
    100       1.7   mycroft struct	componentname;
    101       1.1       cgd struct	ucred;
    102       1.1       cgd struct	flock;
    103       1.1       cgd struct	buf;
    104       1.1       cgd struct	uio;
    105       1.1       cgd 
    106      1.11  christos int	spec_lookup	__P((void *));
    107      1.13   mycroft #define	spec_create	genfs_badop
    108      1.13   mycroft #define	spec_mknod	genfs_badop
    109      1.11  christos int	spec_open	__P((void *));
    110      1.11  christos int	spec_close	__P((void *));
    111      1.13   mycroft #define	spec_access	genfs_ebadf
    112      1.13   mycroft #define	spec_getattr	genfs_ebadf
    113      1.13   mycroft #define	spec_setattr	genfs_ebadf
    114      1.11  christos int	spec_read	__P((void *));
    115      1.11  christos int	spec_write	__P((void *));
    116      1.13   mycroft #define	spec_lease_check genfs_nullop
    117      1.19  sommerfe #define spec_fcntl	genfs_fcntl
    118      1.11  christos int	spec_ioctl	__P((void *));
    119      1.14   mycroft int	spec_poll	__P((void *));
    120      1.22  jdolecek int	spec_kqfilter	__P((void *));
    121      1.17      fvdl #define spec_revoke	genfs_revoke
    122      1.20       chs #define	spec_mmap	genfs_mmap
    123      1.11  christos int	spec_fsync	__P((void *));
    124      1.16    kleink #define	spec_seek	genfs_nullop		/* XXX should query device */
    125      1.13   mycroft #define	spec_remove	genfs_badop
    126      1.13   mycroft #define	spec_link	genfs_badop
    127      1.13   mycroft #define	spec_rename	genfs_badop
    128      1.13   mycroft #define	spec_mkdir	genfs_badop
    129      1.13   mycroft #define	spec_rmdir	genfs_badop
    130      1.13   mycroft #define	spec_symlink	genfs_badop
    131      1.13   mycroft #define	spec_readdir	genfs_badop
    132      1.13   mycroft #define	spec_readlink	genfs_badop
    133      1.13   mycroft #define	spec_abortop	genfs_badop
    134      1.13   mycroft #define	spec_reclaim	genfs_nullop
    135      1.17      fvdl int	spec_inactive	__P((void *));
    136      1.17      fvdl #define	spec_lock	genfs_nolock
    137      1.17      fvdl #define	spec_unlock	genfs_nounlock
    138      1.11  christos int	spec_bmap	__P((void *));
    139      1.11  christos int	spec_strategy	__P((void *));
    140      1.11  christos int	spec_print	__P((void *));
    141      1.17      fvdl #define	spec_islocked	genfs_noislocked
    142      1.11  christos int	spec_pathconf	__P((void *));
    143      1.15    kleink int	spec_advlock	__P((void *));
    144      1.13   mycroft #define	spec_blkatoff	genfs_badop
    145      1.13   mycroft #define	spec_valloc	genfs_badop
    146      1.13   mycroft #define	spec_reallocblks genfs_badop
    147      1.13   mycroft #define	spec_vfree	genfs_badop
    148      1.13   mycroft #define	spec_truncate	genfs_nullop
    149      1.13   mycroft #define	spec_update	genfs_nullop
    150      1.11  christos #define	spec_bwrite	vn_bwrite
    151      1.20       chs #define	spec_getpages	genfs_getpages
    152      1.20       chs #define	spec_putpages	genfs_putpages
    153      1.20       chs int	spec_size	__P((void *));
    154      1.23      matt 
    155      1.23      matt #endif /* _MISCFS_SPECFS_SPECDEV_H_ */
    156