From: Joonsoo Kim <iamjoonsoo.kim@xxxxxxx> v2: Fix rebase mistake (per Vlastimil) Rename some variable/function to prevent confusion (per Vlastimil) Fix header dependency (per Sergey) This patchset tries to reduce memory waste by page extension user. First case is architecture supported debug_pagealloc. It doesn't requires additional memory if guard page isn't used. 8 bytes per page will be saved in this case. Second case is related to page owner feature. Until now, if page_ext users want to use it's own fields on page_ext, fields should be defined in struct page_ext by hard-coding. It has a following problem. struct page_ext { #ifdef CONFIG_A int a; #endif #ifdef CONFIG_B int b; #endif }; Assume that kernel is built with both CONFIG_A and CONFIG_B. Even if we enable feature A and doesn't enable feature B at runtime, each entry of struct page_ext takes two int rather than one int. It's undesirable waste so this patch tries to reduce it. By this patchset, we can save 20 bytes per page dedicated for page owner feature in some configurations. Thanks. Joonsoo Kim (6): mm/debug_pagealloc: clean-up guard page handling code mm/debug_pagealloc: don't allocate page_ext if we don't use guard page mm/page_owner: move page_owner specific function to page_owner.c mm/page_ext: rename offset to index mm/page_ext: support extra space allocation by page_ext user mm/page_owner: don't define fields on struct page_ext by hard-coding include/linux/page_ext.h | 8 +-- include/linux/page_owner.h | 2 + mm/page_alloc.c | 44 +++++++------ mm/page_ext.c | 45 +++++++++---- mm/page_owner.c | 156 ++++++++++++++++++++++++++++++++++++++------- mm/vmstat.c | 79 ----------------------- 6 files changed, 196 insertions(+), 138 deletions(-) -- 1.9.1 -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>