提交 33dd4e0e 编写于 作者: I Ian Campbell 提交者: Linus Torvalds

mm: make some struct page's const

These uses are read-only and in a subsequent patch I have a const struct
page in my hand...

[akpm@linux-foundation.org: fix warnings in lowmem_page_address()]
Signed-off-by: NIan Campbell <ian.campbell@citrix.com>
Cc: Rik van Riel <riel@redhat.com>
Cc: Andrea Arcangeli <aarcange@redhat.com>
Cc: Mel Gorman <mel@csn.ul.ie>
Cc: Michel Lespinasse <walken@google.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 ee8f248d
...@@ -637,7 +637,7 @@ static inline pte_t maybe_mkwrite(pte_t pte, struct vm_area_struct *vma) ...@@ -637,7 +637,7 @@ static inline pte_t maybe_mkwrite(pte_t pte, struct vm_area_struct *vma)
#define SECTIONS_MASK ((1UL << SECTIONS_WIDTH) - 1) #define SECTIONS_MASK ((1UL << SECTIONS_WIDTH) - 1)
#define ZONEID_MASK ((1UL << ZONEID_SHIFT) - 1) #define ZONEID_MASK ((1UL << ZONEID_SHIFT) - 1)
static inline enum zone_type page_zonenum(struct page *page) static inline enum zone_type page_zonenum(const struct page *page)
{ {
return (page->flags >> ZONES_PGSHIFT) & ZONES_MASK; return (page->flags >> ZONES_PGSHIFT) & ZONES_MASK;
} }
...@@ -665,15 +665,15 @@ static inline int zone_to_nid(struct zone *zone) ...@@ -665,15 +665,15 @@ static inline int zone_to_nid(struct zone *zone)
} }
#ifdef NODE_NOT_IN_PAGE_FLAGS #ifdef NODE_NOT_IN_PAGE_FLAGS
extern int page_to_nid(struct page *page); extern int page_to_nid(const struct page *page);
#else #else
static inline int page_to_nid(struct page *page) static inline int page_to_nid(const struct page *page)
{ {
return (page->flags >> NODES_PGSHIFT) & NODES_MASK; return (page->flags >> NODES_PGSHIFT) & NODES_MASK;
} }
#endif #endif
static inline struct zone *page_zone(struct page *page) static inline struct zone *page_zone(const struct page *page)
{ {
return &NODE_DATA(page_to_nid(page))->node_zones[page_zonenum(page)]; return &NODE_DATA(page_to_nid(page))->node_zones[page_zonenum(page)];
} }
...@@ -718,9 +718,9 @@ static inline void set_page_links(struct page *page, enum zone_type zone, ...@@ -718,9 +718,9 @@ static inline void set_page_links(struct page *page, enum zone_type zone,
*/ */
#include <linux/vmstat.h> #include <linux/vmstat.h>
static __always_inline void *lowmem_page_address(struct page *page) static __always_inline void *lowmem_page_address(const struct page *page)
{ {
return __va(PFN_PHYS(page_to_pfn(page))); return __va(PFN_PHYS(page_to_pfn((struct page *)page)));
} }
#if defined(CONFIG_HIGHMEM) && !defined(WANT_PAGE_VIRTUAL) #if defined(CONFIG_HIGHMEM) && !defined(WANT_PAGE_VIRTUAL)
......
...@@ -40,7 +40,7 @@ static u8 section_to_node_table[NR_MEM_SECTIONS] __cacheline_aligned; ...@@ -40,7 +40,7 @@ static u8 section_to_node_table[NR_MEM_SECTIONS] __cacheline_aligned;
static u16 section_to_node_table[NR_MEM_SECTIONS] __cacheline_aligned; static u16 section_to_node_table[NR_MEM_SECTIONS] __cacheline_aligned;
#endif #endif
int page_to_nid(struct page *page) int page_to_nid(const struct page *page)
{ {
return section_to_node_table[page_to_section(page)]; return section_to_node_table[page_to_section(page)];
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册