pgtable-32.c 1.6 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/init.h>
  9. #include <linux/mm.h>
  10. #include <linux/bootmem.h>
  11. #include <linux/highmem.h>
  12. #include <asm/fixmap.h>
  13. #include <asm/pgtable.h>
  14. void pgd_init(unsigned long page)
  15. {
  16. unsigned long *p = (unsigned long *) page;
  17. int i;
  18. for (i = 0; i < USER_PTRS_PER_PGD; i+=8) {
  19. p[i + 0] = (unsigned long) invalid_pte_table;
  20. p[i + 1] = (unsigned long) invalid_pte_table;
  21. p[i + 2] = (unsigned long) invalid_pte_table;
  22. p[i + 3] = (unsigned long) invalid_pte_table;
  23. p[i + 4] = (unsigned long) invalid_pte_table;
  24. p[i + 5] = (unsigned long) invalid_pte_table;
  25. p[i + 6] = (unsigned long) invalid_pte_table;
  26. p[i + 7] = (unsigned long) invalid_pte_table;
  27. }
  28. }
  29. void __init pagetable_init(void)
  30. {
  31. unsigned long vaddr;
  32. pgd_t *pgd_base;
  33. #ifdef CONFIG_HIGHMEM
  34. pgd_t *pgd;
  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. pgd_base = swapper_pg_dir;
  44. /*
  45. * Fixed mappings:
  46. */
  47. vaddr = __fix_to_virt(__end_of_fixed_addresses - 1) & PMD_MASK;
  48. fixrange_init(vaddr, 0, pgd_base);
  49. #ifdef CONFIG_HIGHMEM
  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. }