bfbb9ce670
udev_t in the kernel but still called dev_t in userland. Provide functions to manipulate both types: major() umajor() minor() uminor() makedev() umakedev() dev2udev() udev2dev() For now they're functions, they will become in-line functions after one of the next two steps in this process. Return major/minor/makedev to macro-hood for userland. Register a name in cdevsw[] for the "filedescriptor" driver. In the kernel the udev_t appears in places where we have the major/minor number combination, (ie: a potential device: we may not have the driver nor the device), like in inodes, vattr, cdevsw registration and so on, whereas the dev_t appears where we carry around a reference to a actual device. In the future the cdevsw and the aliased-from vnode will be hung directly from the dev_t, along with up to two softc pointers for the device driver and a few houskeeping bits. This will essentially replace the current "alias" check code (same buck, bigger bang). A little stunt has been provided to try to catch places where the wrong type is being used (dev_t vs udev_t), if you see something not working, #undef DEVT_FASCIST in kern/kern_conf.c and see if it makes a difference. If it does, please try to track it down (many hands make light work) or at least try to reproduce it as simply as possible, and describe how to do that. Without DEVT_FASCIST I belive this patch is a no-op. Stylistic/posixoid comments about the userland view of the <sys/*.h> files welcome now, from userland they now contain the end result. Next planned step: make all dev_t's refer to the same devsw[] which means convert BLK's to CHR's at the perimeter of the vnodes and other places where they enter the game (bootdev, mknod, sysctl).
79 lines
2.9 KiB
C
79 lines
2.9 KiB
C
/*
|
|
* Copyright (c) 1990, 1993
|
|
* The Regents of the University of California. All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
* must display the following acknowledgement:
|
|
* This product includes software developed by the University of
|
|
* California, Berkeley and its contributors.
|
|
* 4. Neither the name of the University nor the names of its contributors
|
|
* may be used to endorse or promote products derived from this software
|
|
* without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
* @(#)specdev.h 8.6 (Berkeley) 5/21/95
|
|
* $Id: specdev.h,v 1.16 1999/02/25 05:22:30 dillon Exp $
|
|
*/
|
|
|
|
/*
|
|
* This structure defines the information maintained about
|
|
* special devices. It is allocated in checkalias and freed
|
|
* in vgone.
|
|
*/
|
|
struct specinfo {
|
|
struct vnode **si_hashchain;
|
|
struct vnode *si_specnext;
|
|
struct mount *si_mountpoint;
|
|
dev_t si_rdev;
|
|
int si_bsize_phys; /* minimum physical block size */
|
|
int si_bsize_best; /* optimal block size / VBLK */
|
|
int si_bsize_max; /* maximum block size */
|
|
};
|
|
/*
|
|
* Exported shorthand
|
|
*/
|
|
#define v_rdev v_specinfo->si_rdev
|
|
#define v_hashchain v_specinfo->si_hashchain
|
|
#define v_specnext v_specinfo->si_specnext
|
|
#define v_specmountpoint v_specinfo->si_mountpoint
|
|
|
|
/*
|
|
* Special device management
|
|
*/
|
|
#define SPECHSZ 64
|
|
#define SPECHASH(rdev) (((unsigned)(minor(rdev)))%SPECHSZ)
|
|
|
|
extern struct vnode *speclisth[SPECHSZ];
|
|
|
|
/*
|
|
* Prototypes for special file operations on vnodes.
|
|
*/
|
|
extern vop_t **spec_vnodeop_p;
|
|
struct nameidata;
|
|
struct componentname;
|
|
struct ucred;
|
|
struct flock;
|
|
struct buf;
|
|
struct uio;
|
|
|
|
int spec_vnoperate __P((struct vop_generic_args *));
|