Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 30 Nov 2014 09:56:13 +0000 (UTC)
From:      Gleb Smirnoff <glebius@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-projects@freebsd.org
Subject:   svn commit: r275308 - projects/sendfile/sys/kern
Message-ID:  <201411300956.sAU9uD6o071042@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: glebius
Date: Sun Nov 30 09:56:13 2014
New Revision: 275308
URL: https://svnweb.freebsd.org/changeset/base/275308

Log:
  Pager limits our readahead count to MAXPHYS, so do not try to pre-allocate
  larger vector.
  
  Sponsored by:	Netflix
  Sponsored by:	Nginx, Inc.

Modified:
  projects/sendfile/sys/kern/uipc_syscalls.c

Modified: projects/sendfile/sys/kern/uipc_syscalls.c
==============================================================================
--- projects/sendfile/sys/kern/uipc_syscalls.c	Sun Nov 30 09:04:24 2014	(r275307)
+++ projects/sendfile/sys/kern/uipc_syscalls.c	Sun Nov 30 09:56:13 2014	(r275308)
@@ -2467,11 +2467,13 @@ retry_space:
 		/*
 		 * Calculate maximum allowed number of pages for readahead
 		 * at this iteration.  First, we allow readahead up to "rem".
-		 * If application wants more, let it be. But check against
-		 * "obj_size", since vm_pager_has_page() can hint beyond EOF.
+		 * If application wants more, let it be, but there is no
+		 * reason to go above MAXPHYS.  Also check against "obj_size",
+		 * since vm_pager_has_page() can hint beyond EOF.
 		 */
 		rhpages = howmany(rem + (off & PAGE_MASK), PAGE_SIZE) - npages;
 		rhpages = max(SF_READAHEAD(flags), rhpages);
+		rhpages = min(howmany(MAXPHYS, PAGE_SIZE), rhpages);
 		rhpages = min(howmany(obj_size - trunc_page(off), PAGE_SIZE) -
 		    npages, rhpages);
 



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201411300956.sAU9uD6o071042>