xref: /freebsd/lib/libc/gen/devname.3 (revision 26d4f5e969a5850cbb0b2344835d515c368d5652)
158f0484fSRodney W. Grimes.\" Copyright (c) 1993
258f0484fSRodney W. Grimes.\"	The Regents of the University of California.  All rights reserved.
358f0484fSRodney W. Grimes.\"
458f0484fSRodney W. Grimes.\" Redistribution and use in source and binary forms, with or without
558f0484fSRodney W. Grimes.\" modification, are permitted provided that the following conditions
658f0484fSRodney W. Grimes.\" are met:
758f0484fSRodney W. Grimes.\" 1. Redistributions of source code must retain the above copyright
858f0484fSRodney W. Grimes.\"    notice, this list of conditions and the following disclaimer.
958f0484fSRodney W. Grimes.\" 2. Redistributions in binary form must reproduce the above copyright
1058f0484fSRodney W. Grimes.\"    notice, this list of conditions and the following disclaimer in the
1158f0484fSRodney W. Grimes.\"    documentation and/or other materials provided with the distribution.
1258f0484fSRodney W. Grimes.\" 4. Neither the name of the University nor the names of its contributors
1358f0484fSRodney W. Grimes.\"    may be used to endorse or promote products derived from this software
1458f0484fSRodney W. Grimes.\"    without specific prior written permission.
1558f0484fSRodney W. Grimes.\"
1658f0484fSRodney W. Grimes.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
1758f0484fSRodney W. Grimes.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1858f0484fSRodney W. Grimes.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1958f0484fSRodney W. Grimes.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
2058f0484fSRodney W. Grimes.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2158f0484fSRodney W. Grimes.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2258f0484fSRodney W. Grimes.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2358f0484fSRodney W. Grimes.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2458f0484fSRodney W. Grimes.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2558f0484fSRodney W. Grimes.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2658f0484fSRodney W. Grimes.\" SUCH DAMAGE.
2758f0484fSRodney W. Grimes.\"
280014b4c0SPeter Wemm.\"     @(#)devname.3	8.2 (Berkeley) 4/29/95
297f3dea24SPeter Wemm.\" $FreeBSD$
3058f0484fSRodney W. Grimes.\"
310e5d513bSTom Rhodes.Dd February 22, 2005
3258f0484fSRodney W. Grimes.Dt DEVNAME 3
33a307d598SRuslan Ermilov.Os
3458f0484fSRodney W. Grimes.Sh NAME
3558f0484fSRodney W. Grimes.Nm devname
360e5d513bSTom Rhodes.Nd "get device name"
3725bb73e0SAlexey Zelkin.Sh LIBRARY
3825bb73e0SAlexey Zelkin.Lb libc
3958f0484fSRodney W. Grimes.Sh SYNOPSIS
4032eef9aeSRuslan Ermilov.In sys/stat.h
4132eef9aeSRuslan Ermilov.In stdlib.h
4258f0484fSRodney W. Grimes.Ft char *
4358f0484fSRodney W. Grimes.Fn devname "dev_t dev" "mode_t type"
44529ac587SPoul-Henning Kamp.Ft char *
45529ac587SPoul-Henning Kamp.Fn devname_r "dev_t dev" "mode_t type" "char *buf" "int len"
4626d4f5e9SEd Schouten.Ft char *
4726d4f5e9SEd Schouten.Fn fdevname "int fd"
4826d4f5e9SEd Schouten.Ft char *
4926d4f5e9SEd Schouten.Fn fdevname_r "int fd" "char *buf" "int len"
5058f0484fSRodney W. Grimes.Sh DESCRIPTION
5158f0484fSRodney W. GrimesThe
5258f0484fSRodney W. Grimes.Fn devname
5358f0484fSRodney W. Grimesfunction returns a pointer to the name of the block or character
5458f0484fSRodney W. Grimesdevice in
551dd9f42aSDima Dorfman.Pa /dev
5658f0484fSRodney W. Grimeswith a device number of
5758f0484fSRodney W. Grimes.Fa dev ,
5858f0484fSRodney W. Grimesand a file type matching the one encoded in
5958f0484fSRodney W. Grimes.Fa type
601dd9f42aSDima Dorfmanwhich must be one of
611dd9f42aSDima Dorfman.Dv S_IFBLK
621dd9f42aSDima Dorfmanor
631dd9f42aSDima Dorfman.Dv S_IFCHR .
64f04938aaSDima DorfmanTo find the right name,
65f04938aaSDima Dorfman.Fn devname
66529ac587SPoul-Henning Kampasks the kernel via the
67f04938aaSDima Dorfman.Va kern.devname
68f04938aaSDima Dorfmansysctl.
69529ac587SPoul-Henning KampIf it is unable to come up with a suitable name,
70f04938aaSDima Dorfmanit will format the information encapsulated in
71f04938aaSDima Dorfman.Fa dev
72f04938aaSDima Dorfmanand
73f04938aaSDima Dorfman.Fa type
74f04938aaSDima Dorfmanin a human-readable format.
75529ac587SPoul-Henning Kamp.Pp
7626d4f5e9SEd SchoutenThe
7726d4f5e9SEd Schouten.Fn fdevname
7826d4f5e9SEd Schoutenand
7926d4f5e9SEd Schouten.Fn fdevname_r
8026d4f5e9SEd Schoutenfunction obtains the device name directly from a file descriptor
8126d4f5e9SEd Schoutenpointing to a character device.
8226d4f5e9SEd SchoutenIf it is unable to come up with a suitable name, these functions will
8326d4f5e9SEd Schoutenreturn a NULL pointer.
8426d4f5e9SEd Schouten.Pp
85529ac587SPoul-Henning Kamp.Fn devname
8626d4f5e9SEd Schoutenand
8726d4f5e9SEd Schouten.Fn fdevname
8826d4f5e9SEd Schoutenreturn the name stored in a static buffer which will be overwritten
89529ac587SPoul-Henning Kampon subsequent calls.
90529ac587SPoul-Henning Kamp.Fn devname_r
9126d4f5e9SEd Schoutenand
9226d4f5e9SEd Schouten.Fn fdevname_r
9326d4f5e9SEd Schoutentake a buffer and length as argument to avoid this problem.
940e5d513bSTom Rhodes.Sh EXAMPLES
950e5d513bSTom Rhodes.Bd -literal -compact
960e5d513bSTom Rhodesint fd;
970e5d513bSTom Rhodesstruct stat buf;
980e5d513bSTom Rhodeschar *name;
990e5d513bSTom Rhodes
1000e5d513bSTom Rhodes	fd = open("/dev/tun");
1010e5d513bSTom Rhodes	fstat(fd, &buf);
1020e5d513bSTom Rhodes	printf("devname is /dev/%s\en", devname(buf.st_rdev, S_IFCHR));
10326d4f5e9SEd Schouten	printf("fdevname is /dev/%s\en", fdevname(fd));
1040e5d513bSTom Rhodes.Ed
10558f0484fSRodney W. Grimes.Sh SEE ALSO
106a1de21c1SRuslan Ermilov.Xr stat 2
10758f0484fSRodney W. Grimes.Sh HISTORY
10858f0484fSRodney W. GrimesThe
109bf5a138eSMike Pritchard.Fn devname
11095f4226bSRuslan Ermilovfunction appeared in
11158f0484fSRodney W. Grimes.Bx 4.4 .
11226d4f5e9SEd SchoutenThe
11326d4f5e9SEd Schouten.Fn fdevname
11426d4f5e9SEd Schoutenfunction appeared in
11526d4f5e9SEd Schouten.Fx 8.0 .
116