xref: /openbmc/linux/arch/mips/sgi-ip32/ip32-memory.c (revision ca15ca40)
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 Keith M Wesolowski
7  * Copyright (C) 2005 Ilya A. Volynets (Total Knowledge)
8  */
9 #include <linux/types.h>
10 #include <linux/init.h>
11 #include <linux/kernel.h>
12 #include <linux/mm.h>
13 
14 #include <asm/ip32/crime.h>
15 #include <asm/bootinfo.h>
16 #include <asm/page.h>
17 
18 extern void crime_init(void);
19 
20 void __init prom_meminit(void)
21 {
22 	u64 base, size;
23 	int bank;
24 
25 	crime_init();
26 
27 	for (bank=0; bank < CRIME_MAXBANKS; bank++) {
28 		u64 bankctl = crime->bank_ctrl[bank];
29 		base = (bankctl & CRIME_MEM_BANK_CONTROL_ADDR) << 25;
30 		if (bank != 0 && base == 0)
31 			continue;
32 		size = (bankctl & CRIME_MEM_BANK_CONTROL_SDRAM_SIZE) ? 128 : 32;
33 		size <<= 20;
34 		if (base + size > (256 << 20))
35 			base += CRIME_HI_MEM_BASE;
36 
37 		printk("CRIME MC: bank %u base 0x%016Lx size %LuMiB\n",
38 			bank, base, size >> 20);
39 		add_memory_region(base, size, BOOT_MEM_RAM);
40 	}
41 }
42 
43 
44 void __init prom_free_prom_memory(void)
45 {
46 }
47