Lines Matching refs:page_ext

87 unsigned long page_ext_size = sizeof(struct page_ext);
126 static inline struct page_ext *get_entry(void *base, unsigned long index) in get_entry()
142 struct page_ext *page_ext_get(struct page *page) in page_ext_get()
144 struct page_ext *page_ext; in page_ext_get() local
147 page_ext = lookup_page_ext(page); in page_ext_get()
148 if (!page_ext) { in page_ext_get()
153 return page_ext; in page_ext_get()
166 void page_ext_put(struct page_ext *page_ext) in page_ext_put() argument
168 if (unlikely(!page_ext)) in page_ext_put()
181 struct page_ext *lookup_page_ext(const struct page *page) in lookup_page_ext()
185 struct page_ext *base; in lookup_page_ext()
205 struct page_ext *base; in alloc_node_page_ext()
256 static bool page_ext_invalid(struct page_ext *page_ext) in page_ext_invalid() argument
258 return !page_ext || (((unsigned long)page_ext & PAGE_EXT_INVALID) == PAGE_EXT_INVALID); in page_ext_invalid()
261 struct page_ext *lookup_page_ext(const struct page *page) in lookup_page_ext()
265 struct page_ext *page_ext = READ_ONCE(section->page_ext); in lookup_page_ext() local
274 if (page_ext_invalid(page_ext)) in lookup_page_ext()
276 return get_entry(page_ext, pfn); in lookup_page_ext()
299 struct page_ext *base; in init_section_page_ext()
304 if (section->page_ext) in init_section_page_ext()
327 section->page_ext = (void *)base - page_ext_size * pfn; in init_section_page_ext()
351 struct page_ext *base; in __free_page_ext()
354 if (!ms || !ms->page_ext) in __free_page_ext()
357 base = READ_ONCE(ms->page_ext); in __free_page_ext()
364 WRITE_ONCE(ms->page_ext, NULL); in __free_page_ext()
376 if (!ms || !ms->page_ext) in __invalidate_page_ext()
378 val = (void *)ms->page_ext + PAGE_EXT_INVALID; in __invalidate_page_ext()
379 WRITE_ONCE(ms->page_ext, val); in __invalidate_page_ext()