Blame view

mm/internal.h 7.1 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
  /* internal.h: mm/ internal definitions
   *
   * Copyright (C) 2004 Red Hat, Inc. All Rights Reserved.
   * Written by David Howells (dhowells@redhat.com)
   *
   * This program is free software; you can redistribute it and/or
   * modify it under the terms of the GNU General Public License
   * as published by the Free Software Foundation; either version
   * 2 of the License, or (at your option) any later version.
   */
0f8053a50   Nick Piggin   [PATCH] mm: make ...
11
12
13
14
  #ifndef __MM_INTERNAL_H
  #define __MM_INTERNAL_H
  
  #include <linux/mm.h>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
15

42b777281   Jan Beulich   mm: remove double...
16
17
  void free_pgtables(struct mmu_gather *tlb, struct vm_area_struct *start_vma,
  		unsigned long floor, unsigned long ceiling);
7835e98b2   Nick Piggin   [PATCH] remove se...
18
  static inline void set_page_count(struct page *page, int v)
77a8a7883   Nick Piggin   [PATCH] mm: set_p...
19
  {
7835e98b2   Nick Piggin   [PATCH] remove se...
20
21
22
23
24
25
26
27
28
  	atomic_set(&page->_count, v);
  }
  
  /*
   * Turn a non-refcounted page (->_count == 0) into refcounted with
   * a count of one.
   */
  static inline void set_page_refcounted(struct page *page)
  {
ae1276b93   Qi Yong   set_page_refcount...
29
  	VM_BUG_ON(PageTail(page));
725d704ec   Nick Piggin   [PATCH] mm: VM_BU...
30
  	VM_BUG_ON(atomic_read(&page->_count));
77a8a7883   Nick Piggin   [PATCH] mm: set_p...
31
  	set_page_count(page, 1);
77a8a7883   Nick Piggin   [PATCH] mm: set_p...
32
  }
0f8053a50   Nick Piggin   [PATCH] mm: make ...
33
34
35
36
  static inline void __put_page(struct page *page)
  {
  	atomic_dec(&page->_count);
  }
03f6462a3   Hugh Dickins   mm: move highest_...
37
  extern unsigned long highest_memmap_pfn;
894bc3104   Lee Schermerhorn   Unevictable LRU I...
38
39
40
  /*
   * in mm/vmscan.c:
   */
62695a84e   Nick Piggin   vmscan: move isol...
41
  extern int isolate_lru_page(struct page *page);
894bc3104   Lee Schermerhorn   Unevictable LRU I...
42
  extern void putback_lru_page(struct page *page);
62695a84e   Nick Piggin   vmscan: move isol...
43

894bc3104   Lee Schermerhorn   Unevictable LRU I...
44
45
46
  /*
   * in mm/page_alloc.c
   */
0c0a4a517   Yasunori Goto   memory hotplug: f...
47
  extern void __free_pages_bootmem(struct page *page, unsigned int order);
20a0307c0   Wu Fengguang   mm: introduce Pag...
48
  extern void prep_compound_page(struct page *page, unsigned long order);
8d22ba1b7   Wu Fengguang   HWPOISON: detect ...
49
50
51
  #ifdef CONFIG_MEMORY_FAILURE
  extern bool is_free_buddy_page(struct page *page);
  #endif
20a0307c0   Wu Fengguang   mm: introduce Pag...
52

0f8053a50   Nick Piggin   [PATCH] mm: make ...
53

48f13bf3e   Mel Gorman   Breakout page_ord...
54
55
56
57
58
59
60
61
62
63
  /*
   * function for dealing with page's order in buddy system.
   * zone->lock is already acquired when we use these.
   * So, we don't need atomic page->flags operations here.
   */
  static inline unsigned long page_order(struct page *page)
  {
  	VM_BUG_ON(!PageBuddy(page));
  	return page_private(page);
  }
b5a0e0113   Alexander van Heukelum   Solve section mis...
64

af8e3354b   Hugh Dickins   mm: CONFIG_MMU fo...
65
66
67
68
69
70
71
72
73
  #ifdef CONFIG_MMU
  extern long mlock_vma_pages_range(struct vm_area_struct *vma,
  			unsigned long start, unsigned long end);
  extern void munlock_vma_pages_range(struct vm_area_struct *vma,
  			unsigned long start, unsigned long end);
  static inline void munlock_vma_pages_all(struct vm_area_struct *vma)
  {
  	munlock_vma_pages_range(vma, vma->vm_start, vma->vm_end);
  }
