Date: Tue, 03 Jun 1997 20:33:22 -0500 From: Scott Lystig Fritchie <fritchie@MR.Net> To: freebsd-hackers@freebsd.org Subject: mmap() incapable of mapping block special files? Message-ID: <199706040133.UAA14543@data.mr.net>
next in thread | raw e-mail | index | archive | help
[Originally posted to comp.unix.bsd.freebsd.misc, <ytlraemlumg.fsf@mr.net>]
I was puzzled for quite a while trying to figure out why a mmap() call
was failing with EINVAL. None of the reasons for EINVAL in the mmap()
man page matched my situation.
I finally resorted to looking at the kernel source code. (I should've
thought of it sooner, but I've got too much Solaris in my blood. :-)
In /usr/src/sys/vm/vm_mmap.c (2.2.1-RELEASE) at about line 211 I
found:
/*
* Mapping file, get fp for validation. Obtain vnode and make
* sure it is of appropriate type.
*/
if (((unsigned) uap->fd) >= fdp->fd_nfiles ||
(fp = fdp->fd_ofiles[uap->fd]) == NULL)
return (EBADF);
if (fp->f_type != DTYPE_VNODE)
return (EINVAL);
vp = (struct vnode *) fp->f_data;
if (vp->v_type != VREG && vp->v_type != VCHR)
return (EINVAL);
Doh! The file in question is a block special file, not a character
special or plain-old regular file.
I'm tempted to add an additional "&&" to the file type test to include
for VBLK ... but I wouldn't wanna do it if it will cause unknown (to
me) mischief down the road. Is there a particular reason why VBLK
isn't included?
-Scott
---
Scott Lystig Fritchie, Network Engineer MRNet Internet Services, Inc.
fritchie@mr.net, PGP key #152B8725 Minnesota Regional Network
v: 612/362.5820, p: 612/637.9547 2829 University Ave SE
http://www.mr.net/~fritchie/ Minneapolis, MN 55414
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?199706040133.UAA14543>
