FreeBSD src
Go to file
Mark Johnston faa998f6ff sendfile: Use the pager size to determine the file extent when possible
Previously sendfile would issue a VOP_GETATTR and use the returned size,
i.e., the file size.  When paging in file data, sendfile_swapin() will
use the pager to determine whether it needs to zero-fill, most often
because of a hole in a sparse file.  An attempt to page in beyond the
end of a file is treated this way, and occurs when the requested page is
past the end of the pager.  In other words, both the file size and pager
size were used interchangeably.

With ZFS, updates to the pager and file sizes are not synchronized by
the exclusive vnode lock, at least partially due to its use of
MNTK_SHARED_WRITES.  In particular, the pager size is updated after the
file size, so in the presence of a writer concurrently extending the
file, sendfile could incorrectly instantiate "holes" in the page cache
pages backing the file, which manifests as data corruption when reading
the file back from the page cache.  The on-disk copy is unaffected.

Fix this by consistently using the pager size when available.

Reported by:	dumbbell
Reviewed by:	chs, kib
Tested by:	dumbbell, pho
MFC after:	1 week
Sponsored by:	The FreeBSD Foundation
Differential Revision:	https://reviews.freebsd.org/D28811
2021-02-25 10:04:44 -05:00
.github/workflows GitHub actions: unbreak macOS build 2021-01-08 15:36:38 +01:00
bin bin/pkill: Fix {pgrep,pkill}-j_test.sh 2021-02-13 13:53:51 +00:00
cddl zfs: merge OpenZFS master-9312e0fd1 2021-02-22 13:01:17 +01:00
contrib close_range: add audit support 2021-02-23 17:47:07 +00:00
crypto openssh: document two changes that are now upstream 2021-02-22 14:03:28 -05:00
etc bhyve/snapshot: drop mkdir when creating the unix domain socket 2021-02-22 11:31:07 -09:00
gnu Bump shared library versions after ncurses bump in 13. 2021-02-01 17:11:49 -08:00
include Remove __NO_TLS. 2021-02-23 20:08:10 +02:00
kerberos5 kerberos5: fix the WITH_OPENLDAP build 2021-01-30 00:07:50 -06:00
lib ncurses: Add support for terminfo database 2021-02-25 14:25:11 +01:00
libexec rc: fix parse of $local_startup 2021-02-23 21:12:49 -08:00
release Use makefs(8) in release VM-image generation instead of md(4) and newfs. 2021-02-24 21:16:56 -05:00
rescue ping: add a ping6 hard link for backwards compatibility 2020-11-26 18:33:04 +00:00
sbin ipfw: make algo name argument optional for some table types 2021-02-25 16:57:47 +03:00
secure OpenSSL: Regen manual page for the previous commit 2021-02-17 18:19:13 -05:00
share terminfo: add terminfo database 2021-02-25 14:25:32 +01:00
stand Disable PIE for MIPS BERI boot loader 2021-02-25 06:41:35 +01:00
sys sendfile: Use the pager size to determine the file extent when possible 2021-02-25 10:04:44 -05:00
targets ndis(4): remove as previous announced 2021-01-25 21:45:03 +00:00
tests bridge tests: Test that we also forward on some interfaces 2021-02-25 10:17:03 +01:00
tools git hooks: add "Fixes" trailer to commit message template 2021-02-22 10:29:56 -05:00
usr.bin ncurses: Add support for terminfo database 2021-02-25 14:25:11 +01:00
usr.sbin Mount the EFI system partition (ESP) on newly-installed systems. 2021-02-23 16:24:21 -05:00
.arcconfig arcconfig: add callsign again 2020-11-23 04:39:29 +00:00
.arclint arc lint: ignore /tests/ in chmod 2017-12-19 03:38:06 +00:00
.cirrus.yml Revert "Cirrus-CI: Use the default Git history depth" 2021-01-29 11:22:03 -05:00
.clang-format clang-format: Avoid breaking after the opening paren of function definitions 2020-10-28 11:54:00 +00:00
.gitattributes Add a basic clang-format configuration file 2019-06-07 15:23:52 +00:00
.gitignore gitignore: expand list of ignored files 2021-01-14 17:03:57 +01:00
COPYRIGHT copyrights: Happy New Year 2021 2020-12-31 10:29:44 -05:00
LOCKS LOCKS: update current locks 2018-06-09 03:08:04 +00:00
MAINTAINERS Add a pointer to csprng@ for the CSPRNG driver. This is enforced anyway by 2020-09-01 08:02:12 +00:00
Makefile Rename NO_WERROR -> MK_WERROR=no 2021-01-07 09:31:03 +00:00
Makefile.inc1 bootstrap: fix a last edit typo 2021-02-25 14:53:00 +01:00
Makefile.libcompat libcompat: remove redundant path for ncurses 2021-01-07 15:14:52 +01:00
Makefile.sys.inc AUTO_OBJ: For all top-level targets enforce using an OBJDIR. 2017-12-05 21:29:47 +00:00
ObsoleteFiles.inc boot: remove gptboot.efifat, it never should have been 2021-02-19 15:34:25 -07:00
README Import OpenSSL 1.1.1j. 2021-02-16 14:54:02 -05:00
README.md Mark the repository has been converted to Git 2020-12-23 12:27:27 +08:00
RELNOTES Bump CURRENT to 14.0 2021-01-21 19:10:07 -05:00
UPDATING Bump __FreeBSD_version for multiple LinuxKPI updates conflicting 2021-01-28 16:37:28 +00:00

FreeBSD Source:

This is the top level of the FreeBSD source directory. This file was last revised on: FreeBSD

FreeBSD is an operating system used to power modern servers, desktops, and embedded platforms. A large community has continually developed it for more than thirty years. Its advanced networking, security, and storage features have made FreeBSD the platform of choice for many of the busiest web sites and most pervasive embedded networking and storage devices.

For copyright information, please see the file COPYRIGHT in this directory. Additional copyright information also exists for some sources in this tree - please see the specific source directories for more information.

The Makefile in this directory supports a number of targets for building components (or all) of the FreeBSD source tree. See build(7), config(8), https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html, and https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html for more information, including setting make(1) variables.

Source Roadmap:

bin		System/user commands.

cddl		Various commands and libraries under the Common Development
		and Distribution License.

contrib		Packages contributed by 3rd parties.

crypto		Cryptography stuff (see crypto/README).

etc		Template files for /etc.

gnu		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* for more information.

include		System include files.

kerberos5	Kerberos5 (Heimdal) package.

lib		System libraries.

libexec		System daemons.

release		Release building Makefile & associated tools.

rescue		Build system for statically linked /rescue utilities.

sbin		System commands.

secure		Cryptographic libraries and commands.

share		Shared resources.

stand		Boot loader sources.

sys		Kernel sources.

sys/<arch>/conf Kernel configuration files. GENERIC is the configuration
		used in release builds. NOTES contains documentation of
		all possible entries.

tests		Regression tests which can be run by Kyua.  See tests/README
		for additional information.

tools		Utilities for regression testing and miscellaneous tasks.

usr.bin		User commands.

usr.sbin	System administration commands.

For information on synchronizing your source tree with one or more of the FreeBSD Project's development branches, please see:

https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/current-stable.html