forked from mirrors/linux
		
	The page table entry is passed in the 'val' argument to note_page(), however this was previously an "unsigned long" which is fine on 64-bit platforms. But for 32 bit x86 it is not always big enough to contain a page table entry which may be 64 bits. Change the type to u64 to ensure that it is always big enough. [akpm@linux-foundation.org: fix riscv] Reported-by: Jan Beulich <jbeulich@suse.com> Signed-off-by: Steven Price <steven.price@arm.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Cc: Andy Lutomirski <luto@kernel.org> Cc: Borislav Petkov <bp@alien8.de> Cc: Dave Hansen <dave.hansen@linux.intel.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: <stable@vger.kernel.org> Link: http://lkml.kernel.org/r/20200521152308.33096-3-steven.price@arm.com Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			23 lines
		
	
	
	
		
			567 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			23 lines
		
	
	
	
		
			567 B
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 */
 | 
						|
 | 
						|
#ifndef _LINUX_PTDUMP_H
 | 
						|
#define _LINUX_PTDUMP_H
 | 
						|
 | 
						|
#include <linux/mm_types.h>
 | 
						|
 | 
						|
struct ptdump_range {
 | 
						|
	unsigned long start;
 | 
						|
	unsigned long end;
 | 
						|
};
 | 
						|
 | 
						|
struct ptdump_state {
 | 
						|
	/* level is 0:PGD to 4:PTE, or -1 if unknown */
 | 
						|
	void (*note_page)(struct ptdump_state *st, unsigned long addr,
 | 
						|
			  int level, u64 val);
 | 
						|
	void (*effective_prot)(struct ptdump_state *st, int level, u64 val);
 | 
						|
	const struct ptdump_range *range;
 | 
						|
};
 | 
						|
 | 
						|
void ptdump_walk_pgd(struct ptdump_state *st, struct mm_struct *mm, pgd_t *pgd);
 | 
						|
 | 
						|
#endif /* _LINUX_PTDUMP_H */
 |