x86/pkeys/selftests: Save off 'prot' for allocations

This makes it possible to to tell what 'prot' a given allocation
is supposed to have. That way, if we want to change just the
pkey, we know what 'prot' to pass to mprotect_pkey().

Also, keep a record of the most recent allocation so the tests
can easily find it.

Signed-off-by: Dave Hansen <dave.hansen@linux.intel.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Dave Hansen <dave.hansen@intel.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Michael Ellermen <mpe@ellerman.id.au>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Ram Pai <linuxram@us.ibm.com>
Cc: Shuah Khan <shuah@kernel.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: linux-mm@kvack.org
Link: http://lkml.kernel.org/r/20180509171354.AA23E228@viggo.jf.intel.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>

authored by Dave Hansen and committed by Ingo Molnar acb25d76 3d64f4ed

+9 -5
+9 -5
tools/testing/selftests/x86/protection_keys.c
··· 677 677 struct pkey_malloc_record { 678 678 void *ptr; 679 679 long size; 680 + int prot; 680 681 }; 681 682 struct pkey_malloc_record *pkey_malloc_records; 683 + struct pkey_malloc_record *pkey_last_malloc_record; 682 684 long nr_pkey_malloc_records; 683 - void record_pkey_malloc(void *ptr, long size) 685 + void record_pkey_malloc(void *ptr, long size, int prot) 684 686 { 685 687 long i; 686 688 struct pkey_malloc_record *rec = NULL; ··· 714 712 (int)(rec - pkey_malloc_records), rec, ptr, size); 715 713 rec->ptr = ptr; 716 714 rec->size = size; 715 + rec->prot = prot; 716 + pkey_last_malloc_record = rec; 717 717 nr_pkey_malloc_records++; 718 718 } 719 719 ··· 760 756 pkey_assert(ptr != (void *)-1); 761 757 ret = mprotect_pkey((void *)ptr, PAGE_SIZE, prot, pkey); 762 758 pkey_assert(!ret); 763 - record_pkey_malloc(ptr, size); 759 + record_pkey_malloc(ptr, size, prot); 764 760 rdpkru(); 765 761 766 762 dprintf1("%s() for pkey %d @ %p\n", __func__, pkey, ptr); ··· 781 777 size = ALIGN_UP(size, HPAGE_SIZE * 2); 782 778 ptr = mmap(NULL, size, PROT_NONE, MAP_ANONYMOUS|MAP_PRIVATE, -1, 0); 783 779 pkey_assert(ptr != (void *)-1); 784 - record_pkey_malloc(ptr, size); 780 + record_pkey_malloc(ptr, size, prot); 785 781 mprotect_pkey(ptr, size, prot, pkey); 786 782 787 783 dprintf1("unaligned ptr: %p\n", ptr); ··· 854 850 pkey_assert(ptr != (void *)-1); 855 851 mprotect_pkey(ptr, size, prot, pkey); 856 852 857 - record_pkey_malloc(ptr, size); 853 + record_pkey_malloc(ptr, size, prot); 858 854 859 855 dprintf1("mmap()'d hugetlbfs for pkey %d @ %p\n", pkey, ptr); 860 856 return ptr; ··· 876 872 877 873 mprotect_pkey(ptr, size, prot, pkey); 878 874 879 - record_pkey_malloc(ptr, size); 875 + record_pkey_malloc(ptr, size, prot); 880 876 881 877 dprintf1("mmap()'d for pkey %d @ %p\n", pkey, ptr); 882 878 close(fd);