svn commit: r321920 - head/sys/sys
Konstantin Belousov
kostikbel at gmail.com
Thu Aug 3 12:07:36 UTC 2017
On Thu, Aug 03, 2017 at 07:34:56PM +1000, Bruce Evans wrote:
> I see another problem. Masking with 0xfffffffff and casting to unsigned
> are gratuitously different spellings for extracting the low 32 bits.
> I prefer the cast.
Below is one more update. I reformulated the man page text, but not too
deep. Also I replaced masking with the cast.
diff --git a/share/man/man3/makedev.3 b/share/man/man3/makedev.3
index 87ca953dc79..8ce9c554a09 100644
--- a/share/man/man3/makedev.3
+++ b/share/man/man3/makedev.3
@@ -24,7 +24,7 @@
.\"
.\" $FreeBSD$
.\"
-.Dd September 28, 2008
+.Dd August 3, 2017
.Dt MAKEDEV 3
.Os
.Sh NAME
@@ -43,7 +43,7 @@
.Sh DESCRIPTION
The
.Fn makedev
-macro allows a unique device number to be generated based on its
+macro returns a device number created from the provided
.Fa major
and
.Fa minor
@@ -52,13 +52,26 @@ The
.Fn major
and
.Fn minor
-macros can be used to obtain the original numbers from the device number
+macros return the original numbers from the device number
.Fa dev .
+In other words, for a value
+.Va dev
+of the type
+.Vt dev_t ,
+and values
+.Va ma , mi
+of the type
+.Vt int ,
+the assertions
+.Dl dev == makedev(major(dev), minor(dev))
+.Dl ma == major(makedev(ma, mi))
+.Dl mi == minor(makedev(ma, mi))
+are valid.
.Pp
In previous implementations of
.Fx
all block and character devices were uniquely identified by a pair of
-major and minor numbers.
+stable major and minor numbers.
The major number referred to a certain device class (e.g. disks, TTYs)
while the minor number identified an instance within the device class.
Later versions of
@@ -66,7 +79,8 @@ Later versions of
automatically generate a unique device number for each character device
visible in
.Pa /dev/ .
-These numbers are not divided in device classes.
+These numbers are not divided in device classes and are not guaranteed
+to be stable upon reboot or driver reload.
.Pp
On
.Fx
@@ -78,11 +92,9 @@ conventional way.
.Sh RETURN VALUES
The
.Fn major
-macro returns a device major number that has a value between 0 and 255.
-The
+and
.Fn minor
-macro returns a device minor number whose value can span the complete
-range of an
+macros return numbers whose value can span the complete range of an
.Vt int .
.Sh SEE ALSO
.Xr mknod 2 ,
diff --git a/sys/sys/types.h b/sys/sys/types.h
index 30a08724443..eacbc1ba0c4 100644
--- a/sys/sys/types.h
+++ b/sys/sys/types.h
@@ -364,9 +364,9 @@ __bitcount64(__uint64_t _x)
#include <sys/select.h>
-#define major(x) ((int)((dev_t)(x) >> 32)) /* major number */
-#define minor(x) ((int)((x) & 0xffffffff)) /* minor number */
-#define makedev(x, y) (((dev_t)(x) << 32) | (unsigned)(y)) /* create dev_t */
+#define major(x) ((int)((dev_t)(x) >> 32))
+#define minor(x) ((int)(x))
+#define makedev(x, y) (((dev_t)(x) << 32) | (unsigned)(y))
/*
* These declarations belong elsewhere, but are repeated here and in
More information about the svn-src-all
mailing list