2 * Port on Texas Instruments TMS320C6x architecture
4 * Copyright (C) 2004, 2009, 2010, 2011 Texas Instruments Incorporated
5 * Author: Aurelien Jacquiot (aurelien.jacquiot@jaluna.com)
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
12 #include <linux/swap.h>
13 #include <linux/module.h>
14 #include <linux/bootmem.h>
15 #ifdef CONFIG_BLK_DEV_RAM
16 #include <linux/blkdev.h>
18 #include <linux/initrd.h>
20 #include <asm/sections.h>
23 * ZERO_PAGE is a special page that is used for zero-initialized
26 unsigned long empty_zero_page
;
27 EXPORT_SYMBOL(empty_zero_page
);
30 * paging_init() continues the virtual memory environment setup which
31 * was begun by the code in arch/head.S.
32 * The parameters are pointers to where to stick the starting and ending
33 * addresses of available kernel virtual memory.
35 void __init
paging_init(void)
37 struct pglist_data
*pgdat
= NODE_DATA(0);
38 unsigned long zones_size
[MAX_NR_ZONES
] = {0, };
40 empty_zero_page
= (unsigned long) alloc_bootmem_pages(PAGE_SIZE
);
41 memset((void *)empty_zero_page
, 0, PAGE_SIZE
);
44 * Set up user data space
51 zones_size
[ZONE_NORMAL
] = (memory_end
- PAGE_OFFSET
) >> PAGE_SHIFT
;
52 pgdat
->node_zones
[ZONE_NORMAL
].zone_start_pfn
=
53 __pa(PAGE_OFFSET
) >> PAGE_SHIFT
;
55 free_area_init(zones_size
);
58 void __init
mem_init(void)
62 unsigned long len
= memory_end
- memory_start
;
64 high_memory
= (void *)(memory_end
& PAGE_MASK
);
66 /* this will put all memory onto the freelists */
67 totalram_pages
= free_all_bootmem();
69 codek
= (_etext
- _stext
) >> 10;
70 datak
= (_end
- _sdata
) >> 10;
72 tmp
= nr_free_pages() << PAGE_SHIFT
;
73 printk(KERN_INFO
"Memory: %luk/%luk RAM (%dk kernel code, %dk data)\n",
74 tmp
>> 10, len
>> 10, codek
, datak
);
77 #ifdef CONFIG_BLK_DEV_INITRD
78 void __init
free_initrd_mem(unsigned long start
, unsigned long end
)
81 for (; start
< end
; start
+= PAGE_SIZE
) {
82 ClearPageReserved(virt_to_page(start
));
83 init_page_count(virt_to_page(start
));
88 printk(KERN_INFO
"Freeing initrd memory: %luk freed\n",
89 (pages
* PAGE_SIZE
) >> 10);
93 void __init
free_initmem(void)
98 * The following code should be cool even if these sections
99 * are not page aligned.
101 addr
= PAGE_ALIGN((unsigned long)(__init_begin
));
103 /* next to check that the page we free is not a partial page */
104 for (; addr
+ PAGE_SIZE
< (unsigned long)(__init_end
);
106 ClearPageReserved(virt_to_page(addr
));
107 init_page_count(virt_to_page(addr
));
111 printk(KERN_INFO
"Freeing unused kernel memory: %dK freed\n",
112 (int) ((addr
- PAGE_ALIGN((long) &__init_begin
)) >> 10));