pgtable-32.c 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /*
  2. * This file is subject to the terms and conditions of the GNU General Public
  3. * License. See the file "COPYING" in the main directory of this archive
  4. * for more details.
  5. *
  6. * Copyright (C) 2003 by Ralf Baechle
  7. */
  8. #include <linux/config.h>
  9. #include <linux/init.h>
  10. #include <linux/mm.h>
  11. #include <linux/bootmem.h>
  12. #include <linux/highmem.h>
  13. #include <asm/fixmap.h>
  14. #include <asm/pgtable.h>
  15. void pgd_init(unsigned long page)
  16. {
  17. unsigned long *p = (unsigned long *) page;
  18. int i;
  19. for (i = 0; i < USER_PTRS_PER_PGD; i+=8) {
  20. p[i + 0] = (unsigned long) invalid_pte_table;
  21. p[i + 1] = (unsigned long) invalid_pte_table;
  22. p[i + 2] = (unsigned long) invalid_pte_table;
  23. p[i + 3] = (unsigned long) invalid_pte_table;
  24. p[i + 4] = (unsigned long) invalid_pte_table;
  25. p[i + 5] = (unsigned long) invalid_pte_table;
  26. p[i + 6] = (unsigned long) invalid_pte_table;
  27. p[i + 7] = (unsigned long) invalid_pte_table;
  28. }
  29. }
  30. void __init pagetable_init(void)
  31. {
  32. #ifdef CONFIG_HIGHMEM
  33. unsigned long vaddr;
  34. pgd_t *pgd, *pgd_base;
  35. pud_t *pud;
  36. pmd_t *pmd;
  37. pte_t *pte;
  38. #endif
  39. /* Initialize the entire pgd. */
  40. pgd_init((unsigned long)swapper_pg_dir);
  41. pgd_init((unsigned long)swapper_pg_dir
  42. + sizeof(pgd_t) * USER_PTRS_PER_PGD);
  43. #ifdef CONFIG_HIGHMEM
  44. pgd_base = swapper_pg_dir;
  45. /*
  46. * Fixed mappings:
  47. */
  48. vaddr = __fix_to_virt(__end_of_fixed_addresses - 1) & PMD_MASK;
  49. fixrange_init(vaddr, 0, pgd_base);
  50. /*
  51. * Permanent kmaps:
  52. */
  53. vaddr = PKMAP_BASE;
  54. fixrange_init(vaddr, vaddr + PAGE_SIZE*LAST_PKMAP, pgd_base);
  55. pgd = swapper_pg_dir + __pgd_offset(vaddr);
  56. pud = pud_offset(pgd, vaddr);
  57. pmd = pmd_offset(pud, vaddr);
  58. pte = pte_offset_kernel(pmd, vaddr);
  59. pkmap_page_table = pte;
  60. #endif
  61. }