pgtable-32.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  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. #ifdef CONFIG_HIGHMEM
  32. unsigned long vaddr;
  33. pgd_t *pgd, *pgd_base;
  34. pud_t *pud;
  35. pmd_t *pmd;
  36. pte_t *pte;
  37. #endif
  38. /* Initialize the entire pgd. */
  39. pgd_init((unsigned long)swapper_pg_dir);
  40. pgd_init((unsigned long)swapper_pg_dir
  41. + sizeof(pgd_t) * USER_PTRS_PER_PGD);
  42. #ifdef CONFIG_HIGHMEM
  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. /*
  50. * Permanent kmaps:
  51. */
  52. vaddr = PKMAP_BASE;
  53. fixrange_init(vaddr, vaddr + PAGE_SIZE*LAST_PKMAP, pgd_base);
  54. pgd = swapper_pg_dir + __pgd_offset(vaddr);
  55. pud = pud_offset(pgd, vaddr);
  56. pmd = pmd_offset(pud, vaddr);
  57. pte = pte_offset_kernel(pmd, vaddr);
  58. pkmap_page_table = pte;
  59. #endif
  60. }