b291f0003   Nick Piggin   mlock: mlocked pa...
74
75
76
77
78
79
80
81
82
83
84
  /*
   * Called only in fault path via page_evictable() for a new page
   * to determine if it's being mapped into a LOCKED vma.
   * If so, mark page as mlocked.
   */
  static inline int is_mlocked_vma(struct vm_area_struct *vma, struct page *page)
  {
  	VM_BUG_ON(PageLRU(page));
  
  	if (likely((vma->vm_flags & (VM_LOCKED | VM_SPECIAL)) != VM_LOCKED))
  		return 0;
5344b7e64   Nick Piggin   vmstat: mlocked p...
85
86
87
88
  	if (!TestSetPageMlocked(page)) {
  		inc_zone_page_state(page, NR_MLOCK);
  		count_vm_event(UNEVICTABLE_PGMLOCKED);
  	}
b291f0003   Nick Piggin   mlock: mlocked pa...
89
90
91
92
  	return 1;
  }
  
  /*
73848b468   Hugh Dickins   ksm: fix mlockfre...
93
   * must be called with vma's mmap_sem held for read or write, and page locked.
b291f0003   Nick Piggin   mlock: mlocked pa...
94
95
   */
  extern void mlock_vma_page(struct page *page);
73848b468   Hugh Dickins   ksm: fix mlockfre...
96
  extern void munlock_vma_page(struct page *page);
b291f0003   Nick Piggin   mlock: mlocked pa...
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
  
  /*
   * Clear the page's PageMlocked().  This can be useful in a situation where
   * we want to unconditionally remove a page from the pagecache -- e.g.,
   * on truncation or freeing.
   *
   * It is legal to call this function for any page, mlocked or not.
   * If called for a page that is still mapped by mlocked vmas, all we do
   * is revert to lazy LRU behaviour -- semantics are not broken.
   */
  extern void __clear_page_mlock(struct page *page);
  static inline void clear_page_mlock(struct page *page)
  {
  	if (unlikely(TestClearPageMlocked(page)))
  		__clear_page_mlock(page);
  }
  
  /*
   * mlock_migrate_page - called only from migrate_page_copy() to
5344b7e64   Nick Piggin   vmstat: mlocked p...
116
   * migrate the Mlocked page flag; update statistics.
b291f0003   Nick Piggin   mlock: mlocked pa...
117
118
119
   */
  static inline void mlock_migrate_page(struct page *newpage, struct page *page)
  {
5344b7e64   Nick Piggin   vmstat: mlocked p...
120
121
122
123
124
  	if (TestClearPageMlocked(page)) {
  		unsigned long flags;
  
  		local_irq_save(flags);
  		__dec_zone_page_state(page, NR_MLOCK);
b291f0003   Nick Piggin   mlock: mlocked pa...
125
  		SetPageMlocked(newpage);
5344b7e64   Nick Piggin   vmstat: mlocked p...
126
127
128
  		__inc_zone_page_state(newpage, NR_MLOCK);
  		local_irq_restore(flags);
  	}
b291f0003   Nick Piggin   mlock: mlocked pa...
129
  }
af8e3354b   Hugh Dickins   mm: CONFIG_MMU fo...
130
  #else /* !CONFIG_MMU */
b291f0003   Nick Piggin   mlock: mlocked pa...
131
132
133
134
135
136
137
  static inline int is_mlocked_vma(struct vm_area_struct *v, struct page *p)
  {
  	return 0;
  }
  static inline void clear_page_mlock(struct page *page) { }
  static inline void mlock_vma_page(struct page *page) { }
  static inline void mlock_migrate_page(struct page *new, struct page *old) { }
af8e3354b   Hugh Dickins   mm: CONFIG_MMU fo...
138
  #endif /* !CONFIG_MMU */
894bc3104   Lee Schermerhorn   Unevictable LRU I...
139

b5a0e0113   Alexander van Heukelum   Solve section mis...
140
  /*
69d177c2f   Andy Whitcroft   hugetlbfs: handle...
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
   * Return the mem_map entry representing the 'offset' subpage within
   * the maximally aligned gigantic page 'base'.  Handle any discontiguity
   * in the mem_map at MAX_ORDER_NR_PAGES boundaries.
   */
  static inline struct page *mem_map_offset(struct page *base, int offset)
  {
  	if (unlikely(offset >= MAX_ORDER_NR_PAGES))
  		return pfn_to_page(page_to_pfn(base) + offset);
  	return base + offset;
  }
  
  /*
   * Iterator over all subpages withing the maximally aligned gigantic
   * page 'base'.  Handle any discontiguity in the mem_map.
   */
  static inline struct page *mem_map_next(struct page *iter,
  						struct page *base, int offset)
  {
  	if (unlikely((offset & (MAX_ORDER_NR_PAGES - 1)) == 0)) {
  		unsigned long pfn = page_to_pfn(base) + offset;
  		if (!pfn_valid(pfn))
  			return NULL;
  		return pfn_to_page(pfn);
  	}
  	return iter + 1;
  }
  
  /*
b5a0e0113   Alexander van Heukelum   Solve section mis...
169
170
171
172
173
174
175
176
177
178
   * FLATMEM and DISCONTIGMEM configurations use alloc_bootmem_node,
   * so all functions starting at paging_init should be marked __init
   * in those cases. SPARSEMEM, however, allows for memory hotplug,
   * and alloc_bootmem_node is not used.
   */
  #ifdef CONFIG_SPARSEMEM
  #define __paginginit __meminit
  #else
  #define __paginginit __init
  #endif
