18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Copyright (C) 2000, 2001, 2002 Jeff Dike (jdike@karaya.com) 48c2ecf20Sopenharmony_ci * Copyright 2003 PathScale, Inc. 58c2ecf20Sopenharmony_ci * Derived from include/asm-i386/pgtable.h 68c2ecf20Sopenharmony_ci */ 78c2ecf20Sopenharmony_ci 88c2ecf20Sopenharmony_ci#ifndef __UM_PGTABLE_2LEVEL_H 98c2ecf20Sopenharmony_ci#define __UM_PGTABLE_2LEVEL_H 108c2ecf20Sopenharmony_ci 118c2ecf20Sopenharmony_ci#include <asm-generic/pgtable-nopmd.h> 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci/* PGDIR_SHIFT determines what a third-level page table entry can map */ 148c2ecf20Sopenharmony_ci 158c2ecf20Sopenharmony_ci#define PGDIR_SHIFT 22 168c2ecf20Sopenharmony_ci#define PGDIR_SIZE (1UL << PGDIR_SHIFT) 178c2ecf20Sopenharmony_ci#define PGDIR_MASK (~(PGDIR_SIZE-1)) 188c2ecf20Sopenharmony_ci 198c2ecf20Sopenharmony_ci/* 208c2ecf20Sopenharmony_ci * entries per page directory level: the i386 is two-level, so 218c2ecf20Sopenharmony_ci * we don't really have any PMD directory physically. 228c2ecf20Sopenharmony_ci */ 238c2ecf20Sopenharmony_ci#define PTRS_PER_PTE 1024 248c2ecf20Sopenharmony_ci#define USER_PTRS_PER_PGD ((TASK_SIZE + (PGDIR_SIZE - 1)) / PGDIR_SIZE) 258c2ecf20Sopenharmony_ci#define PTRS_PER_PGD 1024 268c2ecf20Sopenharmony_ci#define FIRST_USER_ADDRESS 0UL 278c2ecf20Sopenharmony_ci 288c2ecf20Sopenharmony_ci#define pte_ERROR(e) \ 298c2ecf20Sopenharmony_ci printk("%s:%d: bad pte %p(%08lx).\n", __FILE__, __LINE__, &(e), \ 308c2ecf20Sopenharmony_ci pte_val(e)) 318c2ecf20Sopenharmony_ci#define pgd_ERROR(e) \ 328c2ecf20Sopenharmony_ci printk("%s:%d: bad pgd %p(%08lx).\n", __FILE__, __LINE__, &(e), \ 338c2ecf20Sopenharmony_ci pgd_val(e)) 348c2ecf20Sopenharmony_ci 358c2ecf20Sopenharmony_cistatic inline int pgd_newpage(pgd_t pgd) { return 0; } 368c2ecf20Sopenharmony_cistatic inline void pgd_mkuptodate(pgd_t pgd) { } 378c2ecf20Sopenharmony_ci 388c2ecf20Sopenharmony_ci#define set_pmd(pmdptr, pmdval) (*(pmdptr) = (pmdval)) 398c2ecf20Sopenharmony_ci 408c2ecf20Sopenharmony_ci#define pte_pfn(x) phys_to_pfn(pte_val(x)) 418c2ecf20Sopenharmony_ci#define pfn_pte(pfn, prot) __pte(pfn_to_phys(pfn) | pgprot_val(prot)) 428c2ecf20Sopenharmony_ci#define pfn_pmd(pfn, prot) __pmd(pfn_to_phys(pfn) | pgprot_val(prot)) 438c2ecf20Sopenharmony_ci 448c2ecf20Sopenharmony_ci#endif 45