~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/nios2/mm/pgtable.c

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /*
  2  * Copyright (C) 2009 Wind River Systems Inc
  3  *   Implemented by fredrik.markstrom@gmail.com and ivarholmqvist@gmail.com
  4  *
  5  * This file is subject to the terms and conditions of the GNU General Public
  6  * License.  See the file "COPYING" in the main directory of this archive
  7  * for more details.
  8  */
  9 
 10 #include <linux/mm.h>
 11 #include <linux/sched.h>
 12 
 13 #include <asm/cpuinfo.h>
 14 
 15 /* pteaddr:
 16  *   ptbase | vpn* | zero
 17  *   31-22  | 21-2 | 1-0
 18  *
 19  *   *vpn is preserved on double fault
 20  *
 21  * tlbacc:
 22  *   IG   |*flags| pfn
 23  *   31-25|24-20 | 19-0
 24  *
 25  *   *crwxg
 26  *
 27  * tlbmisc:
 28  *   resv  |way   |rd | we|pid |dbl|bad|perm|d
 29  *   31-24 |23-20 |19 | 20|17-4|3  |2  |1   |0
 30  *
 31  */
 32 
 33 /*
 34  * Initialize a new pgd / pmd table with invalid pointers.
 35  */
 36 static void pgd_init(pgd_t *pgd)
 37 {
 38         unsigned long *p = (unsigned long *) pgd;
 39         int i;
 40 
 41         for (i = 0; i < USER_PTRS_PER_PGD; i += 8) {
 42                 p[i + 0] = (unsigned long) invalid_pte_table;
 43                 p[i + 1] = (unsigned long) invalid_pte_table;
 44                 p[i + 2] = (unsigned long) invalid_pte_table;
 45                 p[i + 3] = (unsigned long) invalid_pte_table;
 46                 p[i + 4] = (unsigned long) invalid_pte_table;
 47                 p[i + 5] = (unsigned long) invalid_pte_table;
 48                 p[i + 6] = (unsigned long) invalid_pte_table;
 49                 p[i + 7] = (unsigned long) invalid_pte_table;
 50         }
 51 }
 52 
 53 pgd_t *pgd_alloc(struct mm_struct *mm)
 54 {
 55         pgd_t *ret, *init;
 56 
 57         ret = (pgd_t *) __get_free_page(GFP_KERNEL);
 58         if (ret) {
 59                 init = pgd_offset(&init_mm, 0UL);
 60                 pgd_init(ret);
 61                 memcpy(ret + USER_PTRS_PER_PGD, init + USER_PTRS_PER_PGD,
 62                        (PTRS_PER_PGD - USER_PTRS_PER_PGD) * sizeof(pgd_t));
 63         }
 64 
 65         return ret;
 66 }
 67 
 68 void __init pagetable_init(void)
 69 {
 70         /* Initialize the entire pgd.  */
 71         pgd_init(swapper_pg_dir);
 72         pgd_init(swapper_pg_dir + USER_PTRS_PER_PGD);
 73 }
 74 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php