LKML Archive on lore.kernel.org
help / color / mirror / Atom feed
* [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper
[not found] <Pine.LNX.4.64.0703211510340.15309@skynet.skynet.ie>
@ 2007-03-21 19:14 ` Andy Whitcroft
2007-03-21 19:15 ` [PATCH 1/3] add pfn_valid_within helper for sub-MAX_ORDER hole detection Andy Whitcroft
` (3 more replies)
0 siblings, 4 replies; 7+ messages in thread
From: Andy Whitcroft @ 2007-03-21 19:14 UTC (permalink / raw)
To: Mel Gorman, Bob Picco
Cc: Andy Whitcroft, Dave Hansen, Andrew Morton, linux-kernel
The thought of having a helper for the holes within zones code
has come up on two different threads in the last couple of days.
So I took the pfn_valid_within() patch I had developed for the
linear reclaim series and pulled it forward to 2.6.21-rc4-mm1.
I have split it into a three patch series to better align with the
affected patch sets within -mm.
add-pfn_valid_within-helper-for-sub-MAX_ORDER-hole-detection --
adds the base helper and utilises it within the buddy allocator,
anti-fragmentation-switch-over-to-pfn_valid_within() -- changes
references within Mel Gormans anti-fragmentation patch series, and
lumpy-move-to-using-pfn_valid_within() -- changes references with
my lumpy reclaim patch series.
-apw
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH 1/3] add pfn_valid_within helper for sub-MAX_ORDER hole detection
2007-03-21 19:14 ` [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper Andy Whitcroft
@ 2007-03-21 19:15 ` Andy Whitcroft
2007-03-21 23:23 ` Nick Piggin
2007-03-21 19:15 ` [PATCH 2/3] anti-fragmentation: switch over to pfn_valid_within() Andy Whitcroft
` (2 subsequent siblings)
3 siblings, 1 reply; 7+ messages in thread
From: Andy Whitcroft @ 2007-03-21 19:15 UTC (permalink / raw)
To: Mel Gorman, Bob Picco
Cc: Andy Whitcroft, Dave Hansen, Andrew Morton, linux-kernel
Generally we work under the assumption that memory the mem_map
array is contigious and valid out to MAX_ORDER_NR_PAGES block
of pages, ie. that if we have validated any page within this
MAX_ORDER_NR_PAGES block we need not check any other. This is not
true when CONFIG_HOLES_IN_ZONE is set and we must check each and
every reference we make from a pfn.
Add a pfn_valid_within() helper which should be used when scanning
pages within a MAX_ORDER_NR_PAGES block when we have already
checked the validility of the block normally with pfn_valid().
This can then be optimised away when we do not have holes within
a MAX_ORDER_NR_PAGES block of pages.
Signed-off-by: Andy Whitcroft <apw@shadowen.org>
Acked-by: Mel Gorman <mel@csn.ul.ie>
---
diff --git a/include/linux/mmzone.h b/include/linux/mmzone.h
index 7206c77..8c87d79 100644
--- a/include/linux/mmzone.h
+++ b/include/linux/mmzone.h
@@ -837,6 +837,18 @@ void sparse_init(void);
void memory_present(int nid, unsigned long start, unsigned long end);
unsigned long __init node_memmap_size_bytes(int, unsigned long, unsigned long);
+/*
+ * If it is possible to have holes within a MAX_ORDER_NR_PAGES, then we
+ * need to check pfn validility within that MAX_ORDER_NR_PAGES block.
+ * pfn_valid_within() should be used in this case; we optimise this away
+ * when we have no holes within a MAX_ORDER_NR_PAGES block.
+ */
+#ifdef CONFIG_HOLES_IN_ZONE
+#define pfn_valid_within(pfn) pfn_valid(pfn)
+#else
+#define pfn_valid_within(pfn) (1)
+#endif
+
#endif /* !__ASSEMBLY__ */
#endif /* __KERNEL__ */
#endif /* _LINUX_MMZONE_H */
diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index 3d7a9e2..695b5a6 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -206,10 +206,8 @@ static int page_outside_zone_boundaries(struct zone *zone, struct page *page)
static int page_is_consistent(struct zone *zone, struct page *page)
{
-#ifdef CONFIG_HOLES_IN_ZONE
- if (!pfn_valid(page_to_pfn(page)))
+ if (!pfn_valid_within(page_to_pfn(page)))
return 0;
-#endif
if (zone != page_zone(page))
return 0;
@@ -411,10 +409,8 @@ __find_combined_index(unsigned long page_idx, unsigned int order)
static inline int page_is_buddy(struct page *page, struct page *buddy,
int order)
{
-#ifdef CONFIG_HOLES_IN_ZONE
- if (!pfn_valid(page_to_pfn(buddy)))
+ if (!pfn_valid_within(page_to_pfn(buddy)))
return 0;
-#endif
if (page_zone_id(page) != page_zone_id(buddy))
return 0;
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [PATCH 2/3] anti-fragmentation: switch over to pfn_valid_within()
2007-03-21 19:14 ` [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper Andy Whitcroft
2007-03-21 19:15 ` [PATCH 1/3] add pfn_valid_within helper for sub-MAX_ORDER hole detection Andy Whitcroft
@ 2007-03-21 19:15 ` Andy Whitcroft
2007-03-21 19:16 ` [PATCH 3/3] lumpy: move to using pfn_valid_within() Andy Whitcroft
2007-03-21 20:55 ` [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper Bob Picco
3 siblings, 0 replies; 7+ messages in thread
From: Andy Whitcroft @ 2007-03-21 19:15 UTC (permalink / raw)
To: Mel Gorman, Bob Picco
Cc: Andy Whitcroft, Dave Hansen, Andrew Morton, linux-kernel
Move to using pfn_valid_within().
Signed-off-by: Andy Whitcroft <andyw@uk.ibm.com>
Acked-by: Mel Gorman <mel@csn.ul.ie>
---
diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index 695b5a6..3d7c29e 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -747,12 +747,10 @@ int move_freepages(struct zone *zone,
#endif
for (page = start_page; page < end_page;) {
-#ifdef CONFIG_HOLES_IN_ZONE
- if (!pfn_valid(page_to_pfn(page))) {
+ if (!pfn_valid_within(page_to_pfn(page))) {
page++;
continue;
}
-#endif
if (!PageBuddy(page)) {
page++;
^ permalink raw reply related [flat|nested] 7+ messages in thread
* [PATCH 3/3] lumpy: move to using pfn_valid_within()
2007-03-21 19:14 ` [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper Andy Whitcroft
2007-03-21 19:15 ` [PATCH 1/3] add pfn_valid_within helper for sub-MAX_ORDER hole detection Andy Whitcroft
2007-03-21 19:15 ` [PATCH 2/3] anti-fragmentation: switch over to pfn_valid_within() Andy Whitcroft
@ 2007-03-21 19:16 ` Andy Whitcroft
2007-03-21 20:55 ` [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper Bob Picco
3 siblings, 0 replies; 7+ messages in thread
From: Andy Whitcroft @ 2007-03-21 19:16 UTC (permalink / raw)
To: Mel Gorman, Bob Picco
Cc: Andy Whitcroft, Dave Hansen, Andrew Morton, linux-kernel
Switch to using pfn_valid_within() in lumpy reclaim.
Signed-off-by: Andy Whitcroft <apw@shadowen.org>
Acked-by: Mel Gorman <mel@csn.ul.ie>
---
diff --git a/mm/vmscan.c b/mm/vmscan.c
index c3dc544..cf55c57 100644
--- a/mm/vmscan.c
+++ b/mm/vmscan.c
@@ -722,11 +722,10 @@ static unsigned long isolate_lru_pages(unsigned long nr_to_scan,
/* The target page is in the block, ignore it. */
if (unlikely(pfn == page_pfn))
continue;
-#ifdef CONFIG_HOLES_IN_ZONE
+
/* Avoid holes within the zone. */
- if (unlikely(!pfn_valid(pfn)))
+ if (unlikely(!pfn_valid_within(pfn)))
break;
-#endif
cursor_page = pfn_to_page(pfn);
/* Check that we have not crossed a zone boundary. */
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper
2007-03-21 19:14 ` [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper Andy Whitcroft
` (2 preceding siblings ...)
2007-03-21 19:16 ` [PATCH 3/3] lumpy: move to using pfn_valid_within() Andy Whitcroft
@ 2007-03-21 20:55 ` Bob Picco
3 siblings, 0 replies; 7+ messages in thread
From: Bob Picco @ 2007-03-21 20:55 UTC (permalink / raw)
To: Andy Whitcroft
Cc: Mel Gorman, Bob Picco, Dave Hansen, Andrew Morton, linux-kernel
Andy Wihitcroft wrote: [Wed Mar 21 2007, 02:14:55PM EST]
> The thought of having a helper for the holes within zones code
> has come up on two different threads in the last couple of days.
> So I took the pfn_valid_within() patch I had developed for the
> linear reclaim series and pulled it forward to 2.6.21-rc4-mm1.
> I have split it into a three patch series to better align with the
> affected patch sets within -mm.
>
> add-pfn_valid_within-helper-for-sub-MAX_ORDER-hole-detection --
> adds the base helper and utilises it within the buddy allocator,
>
> anti-fragmentation-switch-over-to-pfn_valid_within() -- changes
> references within Mel Gormans anti-fragmentation patch series, and
>
> lumpy-move-to-using-pfn_valid_within() -- changes references with
> my lumpy reclaim patch series.
>
> -apw
Andy,
Thanks for doing this.
Acked-by: Bob Picco <bob.picco@hp.com>
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 1/3] add pfn_valid_within helper for sub-MAX_ORDER hole detection
2007-03-21 19:15 ` [PATCH 1/3] add pfn_valid_within helper for sub-MAX_ORDER hole detection Andy Whitcroft
@ 2007-03-21 23:23 ` Nick Piggin
2007-03-21 23:46 ` Andrew Morton
0 siblings, 1 reply; 7+ messages in thread
From: Nick Piggin @ 2007-03-21 23:23 UTC (permalink / raw)
To: Andy Whitcroft
Cc: Mel Gorman, Bob Picco, Dave Hansen, Andrew Morton, linux-kernel
Andy Whitcroft wrote:
> Generally we work under the assumption that memory the mem_map
> array is contigious and valid out to MAX_ORDER_NR_PAGES block
> of pages, ie. that if we have validated any page within this
> MAX_ORDER_NR_PAGES block we need not check any other. This is not
> true when CONFIG_HOLES_IN_ZONE is set and we must check each and
> every reference we make from a pfn.
>
> Add a pfn_valid_within() helper which should be used when scanning
> pages within a MAX_ORDER_NR_PAGES block when we have already
> checked the validility of the block normally with pfn_valid().
> This can then be optimised away when we do not have holes within
> a MAX_ORDER_NR_PAGES block of pages.
Nice cleanup. Horrible name ;) Calls read like "is the pfn valid
within pfn".
I can't think of anything really good, but I think, say,
pfn_valid_within_block or pfn_valid_within_valid_block would be a
bit better. You still get a slight net savings in keystrokes!
Thanks,
Nick
>
> Signed-off-by: Andy Whitcroft <apw@shadowen.org>
> Acked-by: Mel Gorman <mel@csn.ul.ie>
> ---
> diff --git a/include/linux/mmzone.h b/include/linux/mmzone.h
> index 7206c77..8c87d79 100644
> --- a/include/linux/mmzone.h
> +++ b/include/linux/mmzone.h
> @@ -837,6 +837,18 @@ void sparse_init(void);
> void memory_present(int nid, unsigned long start, unsigned long end);
> unsigned long __init node_memmap_size_bytes(int, unsigned long, unsigned long);
>
> +/*
> + * If it is possible to have holes within a MAX_ORDER_NR_PAGES, then we
> + * need to check pfn validility within that MAX_ORDER_NR_PAGES block.
> + * pfn_valid_within() should be used in this case; we optimise this away
> + * when we have no holes within a MAX_ORDER_NR_PAGES block.
> + */
> +#ifdef CONFIG_HOLES_IN_ZONE
> +#define pfn_valid_within(pfn) pfn_valid(pfn)
> +#else
> +#define pfn_valid_within(pfn) (1)
> +#endif
> +
> #endif /* !__ASSEMBLY__ */
> #endif /* __KERNEL__ */
> #endif /* _LINUX_MMZONE_H */
> diff --git a/mm/page_alloc.c b/mm/page_alloc.c
> index 3d7a9e2..695b5a6 100644
> --- a/mm/page_alloc.c
> +++ b/mm/page_alloc.c
> @@ -206,10 +206,8 @@ static int page_outside_zone_boundaries(struct zone *zone, struct page *page)
>
> static int page_is_consistent(struct zone *zone, struct page *page)
> {
> -#ifdef CONFIG_HOLES_IN_ZONE
> - if (!pfn_valid(page_to_pfn(page)))
> + if (!pfn_valid_within(page_to_pfn(page)))
> return 0;
> -#endif
> if (zone != page_zone(page))
> return 0;
>
> @@ -411,10 +409,8 @@ __find_combined_index(unsigned long page_idx, unsigned int order)
> static inline int page_is_buddy(struct page *page, struct page *buddy,
> int order)
> {
> -#ifdef CONFIG_HOLES_IN_ZONE
> - if (!pfn_valid(page_to_pfn(buddy)))
> + if (!pfn_valid_within(page_to_pfn(buddy)))
> return 0;
> -#endif
>
> if (page_zone_id(page) != page_zone_id(buddy))
> return 0;
> -
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
>
--
SUSE Labs, Novell Inc.
Send instant messages to your online friends http://au.messenger.yahoo.com
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH 1/3] add pfn_valid_within helper for sub-MAX_ORDER hole detection
2007-03-21 23:23 ` Nick Piggin
@ 2007-03-21 23:46 ` Andrew Morton
0 siblings, 0 replies; 7+ messages in thread
From: Andrew Morton @ 2007-03-21 23:46 UTC (permalink / raw)
To: Nick Piggin
Cc: Andy Whitcroft, Mel Gorman, Bob Picco, Dave Hansen, linux-kernel
On Thu, 22 Mar 2007 10:23:27 +1100
Nick Piggin <nickpiggin@yahoo.com.au> wrote:
> Andy Whitcroft wrote:
> > Generally we work under the assumption that memory the mem_map
> > array is contigious and valid out to MAX_ORDER_NR_PAGES block
> > of pages, ie. that if we have validated any page within this
> > MAX_ORDER_NR_PAGES block we need not check any other. This is not
> > true when CONFIG_HOLES_IN_ZONE is set and we must check each and
> > every reference we make from a pfn.
> >
> > Add a pfn_valid_within() helper which should be used when scanning
> > pages within a MAX_ORDER_NR_PAGES block when we have already
> > checked the validility of the block normally with pfn_valid().
> > This can then be optimised away when we do not have holes within
> > a MAX_ORDER_NR_PAGES block of pages.
>
> Nice cleanup. Horrible name ;) Calls read like "is the pfn valid
> within pfn".
yeah
> I can't think of anything really good, but I think, say,
> pfn_valid_within_block or pfn_valid_within_valid_block would be a
> bit better. You still get a slight net savings in keystrokes!
Neither of those identifiers seem to really fit, and I can't think of anything
suitable either. Oh well, at least pfn_valid_within() has a nice comment
explaining what it does.
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2007-03-21 23:46 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
[not found] <Pine.LNX.4.64.0703211510340.15309@skynet.skynet.ie>
2007-03-21 19:14 ` [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper Andy Whitcroft
2007-03-21 19:15 ` [PATCH 1/3] add pfn_valid_within helper for sub-MAX_ORDER hole detection Andy Whitcroft
2007-03-21 23:23 ` Nick Piggin
2007-03-21 23:46 ` Andrew Morton
2007-03-21 19:15 ` [PATCH 2/3] anti-fragmentation: switch over to pfn_valid_within() Andy Whitcroft
2007-03-21 19:16 ` [PATCH 3/3] lumpy: move to using pfn_valid_within() Andy Whitcroft
2007-03-21 20:55 ` [PATCH 0/3] pfn_valid_within() HOLES_WITHIN_ZONES helper Bob Picco
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).