mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-02 03:44:36 +08:00
e47168f3d1
The 8xx has 4 page sizes: 4k, 16k, 512k and 8M 4k and 16k can be selected at build time as standard page sizes, and 512k and 8M are hugepages. When 4k standard pages are selected, 16k pages are not available. Allow 16k pages as hugepages when 4k pages are used. To allow that, implement arch_make_huge_pte() which receives the necessary arguments to allow setting the PTE in accordance with the page size: - 512 k pages must have _PAGE_HUGE and _PAGE_SPS. They are set by pte_mkhuge(). arch_make_huge_pte() does nothing. - 16 k pages must have only _PAGE_SPS. arch_make_huge_pte() clears _PAGE_HUGE. Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu> Signed-off-by: Michael Ellerman <mpe@ellerman.id.au> Link: https://lore.kernel.org/r/a518abc29266a708dfbccc8fce9ae6694fe4c2c6.1598862623.git.christophe.leroy@csgroup.eu
93 lines
1.6 KiB
C
93 lines
1.6 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* From split of dump_linuxpagetables.c
|
|
* Copyright 2016, Rashmica Gupta, IBM Corp.
|
|
*
|
|
*/
|
|
#include <linux/kernel.h>
|
|
#include <linux/pgtable.h>
|
|
|
|
#include "ptdump.h"
|
|
|
|
static const struct flag_info flag_array[] = {
|
|
{
|
|
#ifdef CONFIG_PPC_16K_PAGES
|
|
.mask = _PAGE_HUGE,
|
|
.val = _PAGE_HUGE,
|
|
#else
|
|
.mask = _PAGE_SPS,
|
|
.val = _PAGE_SPS,
|
|
#endif
|
|
.set = "huge",
|
|
.clear = " ",
|
|
}, {
|
|
.mask = _PAGE_SH,
|
|
.val = 0,
|
|
.set = "user",
|
|
.clear = " ",
|
|
}, {
|
|
.mask = _PAGE_RO | _PAGE_NA,
|
|
.val = 0,
|
|
.set = "rw",
|
|
}, {
|
|
.mask = _PAGE_RO | _PAGE_NA,
|
|
.val = _PAGE_RO,
|
|
.set = "r ",
|
|
}, {
|
|
.mask = _PAGE_RO | _PAGE_NA,
|
|
.val = _PAGE_NA,
|
|
.set = " ",
|
|
}, {
|
|
.mask = _PAGE_EXEC,
|
|
.val = _PAGE_EXEC,
|
|
.set = " X ",
|
|
.clear = " ",
|
|
}, {
|
|
.mask = _PAGE_PRESENT,
|
|
.val = _PAGE_PRESENT,
|
|
.set = "present",
|
|
.clear = " ",
|
|
}, {
|
|
.mask = _PAGE_GUARDED,
|
|
.val = _PAGE_GUARDED,
|
|
.set = "guarded",
|
|
.clear = " ",
|
|
}, {
|
|
.mask = _PAGE_DIRTY,
|
|
.val = _PAGE_DIRTY,
|
|
.set = "dirty",
|
|
.clear = " ",
|
|
}, {
|
|
.mask = _PAGE_ACCESSED,
|
|
.val = _PAGE_ACCESSED,
|
|
.set = "accessed",
|
|
.clear = " ",
|
|
}, {
|
|
.mask = _PAGE_NO_CACHE,
|
|
.val = _PAGE_NO_CACHE,
|
|
.set = "no cache",
|
|
.clear = " ",
|
|
}, {
|
|
.mask = _PAGE_SPECIAL,
|
|
.val = _PAGE_SPECIAL,
|
|
.set = "special",
|
|
}
|
|
};
|
|
|
|
struct pgtable_level pg_level[5] = {
|
|
{
|
|
}, { /* pgd */
|
|
.flag = flag_array,
|
|
.num = ARRAY_SIZE(flag_array),
|
|
}, { /* pud */
|
|
.flag = flag_array,
|
|
.num = ARRAY_SIZE(flag_array),
|
|
}, { /* pmd */
|
|
.flag = flag_array,
|
|
.num = ARRAY_SIZE(flag_array),
|
|
}, { /* pte */
|
|
.flag = flag_array,
|
|
.num = ARRAY_SIZE(flag_array),
|
|
},
|
|
};
|