-
Notifications
You must be signed in to change notification settings - Fork 54.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
mm: move page flags layout to separate header
This is a preparation patch for moving page->_last_nid into page->flags that moves page flag layout information to a separate header. This patch is necessary because otherwise there would be a circular dependency between mm_types.h and mm.h. Signed-off-by: Mel Gorman <mgorman@suse.de> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Andrea Arcangeli <aarcange@redhat.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Simon Jeons <simon.jeons@gmail.com> Cc: Wanpeng Li <liwanp@linux.vnet.ibm.com> Cc: Hugh Dickins <hughd@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
- Loading branch information
Showing
4 changed files
with
73 additions
and
61 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
#ifndef PAGE_FLAGS_LAYOUT_H | ||
#define PAGE_FLAGS_LAYOUT_H | ||
|
||
#include <linux/numa.h> | ||
#include <generated/bounds.h> | ||
|
||
/* | ||
* When a memory allocation must conform to specific limitations (such | ||
* as being suitable for DMA) the caller will pass in hints to the | ||
* allocator in the gfp_mask, in the zone modifier bits. These bits | ||
* are used to select a priority ordered list of memory zones which | ||
* match the requested limits. See gfp_zone() in include/linux/gfp.h | ||
*/ | ||
#if MAX_NR_ZONES < 2 | ||
#define ZONES_SHIFT 0 | ||
#elif MAX_NR_ZONES <= 2 | ||
#define ZONES_SHIFT 1 | ||
#elif MAX_NR_ZONES <= 4 | ||
#define ZONES_SHIFT 2 | ||
#else | ||
#error ZONES_SHIFT -- too many zones configured adjust calculation | ||
#endif | ||
|
||
#ifdef CONFIG_SPARSEMEM | ||
#include <asm/sparsemem.h> | ||
|
||
/* SECTION_SHIFT #bits space required to store a section # */ | ||
#define SECTIONS_SHIFT (MAX_PHYSMEM_BITS - SECTION_SIZE_BITS) | ||
|
||
#endif /* CONFIG_SPARSEMEM */ | ||
|
||
/* | ||
* page->flags layout: | ||
* | ||
* There are three possibilities for how page->flags get | ||
* laid out. The first is for the normal case, without | ||
* sparsemem. The second is for sparsemem when there is | ||
* plenty of space for node and section. The last is when | ||
* we have run out of space and have to fall back to an | ||
* alternate (slower) way of determining the node. | ||
* | ||
* No sparsemem or sparsemem vmemmap: | NODE | ZONE | ... | FLAGS | | ||
* classic sparse with space for node:| SECTION | NODE | ZONE | ... | FLAGS | | ||
* classic sparse no space for node: | SECTION | ZONE | ... | FLAGS | | ||
*/ | ||
#if defined(CONFIG_SPARSEMEM) && !defined(CONFIG_SPARSEMEM_VMEMMAP) | ||
#define SECTIONS_WIDTH SECTIONS_SHIFT | ||
#else | ||
#define SECTIONS_WIDTH 0 | ||
#endif | ||
|
||
#define ZONES_WIDTH ZONES_SHIFT | ||
|
||
#if SECTIONS_WIDTH+ZONES_WIDTH+NODES_SHIFT <= BITS_PER_LONG - NR_PAGEFLAGS | ||
#define NODES_WIDTH NODES_SHIFT | ||
#else | ||
#ifdef CONFIG_SPARSEMEM_VMEMMAP | ||
#error "Vmemmap: No space for nodes field in page flags" | ||
#endif | ||
#define NODES_WIDTH 0 | ||
#endif | ||
|
||
/* | ||
* We are going to use the flags for the page to node mapping if its in | ||
* there. This includes the case where there is no node, so it is implicit. | ||
*/ | ||
#if !(NODES_WIDTH > 0 || NODES_SHIFT == 0) | ||
#define NODE_NOT_IN_PAGE_FLAGS | ||
#endif | ||
|
||
#endif /* _LINUX_PAGE_FLAGS_LAYOUT */ |