Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 | // SPDX-License-Identifier: GPL-2.0 /* * 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/memblock.h> #include <linux/gfp.h> #include <asm/setup.h> #include <linux/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); #ifdef CONFIG_MMU int m68k_virt_to_node_shift; void __init m68k_setup_node(int 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 max_zone_pfn[MAX_NR_ZONES] = { 0, }; high_memory = (void *) end_mem; empty_zero_page = memblock_alloc(PAGE_SIZE, PAGE_SIZE); if (!empty_zero_page) panic("%s: Failed to allocate %lu bytes align=0x%lx\n", __func__, PAGE_SIZE, PAGE_SIZE); max_zone_pfn[ZONE_DMA] = end_mem >> PAGE_SHIFT; free_area_init(max_zone_pfn); } #endif /* CONFIG_MMU */ void free_initmem(void) { #ifndef CONFIG_MMU_SUN3 free_initmem_default(-1); #endif /* CONFIG_MMU_SUN3 */ } #if defined(CONFIG_MMU) && !defined(CONFIG_COLDFIRE) #define VECTORS &vectors[0] #else #define VECTORS _ramvec #endif static inline void init_pointer_tables(void) { #if defined(CONFIG_MMU) && !defined(CONFIG_SUN3) && !defined(CONFIG_COLDFIRE) int i, j; /* insert pointer tables allocated so far into the tablelist */ init_pointer_table(kernel_pg_dir, TABLE_PGD); for (i = 0; i < PTRS_PER_PGD; i++) { pud_t *pud = (pud_t *)&kernel_pg_dir[i]; pmd_t *pmd_dir; if (!pud_present(*pud)) continue; pmd_dir = (pmd_t *)pgd_page_vaddr(kernel_pg_dir[i]); init_pointer_table(pmd_dir, TABLE_PMD); for (j = 0; j < PTRS_PER_PMD; j++) { pmd_t *pmd = &pmd_dir[j]; pte_t *pte_dir; if (!pmd_present(*pmd)) continue; pte_dir = (pte_t *)pmd_page_vaddr(*pmd); init_pointer_table(pte_dir, TABLE_PTE); } } #endif } void __init mem_init(void) { /* this will put all memory onto the freelists */ memblock_free_all(); init_pointer_tables(); } |