lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20101122212220.ae26d9a5.akpm@linux-foundation.org>
Date:	Mon, 22 Nov 2010 21:22:20 -0800
From:	Andrew Morton <akpm@...ux-foundation.org>
To:	Minchan Kim <minchan.kim@...il.com>
Cc:	linux-mm <linux-mm@...ck.org>, LKML <linux-kernel@...r.kernel.org>,
	Peter Zijlstra <peterz@...radead.org>,
	Rik van Riel <riel@...hat.com>,
	KOSAKI Motohiro <kosaki.motohiro@...fujitsu.com>,
	Johannes Weiner <hannes@...xchg.org>,
	Nick Piggin <npiggin@...nel.dk>
Subject: Re: [RFC 1/2] deactive invalidated pages

On Tue, 23 Nov 2010 14:23:33 +0900 Minchan Kim <minchan.kim@...il.com> wrote:

> On Tue, Nov 23, 2010 at 2:01 PM, Andrew Morton
> <akpm@...ux-foundation.org> wrote:
> > On Tue, 23 Nov 2010 13:52:05 +0900 Minchan Kim <minchan.kim@...il.com> wrote:
> >
> >> >> +/*
> >> >> + * Function used to forecefully demote a page to the head of the inactive
> >> >> + * list.
> >> >> + */
> >> >
> >> > This comment is wrong? __The page gets moved to the _tail_ of the
> >> > inactive list?
> >>
> >> No. I add it in _head_ of the inactive list intentionally.
> >> Why I don't add it to _tail_ is that I don't want to be aggressive.
> >> The page might be real working set. So I want to give a chance to
> >> activate it again.
> >
> > Well.. __why? __The user just tried to toss the page away altogether. __If
> > the kernel wasn't able to do that immediately, the best it can do is to
> > toss the page away asap?
> >
> >> If it's not working set, it can be reclaimed easily and it can prevent
> >> active page demotion since inactive list size would be big enough for
> >> not calling shrink_active_list.
> >
> > What is "working set"? __Mapped and unmapped pagecache, or are you
> > referring solely to mapped pagecache?
> 
> I mean it's mapped by other processes.
> 
> >
> > If it's mapped pagecache then the user was being a bit silly (or didn't
> > know that some other process had mapped the file). __In which case we
> > need to decide what to do - leave the page alone, deactivate it, or
> > half-deactivate it as this patch does.
> 
> 
> What I want is the half-deactivate.
> 
> Okay. We will use the result of invalidate_inode_page.
> If fail happens by page_mapped, we can do half-deactivate.
> But if fail happens by dirty(ex, writeback), we can add it to tail.
> Does it make sense?

Spose so.  It's unobvious.

If the page is dirty or under writeback then reclaim will immediately
move it to the head of the LRU anyway.  But given that the user has
just freed a bunch of pages with invalidate(), it's unlikely that
reclaim will be running soon.


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