LKML Archive on lore.kernel.org help / color / mirror / Atom feed
From: Peter Zijlstra <a.p.zijlstra@chello.nl> To: linux-kernel@vger.kernel.org, netdev@vger.kernel.org, linux-mm@kvack.org Cc: David Miller <davem@davemloft.net>, Peter Zijlstra <a.p.zijlstra@chello.nl> Subject: [PATCH 4/9] mm: serialize access to min_free_kbytes Date: Tue, 16 Jan 2007 10:46:01 +0100 [thread overview] Message-ID: <20070116101815.501185000@taijtu.programming.kicks-ass.net> (raw) In-Reply-To: 20070116094557.494892000@taijtu.programming.kicks-ass.net [-- Attachment #1: setup_per_zone_pages_min.patch --] [-- Type: text/plain, Size: 1913 bytes --] There is a small race between the procfs caller and the memory hotplug caller of setup_per_zone_pages_min(). Not a big deal, but the next patch will add yet another caller. Time to close the gap. Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl> --- mm/page_alloc.c | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) Index: linux-2.6-git/mm/page_alloc.c =================================================================== --- linux-2.6-git.orig/mm/page_alloc.c 2007-01-15 09:58:49.000000000 +0100 +++ linux-2.6-git/mm/page_alloc.c 2007-01-15 09:58:51.000000000 +0100 @@ -95,6 +95,7 @@ static char * const zone_names[MAX_NR_ZO #endif }; +static DEFINE_SPINLOCK(min_free_lock); int min_free_kbytes = 1024; unsigned long __meminitdata nr_kernel_pages; @@ -3074,12 +3075,12 @@ static void setup_per_zone_lowmem_reserv } /** - * setup_per_zone_pages_min - called when min_free_kbytes changes. + * __setup_per_zone_pages_min - called when min_free_kbytes changes. * * Ensures that the pages_{min,low,high} values for each zone are set correctly * with respect to min_free_kbytes. */ -void setup_per_zone_pages_min(void) +static void __setup_per_zone_pages_min(void) { unsigned long pages_min = min_free_kbytes >> (PAGE_SHIFT - 10); unsigned long lowmem_pages = 0; @@ -3133,6 +3134,15 @@ void setup_per_zone_pages_min(void) calculate_totalreserve_pages(); } +void setup_per_zone_pages_min(void) +{ + unsigned long flags; + + spin_lock_irqsave(&min_free_lock, flags); + __setup_per_zone_pages_min(); + spin_unlock_irqrestore(&min_free_lock, flags); +} + /* * Initialise min_free_kbytes. * @@ -3168,7 +3178,7 @@ static int __init init_per_zone_pages_mi min_free_kbytes = 128; if (min_free_kbytes > 65536) min_free_kbytes = 65536; - setup_per_zone_pages_min(); + __setup_per_zone_pages_min(); setup_per_zone_lowmem_reserve(); return 0; } --
next prev parent reply other threads:[~2007-01-16 10:28 UTC|newest] Thread overview: 32+ messages / expand[flat|nested] mbox.gz Atom feed top 2007-01-16 9:45 [PATCH 0/9] VM deadlock avoidance -v10 Peter Zijlstra 2007-01-16 9:45 ` [PATCH 1/9] mm: page allocation rank Peter Zijlstra 2007-01-16 9:45 ` [PATCH 2/9] mm: slab allocation fairness Peter Zijlstra 2007-01-16 9:46 ` [PATCH 3/9] mm: allow PF_MEMALLOC from softirq context Peter Zijlstra 2007-01-16 9:46 ` Peter Zijlstra [this message] 2007-01-16 9:46 ` [PATCH 5/9] mm: emergency pool Peter Zijlstra 2007-01-16 9:46 ` [PATCH 6/9] mm: __GFP_EMERGENCY Peter Zijlstra 2007-01-16 9:46 ` [PATCH 7/9] mm: allow mempool to fall back to memalloc reserves Peter Zijlstra 2007-01-16 9:46 ` [PATCH 8/9] slab: kmem_cache_objs_to_pages() Peter Zijlstra 2007-01-16 9:46 ` [PATCH 9/9] net: vm deadlock avoidance core Peter Zijlstra 2007-01-16 13:25 ` Evgeniy Polyakov 2007-01-16 13:47 ` Peter Zijlstra 2007-01-16 15:33 ` Evgeniy Polyakov 2007-01-16 16:08 ` Peter Zijlstra 2007-01-17 4:54 ` Evgeniy Polyakov 2007-01-17 9:07 ` Peter Zijlstra 2007-01-18 10:41 ` Evgeniy Polyakov 2007-01-18 12:18 ` Peter Zijlstra 2007-01-18 13:58 ` Possible ways of dealing with OOM conditions Evgeniy Polyakov 2007-01-18 15:10 ` Peter Zijlstra 2007-01-18 15:50 ` Evgeniy Polyakov 2007-01-18 17:31 ` Peter Zijlstra 2007-01-18 18:34 ` Evgeniy Polyakov 2007-01-19 12:53 ` Peter Zijlstra 2007-01-19 22:56 ` Evgeniy Polyakov 2007-01-20 22:36 ` Rik van Riel 2007-01-21 1:46 ` Evgeniy Polyakov 2007-01-21 2:14 ` Evgeniy Polyakov 2007-01-21 16:30 ` Rik van Riel 2007-01-19 17:54 ` Christoph Lameter 2007-01-17 9:12 ` [PATCH 0/9] VM deadlock avoidance -v10 Pavel Machek 2007-01-17 9:20 ` Peter Zijlstra
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20070116101815.501185000@taijtu.programming.kicks-ass.net \ --to=a.p.zijlstra@chello.nl \ --cc=davem@davemloft.net \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-mm@kvack.org \ --cc=netdev@vger.kernel.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).