From 0f03ce1bb8df1297441f59300c534a01aa119ad0 Mon Sep 17 00:00:00 2001 From: Ed Schouten Date: Thu, 12 Jun 2008 08:30:54 +0000 Subject: [PATCH] Turn dev2unit(), minor(), unit2minor() and minor2unit() into macro's. Now that we got rid of the minor-to-unit conversion and the constraints on device minor numbers, we can convert the functions that operate on minor and unit numbers to simple macro's. The unit2minor() and minor2unit() macro's are now no-ops. The ZFS code als defined a macro named `minor'. Change the ZFS code to use umajor() and uminor() here, as it is the correct approach to do this. Also add $FreeBSD$ to keep SVN happy. Approved by: philip (mentor), pjd --- .../opensolaris/uts/common/fs/zfs/zfs_znode.c | 10 ++---- sys/kern/kern_conf.c | 35 ------------------- sys/sys/conf.h | 8 +++-- sys/sys/systm.h | 1 - 4 files changed, 8 insertions(+), 46 deletions(-) diff --git a/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_znode.c b/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_znode.c index e32e873866ae..321f837a2063 100644 --- a/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_znode.c +++ b/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/zfs_znode.c @@ -17,6 +17,8 @@ * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END + * + * $FreeBSD$ */ /* * Copyright 2007 Sun Microsystems, Inc. All rights reserved. @@ -279,12 +281,6 @@ zfs_init_fs(zfsvfs_t *zfsvfs, znode_t **zpp, cred_t *cr) #ifndef MAXMIN64 #define MAXMIN64 0xffffffffUL #endif -#ifndef major -#define major(x) ((int)(((u_int)(x) >> 8)&0xff)) /* major number */ -#endif -#ifndef minor -#define minor(x) ((int)((x)&0xffff00ff)) /* minor number */ -#endif /* * Create special expldev for ZFS private use. @@ -297,7 +293,7 @@ zfs_init_fs(zfsvfs_t *zfsvfs, znode_t **zpp, cred_t *cr) static uint64_t zfs_expldev(dev_t dev) { - return (((uint64_t)major(dev) << NBITSMINOR64) | minor(dev)); + return (((uint64_t)umajor(dev) << NBITSMINOR64) | uminor(dev)); } /* * Special cmpldev for ZFS private use. diff --git a/sys/kern/kern_conf.c b/sys/kern/kern_conf.c index 0cff9eaff722..c9eac628796a 100644 --- a/sys/kern/kern_conf.c +++ b/sys/kern/kern_conf.c @@ -492,41 +492,6 @@ giant_mmap(struct cdev *dev, vm_offset_t offset, vm_paddr_t *paddr, int nprot) } -/* - * struct cdev * and u_dev_t primitives - */ - -int -minor(struct cdev *x) -{ - if (x == NULL) - return NODEV; - return (x->si_drv0); -} - -int -dev2unit(struct cdev *x) -{ - - if (x == NULL) - return NODEV; - return (x->si_drv0); -} - -u_int -minor2unit(u_int _minor) -{ - - return (_minor); -} - -int -unit2minor(int unit) -{ - - return (unit); -} - static void notify(struct cdev *dev, const char *ev) { diff --git a/sys/sys/conf.h b/sys/sys/conf.h index e26b7218d9c5..cd2bb8d1dcfa 100644 --- a/sys/sys/conf.h +++ b/sys/sys/conf.h @@ -273,13 +273,15 @@ struct cdev *make_dev_credf(int _flags, struct ucred *_cr, uid_t _uid, gid_t _gid, int _mode, const char *_fmt, ...) __printflike(8, 9); struct cdev *make_dev_alias(struct cdev *_pdev, const char *_fmt, ...) __printflike(2, 3); -int dev2unit(struct cdev *_dev); void dev_lock(void); void dev_unlock(void); -int unit2minor(int _unit); -u_int minor2unit(u_int _minor); void setconf(void); +#define dev2unit(d) ((d) ? (d)->si_drv0 : NODEV) +#define minor(d) ((d) ? (d)->si_drv0 : NODEV) +#define unit2minor(u) (u) +#define minor2unit(m) (m) + typedef void (*cdevpriv_dtr_t)(void *data); int devfs_get_cdevpriv(void **datap); int devfs_set_cdevpriv(void *priv, cdevpriv_dtr_t dtr); diff --git a/sys/sys/systm.h b/sys/sys/systm.h index 2dd4a3f2a971..ebdc9e8b70f1 100644 --- a/sys/sys/systm.h +++ b/sys/sys/systm.h @@ -311,7 +311,6 @@ void wakeup_one(void *chan) __nonnull(1); */ struct cdev; -int minor(struct cdev *x); dev_t dev2udev(struct cdev *x); int uminor(dev_t dev); int umajor(dev_t dev);