init.c 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /*
  2. * Copyright (C) 2012 Regents of the University of California
  3. *
  4. * This program is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU General Public License
  6. * as published by the Free Software Foundation, version 2.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. */
  13. #include <linux/init.h>
  14. #include <linux/mm.h>
  15. #include <linux/bootmem.h>
  16. #include <linux/initrd.h>
  17. #include <linux/memblock.h>
  18. #include <linux/swap.h>
  19. #include <linux/sizes.h>
  20. #include <asm/tlbflush.h>
  21. #include <asm/sections.h>
  22. #include <asm/pgtable.h>
  23. #include <asm/io.h>
  24. static void __init zone_sizes_init(void)
  25. {
  26. unsigned long max_zone_pfns[MAX_NR_ZONES] = { 0, };
  27. max_zone_pfns[ZONE_DMA32] = PFN_DOWN(min(4UL * SZ_1G, max_low_pfn));
  28. max_zone_pfns[ZONE_NORMAL] = max_low_pfn;
  29. free_area_init_nodes(max_zone_pfns);
  30. }
  31. void setup_zero_page(void)
  32. {
  33. memset((void *)empty_zero_page, 0, PAGE_SIZE);
  34. }
  35. void __init paging_init(void)
  36. {
  37. setup_zero_page();
  38. local_flush_tlb_all();
  39. zone_sizes_init();
  40. }
  41. void __init mem_init(void)
  42. {
  43. #ifdef CONFIG_FLATMEM
  44. BUG_ON(!mem_map);
  45. #endif /* CONFIG_FLATMEM */
  46. high_memory = (void *)(__va(PFN_PHYS(max_low_pfn)));
  47. free_all_bootmem();
  48. mem_init_print_info(NULL);
  49. }
  50. void free_initmem(void)
  51. {
  52. free_initmem_default(0);
  53. }
  54. #ifdef CONFIG_BLK_DEV_INITRD
  55. void free_initrd_mem(unsigned long start, unsigned long end)
  56. {
  57. }
  58. #endif /* CONFIG_BLK_DEV_INITRD */