|
@@ -11,13 +11,15 @@
|
|
|
#include <linux/gfp.h>
|
|
|
#include <linux/init.h>
|
|
|
#include <linux/bootmem.h>
|
|
|
+#include <linux/proc_fs.h>
|
|
|
+#include <linux/kcore.h>
|
|
|
#include <asm/tlb.h>
|
|
|
#include <asm/sections.h>
|
|
|
|
|
|
unsigned long empty_zero_page;
|
|
|
+EXPORT_SYMBOL(empty_zero_page);
|
|
|
|
|
|
-void __init
|
|
|
-mem_init(void)
|
|
|
+void __init mem_init(void)
|
|
|
{
|
|
|
BUG_ON(!mem_map);
|
|
|
|
|
@@ -31,10 +33,36 @@ mem_init(void)
|
|
|
mem_init_print_info(NULL);
|
|
|
}
|
|
|
|
|
|
-/* free the pages occupied by initialization code */
|
|
|
+/* Free a range of init pages. Virtual addresses. */
|
|
|
|
|
|
-void
|
|
|
-free_initmem(void)
|
|
|
+void free_init_pages(const char *what, unsigned long begin, unsigned long end)
|
|
|
+{
|
|
|
+ unsigned long addr;
|
|
|
+
|
|
|
+ for (addr = begin; addr < end; addr += PAGE_SIZE) {
|
|
|
+ ClearPageReserved(virt_to_page(addr));
|
|
|
+ init_page_count(virt_to_page(addr));
|
|
|
+ free_page(addr);
|
|
|
+ totalram_pages++;
|
|
|
+ }
|
|
|
+
|
|
|
+ printk(KERN_INFO "Freeing %s: %ldk freed\n", what, (end - begin) >> 10);
|
|
|
+}
|
|
|
+
|
|
|
+/* Free the pages occupied by initialization code. */
|
|
|
+
|
|
|
+void free_initmem(void)
|
|
|
{
|
|
|
free_initmem_default(-1);
|
|
|
}
|
|
|
+
|
|
|
+/* Free the pages occupied by initrd code. */
|
|
|
+
|
|
|
+#ifdef CONFIG_BLK_DEV_INITRD
|
|
|
+void free_initrd_mem(unsigned long start, unsigned long end)
|
|
|
+{
|
|
|
+ free_init_pages("initrd memory",
|
|
|
+ start,
|
|
|
+ end);
|
|
|
+}
|
|
|
+#endif
|