Marcel Moolenaar 9ba57342c9 SEEK_DATA has interesting behaviour for sparse files on ZFS. A sparse file
with 128K of random data and truncated to 800K can have SEEK_DATA return -1
when given an offset of 128K. On UFS, the SEEK_DATA returns 800K (the size
of the file). SEEK_HOLE on ZFS seems to behave the same as UFS.

To handle this, map -1 to the size of the file (`end') when lseek returns
this for either SEEK_HOLE or SEEK_DATA. When sparse files are not supported
by the file system both `hole' and `data' will now be equal to `end' and we
will treat the entire file as data. This way, the -1 return for SEEK_DATA
on ZFS will end up doing the right thing.

Reported by: gjb@

MFC after:	3 days
2014-11-12 00:10:27 +00:00
..
2014-07-08 22:27:50 +00:00
2014-02-08 13:29:35 +00:00
2014-04-16 23:14:05 +00:00
2014-08-06 22:17:26 +00:00
2014-06-10 06:16:34 +00:00
2012-11-04 09:27:01 +00:00
2014-09-16 22:26:01 +00:00
2013-11-21 21:19:01 +00:00
2014-07-31 03:36:03 +00:00
2014-07-07 00:27:09 +00:00
2014-10-23 01:22:29 +00:00
2014-08-26 19:36:47 +00:00
2012-05-10 02:07:00 +00:00
2013-02-19 13:32:26 +00:00
2012-09-14 17:50:42 +00:00
2012-11-17 23:52:38 +00:00
2014-08-26 11:04:51 +00:00
2014-07-04 04:47:29 +00:00
2011-10-16 08:04:43 +00:00
2014-05-11 02:04:40 +00:00
2012-06-21 21:47:08 +00:00
2012-05-26 17:10:16 +00:00
2013-09-20 16:05:09 +00:00
2014-09-11 19:54:30 +00:00
2013-03-17 06:36:04 +00:00
2011-11-06 08:16:35 +00:00
2013-11-09 09:05:50 +00:00
2013-01-14 11:06:50 +00:00
2014-08-26 20:40:12 +00:00
2013-04-23 13:03:17 +00:00
2013-11-20 17:48:38 +00:00
2013-05-12 22:22:12 +00:00
2014-11-11 21:52:10 +00:00
2012-10-07 20:01:41 +00:00
2014-07-07 00:27:09 +00:00
2011-10-16 08:04:43 +00:00
2013-03-07 23:44:35 +00:00