6b74ab97b   Mel Gorman   mm: add a basic d...
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
  /* Memory initialisation debug and verification */
  enum mminit_level {
  	MMINIT_WARNING,
  	MMINIT_VERIFY,
  	MMINIT_TRACE
  };
  
  #ifdef CONFIG_DEBUG_MEMORY_INIT
  
  extern int mminit_loglevel;
  
  #define mminit_dprintk(level, prefix, fmt, arg...) \
  do { \
  	if (level < mminit_loglevel) { \
  		printk(level <= MMINIT_WARNING ? KERN_WARNING : KERN_DEBUG); \
  		printk(KERN_CONT "mminit::" prefix " " fmt, ##arg); \
  	} \
  } while (0)
708614e61   Mel Gorman   mm: verify the pa...
197
198
199
  extern void mminit_verify_pageflags_layout(void);
  extern void mminit_verify_page_links(struct page *page,
  		enum zone_type zone, unsigned long nid, unsigned long pfn);
68ad8df42   Mel Gorman   mm: print out the...
200
  extern void mminit_verify_zonelist(void);
708614e61   Mel Gorman   mm: verify the pa...
201

6b74ab97b   Mel Gorman   mm: add a basic d...
202
203
204
205
206
207
  #else
  
  static inline void mminit_dprintk(enum mminit_level level,
  				const char *prefix, const char *fmt, ...)
  {
  }
708614e61   Mel Gorman   mm: verify the pa...
208
209
210
211
212
213
214
215
  static inline void mminit_verify_pageflags_layout(void)
  {
  }
  
  static inline void mminit_verify_page_links(struct page *page,
  		enum zone_type zone, unsigned long nid, unsigned long pfn)
  {
  }
68ad8df42   Mel Gorman   mm: print out the...
216
217
218
219
  
  static inline void mminit_verify_zonelist(void)
  {
  }
6b74ab97b   Mel Gorman   mm: add a basic d...
220
  #endif /* CONFIG_DEBUG_MEMORY_INIT */
2dbb51c49   Mel Gorman   mm: make defensiv...
221
222
223
224
225
226
227
228
229
230
231
  
  /* mminit_validate_memmodel_limits is independent of CONFIG_DEBUG_MEMORY_INIT */
  #if defined(CONFIG_SPARSEMEM)
  extern void mminit_validate_memmodel_limits(unsigned long *start_pfn,
  				unsigned long *end_pfn);
  #else
  static inline void mminit_validate_memmodel_limits(unsigned long *start_pfn,
  				unsigned long *end_pfn)
  {
  }
  #endif /* CONFIG_SPARSEMEM */
b291f0003   Nick Piggin   mlock: mlocked pa...
232
  int __get_user_pages(struct task_struct *tsk, struct mm_struct *mm,
58fa879e1   Hugh Dickins   mm: FOLL flags fo...
233
  		     unsigned long start, int len, unsigned int foll_flags,
b291f0003   Nick Piggin   mlock: mlocked pa...
234
  		     struct page **pages, struct vm_area_struct **vmas);
fa5e084e4   Mel Gorman   vmscan: do not un...
235
236
237
238
  #define ZONE_RECLAIM_NOSCAN	-2
  #define ZONE_RECLAIM_FULL	-1
  #define ZONE_RECLAIM_SOME	0
  #define ZONE_RECLAIM_SUCCESS	1
0f8053a50   Nick Piggin   [PATCH] mm: make ...
239
  #endif
7c116f2b0   Wu Fengguang   HWPOISON: add fs/...
240

31d3d3484   Wu Fengguang   HWPOISON: limit h...
241
  extern int hwpoison_filter(struct page *p);
7c116f2b0   Wu Fengguang   HWPOISON: add fs/...
242
243
  extern u32 hwpoison_filter_dev_major;
  extern u32 hwpoison_filter_dev_minor;
478c5ffc0   Wu Fengguang   HWPOISON: add pag...
244
245
  extern u64 hwpoison_filter_flags_mask;
  extern u64 hwpoison_filter_flags_value;
4fd466eb4   Andi Kleen   HWPOISON: add mem...
246
  extern u64 hwpoison_filter_memcg;
1bfe5febe   Haicheng Li   HWPOISON: add an ...
247
  extern u32 hwpoison_filter_enable;