Page MenuHomeFreeBSD

Fix lseek() so that it never returns errnos not listed on the man page, such as ENOTTY
ClosedPublic

Authored by rmacklem on Aug 17 2019, 3:24 AM.
Tags
None
Referenced Files
F108517115: D21300.id61103.diff
Sat, Jan 25, 7:57 PM
Unknown Object (File)
Thu, Jan 23, 6:44 PM
Unknown Object (File)
Sat, Jan 18, 5:24 PM
Unknown Object (File)
Tue, Jan 14, 6:40 PM
Unknown Object (File)
Sat, Jan 4, 10:27 AM
Unknown Object (File)
Dec 21 2024, 5:09 PM
Unknown Object (File)
Dec 3 2024, 4:21 PM
Unknown Object (File)
Nov 22 2024, 7:00 AM
Subscribers

Details

Summary

VOP_IOCTL() can return errors such as ENOTTY, which are not listed as errnos for lseek(2)
on either the man page nor in POSIX.

The trivial patch maps all errnos not listed in the man page (and POSIX) to EINVAL, which
is listed. This is done mainly for the ENOTTY case, but serves as a "catch-all" for any other
non-standard errnos that might be returned by the VOP_IOCTL().

Test Plan

A test program was run on an NFS mount (which does not have a VOP_IOCTL() and, as such, the
VOP_IOCTL() call returns ENOTTY) which does lseek(SEEK_DATA/SEEK_HOLE), to see that it gets
errno == EINVAL instead of ENOTTY.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 25931

Event Timeline

I understand that the intent is to filter out unexpected error values, but I think it would be better to simply restrict the check to ENOTTY: if our code starts returning an unexpected error number (i.e., not one of the documented error numbers and not ENOTTY), and we map it to EINVAL, userspace will get a documented error number for an undocumented reason, which IMHO isn't much better. Preserving the original error number will make it easier to determine where the error is coming from, which will inform whether it becomes a documented error for lseek().

Actually, I only mapped ENOTTY when I first did the patch. The only reason I changed it
is that any error returned by VOP_GETATTR() also gets returned to lseek(2). For NFS,
this could be EACCES, for example, since file permissions are checked for every operation
on NFS, nit just at open(2) time.

However, I have no problem going to just mapping ENOTTY.

I update the patch tomorrow.
I'll also take a closer look at what errors VOP_GETATTR() can return.

Updated the patch to only map ENOTTY to EINVAL, per Mark's comments.

This revision is now accepted and ready to land.Aug 21 2019, 10:33 PM