blob: 9f4bee5e51fd8af20aa353d1f9f348cb939b8b73 [file] [log] [blame]
Palmer Dabbelt76d2a042017-07-10 18:00:26 -07001/*
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
14#include <linux/init.h>
15#include <linux/mm.h>
16#include <linux/bootmem.h>
17#include <linux/initrd.h>
18#include <linux/memblock.h>
19#include <linux/swap.h>
20
21#include <asm/tlbflush.h>
22#include <asm/sections.h>
23#include <asm/pgtable.h>
24#include <asm/io.h>
25
26static void __init zone_sizes_init(void)
27{
28 unsigned long zones_size[MAX_NR_ZONES];
29
30 memset(zones_size, 0, sizeof(zones_size));
31 zones_size[ZONE_NORMAL] = max_mapnr;
32 free_area_init_node(0, zones_size, pfn_base, NULL);
33}
34
35void setup_zero_page(void)
36{
37 memset((void *)empty_zero_page, 0, PAGE_SIZE);
38}
39
40void __init paging_init(void)
41{
42 init_mm.pgd = (pgd_t *)pfn_to_virt(csr_read(sptbr));
43
44 setup_zero_page();
45 local_flush_tlb_all();
46 zone_sizes_init();
47}
48
49void __init mem_init(void)
50{
51#ifdef CONFIG_FLATMEM
52 BUG_ON(!mem_map);
53#endif /* CONFIG_FLATMEM */
54
55 high_memory = (void *)(__va(PFN_PHYS(max_low_pfn)));
56 free_all_bootmem();
57
58 mem_init_print_info(NULL);
59}
60
61void free_initmem(void)
62{
63 free_initmem_default(0);
64}
65
66#ifdef CONFIG_BLK_DEV_INITRD
67void free_initrd_mem(unsigned long start, unsigned long end)
68{
69}
70#endif /* CONFIG_BLK_DEV_INITRD */