From owner-freebsd-hackers Wed Oct 29 21:21:11 1997 Return-Path: Received: (from root@localhost) by hub.freebsd.org (8.8.7/8.8.7) id VAA15174 for hackers-outgoing; Wed, 29 Oct 1997 21:21:11 -0800 (PST) (envelope-from owner-freebsd-hackers) Received: from smtp03.primenet.com (smtp03.primenet.com [206.165.5.84]) by hub.freebsd.org (8.8.7/8.8.7) with ESMTP id VAA15168 for ; Wed, 29 Oct 1997 21:21:03 -0800 (PST) (envelope-from tlambert@usr05.primenet.com) Received: (from daemon@localhost) by smtp03.primenet.com (8.8.7/8.8.7) id WAA13874; Wed, 29 Oct 1997 22:20:57 -0700 (MST) Received: from usr05.primenet.com(206.165.6.205) via SMTP by smtp03.primenet.com, id smtpd013863; Wed Oct 29 22:20:55 1997 Received: (from tlambert@localhost) by usr05.primenet.com (8.8.5/8.8.5) id WAA00554; Wed, 29 Oct 1997 22:20:48 -0700 (MST) From: Terry Lambert Message-Id: <199710300520.WAA00554@usr05.primenet.com> Subject: Re: help with fstat? To: njs3@doc.ic.ac.uk (Niall Smart) Date: Thu, 30 Oct 1997 05:20:47 +0000 (GMT) Cc: tlambert@primenet.com, freebsd-hackers@freebsd.org In-Reply-To: from "Niall Smart" at Oct 29, 97 08:51:08 pm X-Mailer: ELM [version 2.4 PL23] Content-Type: text Sender: owner-freebsd-hackers@freebsd.org X-Loop: FreeBSD.org Precedence: bulk > Does FreeBSD maintain a "free page" list internally that it will > consult before trying the heuristics for replacing a page? If this > is so then when we page in a page for a memory mapped region with the > MADV_SEQUENTIAL attribute we can immediately add the previous page to the > "free page" list. John does this in the OBJ_SEQUENTIAL case in vm_fault() in vm_fault.c. But he merely goes through the pages in the region before the faulted region (taking read-ahead into account), and if dirty, protects and deactivates the page, or if clean, caches it. My problem is with it being cached, since it's now on the LRU list ahead of my page that's been cached, and the user promised us that he's never going to reference the thing again. So why is it cached instead of "cached with extreme prejudice"... ie: inserted at the LRU head as if it were truly the least recently used instead of in LRU order, where it can force my pages (which I *am* going to reference again) out of core? That's what pisses me off about MADV_SEQUENTIAL... it snipes pages with possible locality to replace them with pages with no possible locality. I think vm_page_cache() and vm_page_deactivate() need a parameter like "defeat_normal_LRU_insertion_order" to stuff them at the other end of the LRU so they'll be the first against the wall when someone needs another page. Terry Lambert terry@lambert.org --- Any opinions in this posting are my own and not those of my present or previous employers.