blob: e3667c9a33a5deea5ef1f849b97cb0c3fe83a404 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002#ifndef _4LEVEL_FIXUP_H
3#define _4LEVEL_FIXUP_H
4
5#define __ARCH_HAS_4LEVEL_HACK
Martin Schwidefskya8874e72018-10-31 12:11:48 +01006#define __PAGETABLE_PUD_FOLDED 1
Linus Torvalds1da177e2005-04-16 15:20:36 -07007
Kirill A. Shutemov4155b8e2015-02-11 15:26:44 -08008#define PUD_SHIFT PGDIR_SHIFT
Linus Torvalds1da177e2005-04-16 15:20:36 -07009#define PUD_SIZE PGDIR_SIZE
10#define PUD_MASK PGDIR_MASK
11#define PTRS_PER_PUD 1
12
13#define pud_t pgd_t
14
Hugh Dickins1bb36302005-10-29 18:16:22 -070015#define pmd_alloc(mm, pud, address) \
16 ((unlikely(pgd_none(*(pud))) && __pmd_alloc(mm, pud, address))? \
17 NULL: pmd_offset(pud, address))
Linus Torvalds1da177e2005-04-16 15:20:36 -070018
Linus Torvalds1da177e2005-04-16 15:20:36 -070019#define pud_offset(pgd, start) (pgd)
20#define pud_none(pud) 0
21#define pud_bad(pud) 0
22#define pud_present(pud) 1
23#define pud_ERROR(pud) do { } while (0)
24#define pud_clear(pud) pgd_clear(pud)
Dave McCracken46a82b22006-09-25 23:31:48 -070025#define pud_val(pud) pgd_val(pud)
26#define pud_populate(mm, pud, pmd) pgd_populate(mm, pud, pmd)
27#define pud_page(pud) pgd_page(pud)
28#define pud_page_vaddr(pud) pgd_page_vaddr(pud)
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
30#undef pud_free_tlb
Benjamin Herrenschmidt9e1b32c2009-07-22 15:44:28 +100031#define pud_free_tlb(tlb, x, addr) do { } while (0)
Benjamin Herrenschmidt5e541972008-02-04 22:29:14 -080032#define pud_free(mm, x) do { } while (0)
Benjamin Herrenschmidt9e1b32c2009-07-22 15:44:28 +100033#define __pud_free_tlb(tlb, x, addr) do { } while (0)
Linus Torvalds1da177e2005-04-16 15:20:36 -070034
35#undef pud_addr_end
36#define pud_addr_end(addr, end) (end)
37
Kirill A. Shutemov505a60e2017-03-09 17:24:03 +030038#include <asm-generic/5level-fixup.h>
39
Linus Torvalds1da177e2005-04-16 15:20:36 -070040#endif