mirror of
https://github.com/team-infusion-developers/android_kernel_samsung_msm8976.git
synced 2024-11-01 02:21:16 +00:00
b78e83204c
Concentrate code to modify totalram_pages into the mm core, so the arch memory initialized code doesn't need to take care of it. With these changes applied, only following functions from mm core modify global variable totalram_pages: free_bootmem_late(), free_all_bootmem(), free_all_bootmem_node(), adjust_managed_page_count(). With this patch applied, it will be much more easier for us to keep totalram_pages and zone->managed_pages in consistence. Signed-off-by: Jiang Liu <jiang.liu@huawei.com> Acked-by: David Howells <dhowells@redhat.com> Cc: "H. Peter Anvin" <hpa@zytor.com> Cc: "Michael S. Tsirkin" <mst@redhat.com> Cc: <sworddragon2@aol.com> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: Chris Metcalf <cmetcalf@tilera.com> Cc: Geert Uytterhoeven <geert@linux-m68k.org> Cc: Ingo Molnar <mingo@redhat.com> Cc: Jeremy Fitzhardinge <jeremy@goop.org> Cc: Jianguo Wu <wujianguo@huawei.com> Cc: Joonsoo Kim <js1304@gmail.com> Cc: Kamezawa Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> Cc: Marek Szyprowski <m.szyprowski@samsung.com> Cc: Mel Gorman <mel@csn.ul.ie> Cc: Michel Lespinasse <walken@google.com> Cc: Minchan Kim <minchan@kernel.org> Cc: Rik van Riel <riel@redhat.com> Cc: Rusty Russell <rusty@rustcorp.com.au> Cc: Tang Chen <tangchen@cn.fujitsu.com> Cc: Tejun Heo <tj@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Wen Congyang <wency@cn.fujitsu.com> Cc: Will Deacon <will.deacon@arm.com> Cc: Yasuaki Ishimatsu <isimatu.yasuaki@jp.fujitsu.com> Cc: Yinghai Lu <yinghai@kernel.org> Cc: Russell King <rmk@arm.linux.org.uk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Git-commit: 0c988534737a358fdff42fcce78f0ff1a12dbfc5 Git-repo: git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git Signed-off-by: Ian Maund <imaund@codeaurora.org>
207 lines
5.3 KiB
C
207 lines
5.3 KiB
C
/*
|
|
* linux/arch/m68k/mm/init.c
|
|
*
|
|
* Copyright (C) 1995 Hamish Macdonald
|
|
*
|
|
* Contains common initialization routines, specific init code moved
|
|
* to motorola.c and sun3mmu.c
|
|
*/
|
|
|
|
#include <linux/module.h>
|
|
#include <linux/signal.h>
|
|
#include <linux/sched.h>
|
|
#include <linux/mm.h>
|
|
#include <linux/swap.h>
|
|
#include <linux/kernel.h>
|
|
#include <linux/string.h>
|
|
#include <linux/types.h>
|
|
#include <linux/init.h>
|
|
#include <linux/bootmem.h>
|
|
#include <linux/gfp.h>
|
|
|
|
#include <asm/setup.h>
|
|
#include <asm/uaccess.h>
|
|
#include <asm/page.h>
|
|
#include <asm/pgalloc.h>
|
|
#include <asm/traps.h>
|
|
#include <asm/machdep.h>
|
|
#include <asm/io.h>
|
|
#ifdef CONFIG_ATARI
|
|
#include <asm/atari_stram.h>
|
|
#endif
|
|
#include <asm/sections.h>
|
|
#include <asm/tlb.h>
|
|
|
|
/*
|
|
* ZERO_PAGE is a special page that is used for zero-initialized
|
|
* data and COW.
|
|
*/
|
|
void *empty_zero_page;
|
|
EXPORT_SYMBOL(empty_zero_page);
|
|
|
|
#if !defined(CONFIG_SUN3) && !defined(CONFIG_COLDFIRE)
|
|
extern void init_pointer_table(unsigned long ptable);
|
|
extern pmd_t *zero_pgtable;
|
|
#endif
|
|
|
|
#ifdef CONFIG_MMU
|
|
|
|
pg_data_t pg_data_map[MAX_NUMNODES];
|
|
EXPORT_SYMBOL(pg_data_map);
|
|
|
|
int m68k_virt_to_node_shift;
|
|
|
|
#ifndef CONFIG_SINGLE_MEMORY_CHUNK
|
|
pg_data_t *pg_data_table[65];
|
|
EXPORT_SYMBOL(pg_data_table);
|
|
#endif
|
|
|
|
void __init m68k_setup_node(int node)
|
|
{
|
|
#ifndef CONFIG_SINGLE_MEMORY_CHUNK
|
|
struct mem_info *info = m68k_memory + node;
|
|
int i, end;
|
|
|
|
i = (unsigned long)phys_to_virt(info->addr) >> __virt_to_node_shift();
|
|
end = (unsigned long)phys_to_virt(info->addr + info->size - 1) >> __virt_to_node_shift();
|
|
for (; i <= end; i++) {
|
|
if (pg_data_table[i])
|
|
printk("overlap at %u for chunk %u\n", i, node);
|
|
pg_data_table[i] = pg_data_map + node;
|
|
}
|
|
#endif
|
|
pg_data_map[node].bdata = bootmem_node_data + node;
|
|
node_set_online(node);
|
|
}
|
|
|
|
#else /* CONFIG_MMU */
|
|
|
|
/*
|
|
* paging_init() continues the virtual memory environment setup which
|
|
* was begun by the code in arch/head.S.
|
|
* The parameters are pointers to where to stick the starting and ending
|
|
* addresses of available kernel virtual memory.
|
|
*/
|
|
void __init paging_init(void)
|
|
{
|
|
/*
|
|
* Make sure start_mem is page aligned, otherwise bootmem and
|
|
* page_alloc get different views of the world.
|
|
*/
|
|
unsigned long end_mem = memory_end & PAGE_MASK;
|
|
unsigned long zones_size[MAX_NR_ZONES] = { 0, };
|
|
|
|
high_memory = (void *) end_mem;
|
|
|
|
empty_zero_page = alloc_bootmem_pages(PAGE_SIZE);
|
|
memset(empty_zero_page, 0, PAGE_SIZE);
|
|
|
|
/*
|
|
* Set up SFC/DFC registers (user data space).
|
|
*/
|
|
set_fs (USER_DS);
|
|
|
|
zones_size[ZONE_DMA] = (end_mem - PAGE_OFFSET) >> PAGE_SHIFT;
|
|
free_area_init(zones_size);
|
|
}
|
|
|
|
#endif /* CONFIG_MMU */
|
|
|
|
void free_initmem(void)
|
|
{
|
|
#ifndef CONFIG_MMU_SUN3
|
|
free_initmem_default(0);
|
|
#endif /* CONFIG_MMU_SUN3 */
|
|
}
|
|
|
|
#if defined(CONFIG_MMU) && !defined(CONFIG_COLDFIRE)
|
|
#define VECTORS &vectors[0]
|
|
#else
|
|
#define VECTORS _ramvec
|
|
#endif
|
|
|
|
void __init print_memmap(void)
|
|
{
|
|
#define UL(x) ((unsigned long) (x))
|
|
#define MLK(b, t) UL(b), UL(t), (UL(t) - UL(b)) >> 10
|
|
#define MLM(b, t) UL(b), UL(t), (UL(t) - UL(b)) >> 20
|
|
#define MLK_ROUNDUP(b, t) b, t, DIV_ROUND_UP(((t) - (b)), 1024)
|
|
|
|
pr_notice("Virtual kernel memory layout:\n"
|
|
" vector : 0x%08lx - 0x%08lx (%4ld KiB)\n"
|
|
" kmap : 0x%08lx - 0x%08lx (%4ld MiB)\n"
|
|
" vmalloc : 0x%08lx - 0x%08lx (%4ld MiB)\n"
|
|
" lowmem : 0x%08lx - 0x%08lx (%4ld MiB)\n"
|
|
" .init : 0x%p" " - 0x%p" " (%4d KiB)\n"
|
|
" .text : 0x%p" " - 0x%p" " (%4d KiB)\n"
|
|
" .data : 0x%p" " - 0x%p" " (%4d KiB)\n"
|
|
" .bss : 0x%p" " - 0x%p" " (%4d KiB)\n",
|
|
MLK(VECTORS, VECTORS + 256),
|
|
MLM(KMAP_START, KMAP_END),
|
|
MLM(VMALLOC_START, VMALLOC_END),
|
|
MLM(PAGE_OFFSET, (unsigned long)high_memory),
|
|
MLK_ROUNDUP(__init_begin, __init_end),
|
|
MLK_ROUNDUP(_stext, _etext),
|
|
MLK_ROUNDUP(_sdata, _edata),
|
|
MLK_ROUNDUP(__bss_start, __bss_stop));
|
|
}
|
|
|
|
void __init mem_init(void)
|
|
{
|
|
pg_data_t *pgdat;
|
|
int codepages = 0;
|
|
int datapages = 0;
|
|
int initpages = 0;
|
|
int i;
|
|
|
|
/* this will put all memory onto the freelists */
|
|
num_physpages = 0;
|
|
for_each_online_pgdat(pgdat) {
|
|
num_physpages += pgdat->node_present_pages;
|
|
|
|
free_all_bootmem_node(pgdat);
|
|
for (i = 0; i < pgdat->node_spanned_pages; i++) {
|
|
struct page *page = pgdat->node_mem_map + i;
|
|
char *addr = page_to_virt(page);
|
|
|
|
if (!PageReserved(page))
|
|
continue;
|
|
if (addr >= _text &&
|
|
addr < _etext)
|
|
codepages++;
|
|
else if (addr >= __init_begin &&
|
|
addr < __init_end)
|
|
initpages++;
|
|
else
|
|
datapages++;
|
|
}
|
|
}
|
|
|
|
#if defined(CONFIG_MMU) && !defined(CONFIG_SUN3) && !defined(CONFIG_COLDFIRE)
|
|
/* insert pointer tables allocated so far into the tablelist */
|
|
init_pointer_table((unsigned long)kernel_pg_dir);
|
|
for (i = 0; i < PTRS_PER_PGD; i++) {
|
|
if (pgd_present(kernel_pg_dir[i]))
|
|
init_pointer_table(__pgd_page(kernel_pg_dir[i]));
|
|
}
|
|
|
|
/* insert also pointer table that we used to unmap the zero page */
|
|
if (zero_pgtable)
|
|
init_pointer_table((unsigned long)zero_pgtable);
|
|
#endif
|
|
|
|
pr_info("Memory: %luk/%luk available (%dk kernel code, %dk data, %dk init)\n",
|
|
nr_free_pages() << (PAGE_SHIFT-10),
|
|
totalram_pages << (PAGE_SHIFT-10),
|
|
codepages << (PAGE_SHIFT-10),
|
|
datapages << (PAGE_SHIFT-10),
|
|
initpages << (PAGE_SHIFT-10));
|
|
print_memmap();
|
|
}
|
|
|
|
#ifdef CONFIG_BLK_DEV_INITRD
|
|
void free_initrd_mem(unsigned long start, unsigned long end)
|
|
{
|
|
free_reserved_area(start, end, 0, "initrd");
|
|
}
|
|
#endif
|