cregit-Linux how code gets into the kernel

Release 4.7 arch/powerpc/kernel/setup_32.c

/*
 * Common prep/pmac/chrp boot and setup code.
 */

#include <linux/module.h>
#include <linux/string.h>
#include <linux/sched.h>
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/reboot.h>
#include <linux/delay.h>
#include <linux/initrd.h>
#include <linux/tty.h>
#include <linux/seq_file.h>
#include <linux/root_dev.h>
#include <linux/cpu.h>
#include <linux/console.h>
#include <linux/memblock.h>

#include <asm/io.h>
#include <asm/prom.h>
#include <asm/processor.h>
#include <asm/pgtable.h>
#include <asm/setup.h>
#include <asm/smp.h>
#include <asm/elf.h>
#include <asm/cputable.h>
#include <asm/bootx.h>
#include <asm/btext.h>
#include <asm/machdep.h>
#include <asm/uaccess.h>
#include <asm/pmac_feature.h>
#include <asm/sections.h>
#include <asm/nvram.h>
#include <asm/xmon.h>
#include <asm/time.h>
#include <asm/serial.h>
#include <asm/udbg.h>
#include <asm/mmu_context.h>
#include <asm/epapr_hcalls.h>
#include <asm/code-patching.h>


#define DBG(fmt...)

extern void bootx_init(unsigned long r4, unsigned long phys);


int boot_cpuid_phys;

EXPORT_SYMBOL_GPL(boot_cpuid_phys);


int smp_hw_index[NR_CPUS];


unsigned long ISA_DMA_THRESHOLD;

unsigned int DMA_MODE_READ;

unsigned int DMA_MODE_WRITE;

/*
 * These are used in binfmt_elf.c to put aux entries on the stack
 * for each elf executable being started.
 */

int dcache_bsize;

int icache_bsize;

int ucache_bsize;

/*
 * We're called here very early in the boot.  We determine the machine
 * type and call the appropriate low-level setup functions.
 *  -- Cort <cort@fsmlabs.com>
 *
 * Note that the kernel may be running at an address which is different
 * from the address that it was linked at, so we must use RELOC/PTRRELOC
 * to access static data (including strings).  -- paulus
 */

notrace unsigned long __init early_init(unsigned long dt_ptr) { unsigned long offset = reloc_offset(); struct cpu_spec *spec; /* First zero the BSS -- use memset_io, some platforms don't have * caches on yet */ memset_io((void __iomem *)PTRRELOC(&__bss_start), 0, __bss_stop - __bss_start); /* * Identify the CPU type and fix up code sections * that depend on which cpu we have. */ spec = identify_cpu(offset, mfspr(SPRN_PVR)); do_feature_fixups(spec->cpu_features, PTRRELOC(&__start___ftr_fixup), PTRRELOC(&__stop___ftr_fixup)); do_feature_fixups(spec->mmu_features, PTRRELOC(&__start___mmu_ftr_fixup), PTRRELOC(&__stop___mmu_ftr_fixup)); do_lwsync_fixups(spec->cpu_features, PTRRELOC(&__start___lwsync_fixup), PTRRELOC(&__stop___lwsync_fixup)); do_final_fixups(); return KERNELBASE + offset; }

Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras5242.28%330.00%
benjamin herrenschmidtbenjamin herrenschmidt4234.15%220.00%
kumar galakumar gala1915.45%110.00%
stephen rothwellstephen rothwell54.07%110.00%
anton blanchardanton blanchard32.44%110.00%
steven rostedtsteven rostedt10.81%110.00%
mark a. greermark a. greer10.81%110.00%
Total123100.00%10100.00%

/* * Find out what kind of machine we're on and save any data we need * from the early boot process (devtree is copied on pmac by prom_init()). * This is called very early on the boot process, after a minimal * MMU environment has been set up but before MMU_init is called. */ extern unsigned int memset_nocache_branch; /* Insn to be replaced by NOP */
notrace void __init machine_init(u64 dt_ptr) { /* Enable early debugging if any specified (see udbg.h) */ udbg_early_init(); patch_instruction((unsigned int *)&memcpy, PPC_INST_NOP); patch_instruction(&memset_nocache_branch, PPC_INST_NOP); /* Do some early initialization based on the flat device tree */ early_init_devtree(__va(dt_ptr)); epapr_paravirt_early_init(); early_init_mmu(); probe_machine(); setup_kdump_trampoline(); #ifdef CONFIG_6xx if (cpu_has_feature(CPU_FTR_CAN_DOZE) || cpu_has_feature(CPU_FTR_CAN_NAP)) ppc_md.power_save = ppc6xx_idle; #endif #ifdef CONFIG_E500 if (cpu_has_feature(CPU_FTR_CAN_DOZE) || cpu_has_feature(CPU_FTR_CAN_NAP)) ppc_md.power_save = e500_idle; #endif if (ppc_md.progress) ppc_md.progress("id mach(): done", 0x200); }

Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras5446.15%215.38%
kumar galakumar gala2319.66%17.69%
christophe leroychristophe leroy2117.95%215.38%
benjamin herrenschmidtbenjamin herrenschmidt54.27%215.38%
laurentiu tudorlaurentiu tudor32.56%17.69%
dale farnsworthdale farnsworth32.56%17.69%
david gibsondavid gibson32.56%17.69%
dave kleikampdave kleikamp32.56%17.69%
steven rostedtsteven rostedt10.85%17.69%
scott woodscott wood10.85%17.69%
Total117100.00%13100.00%

/* Checks "l2cr=xxxx" command-line option */
int __init ppc_setup_l2cr(char *str) { if (cpu_has_feature(CPU_FTR_L2CR)) { unsigned long val = simple_strtoul(str, NULL, 0); printk(KERN_INFO "l2cr set to %lx\n", val); _set_L2CR(0); /* force invalidate by disable cache */ _set_L2CR(val); /* and enable it */ } return 1; }

Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras55100.00%1100.00%
Total55100.00%1100.00%

__setup("l2cr=", ppc_setup_l2cr); /* Checks "l3cr=xxxx" command-line option */
int __init ppc_setup_l3cr(char *str) { if (cpu_has_feature(CPU_FTR_L3CR)) { unsigned long val = simple_strtoul(str, NULL, 0); printk(KERN_INFO "l3cr set to %lx\n", val); _set_L3CR(val); /* and enable it */ } return 1; }

Contributors

PersonTokensPropCommitsCommitProp
robert broserobert brose49100.00%1100.00%
Total49100.00%1100.00%

__setup("l3cr=", ppc_setup_l3cr); #ifdef CONFIG_GENERIC_NVRAM /* Generic nvram hooks used by drivers/char/gen_nvram.c */
unsigned char nvram_read_byte(int addr) { if (ppc_md.nvram_read_val) return ppc_md.nvram_read_val(addr); return 0xff; }

Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras26100.00%1100.00%
Total26100.00%1100.00%

EXPORT_SYMBOL(nvram_read_byte);
void nvram_write_byte(unsigned char val, int addr) { if (ppc_md.nvram_write_val) ppc_md.nvram_write_val(addr, val); }

Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras27100.00%1100.00%
Total27100.00%1100.00%

EXPORT_SYMBOL(nvram_write_byte);
ssize_t nvram_get_size(void) { if (ppc_md.nvram_size) return ppc_md.nvram_size(); return -1; }

Contributors

PersonTokensPropCommitsCommitProp
martyn welchmartyn welch23100.00%1100.00%
Total23100.00%1100.00%

EXPORT_SYMBOL(nvram_get_size);
void nvram_sync(void) { if (ppc_md.nvram_sync) ppc_md.nvram_sync(); }

Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras18100.00%1100.00%
Total18100.00%1100.00%

EXPORT_SYMBOL(nvram_sync); #endif /* CONFIG_NVRAM */
int __init ppc_init(void) { /* clear the progress line */ if (ppc_md.progress) ppc_md.progress(" ", 0xffff); /* call platform init */ if (ppc_md.init != NULL) { ppc_md.init(); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras43100.00%1100.00%
Total43100.00%1100.00%

arch_initcall(ppc_init);
static void __init irqstack_early_init(void) { unsigned int i; /* interrupt stacks must be in lowmem, we get that for free on ppc32 * as the memblock is limited to lowmem by default */ for_each_possible_cpu(i) { softirq_ctx[i] = (struct thread_info *) __va(memblock_alloc(THREAD_SIZE, THREAD_SIZE)); hardirq_ctx[i] = (struct thread_info *) __va(memblock_alloc(THREAD_SIZE, THREAD_SIZE)); } }

Contributors

PersonTokensPropCommitsCommitProp
kumar galakumar gala5795.00%133.33%
yinghai luyinghai lu23.33%133.33%
benjamin herrenschmidtbenjamin herrenschmidt11.67%133.33%
Total60100.00%3100.00%

#if defined(CONFIG_BOOKE) || defined(CONFIG_40x)
static void __init exc_lvl_early_init(void) { unsigned int i, hw_cpu; /* interrupt stacks must be in lowmem, we get that for free on ppc32 * as the memblock is limited to lowmem by MEMBLOCK_REAL_LIMIT */ for_each_possible_cpu(i) { #ifdef CONFIG_SMP hw_cpu = get_hard_smp_processor_id(i); #else hw_cpu = 0; #endif critirq_ctx[hw_cpu] = (struct thread_info *) __va(memblock_alloc(THREAD_SIZE, THREAD_SIZE)); #ifdef CONFIG_BOOKE dbgirq_ctx[hw_cpu] = (struct thread_info *) __va(memblock_alloc(THREAD_SIZE, THREAD_SIZE)); mcheckirq_ctx[hw_cpu] = (struct thread_info *) __va(memblock_alloc(THREAD_SIZE, THREAD_SIZE)); #endif } }

Contributors

PersonTokensPropCommitsCommitProp
kumar galakumar gala7874.29%125.00%
dave kleikampdave kleikamp1211.43%125.00%
kevin haokevin hao1110.48%125.00%
yinghai luyinghai lu43.81%125.00%
Total105100.00%4100.00%

#else #define exc_lvl_early_init() #endif /* Warning, IO base is not yet inited */
void __init setup_arch(char **cmdline_p) { *cmdline_p = boot_command_line; /* so udelay does something sensible, assume <= 1000 bogomips */ loops_per_jiffy = 500000000 / HZ; unflatten_device_tree(); check_for_initrd(); if (ppc_md.init_early) ppc_md.init_early(); find_legacy_serial_ports(); smp_setup_cpu_maps(); /* Register early console */ register_early_udbg_console(); xmon_setup(); /* * Set cache line size based on type of cpu as a default. * Systems with OF can look in the properties on the cpu node(s) * for a possibly more accurate value. */ dcache_bsize = cur_cpu_spec->dcache_bsize; icache_bsize = cur_cpu_spec->icache_bsize; ucache_bsize = 0; if (cpu_has_feature(CPU_FTR_UNIFIED_ID_CACHE)) ucache_bsize = icache_bsize = dcache_bsize; if (ppc_md.panic) setup_panic(); init_mm.start_code = (unsigned long)_stext; init_mm.end_code = (unsigned long) _etext; init_mm.end_data = (unsigned long) _edata; init_mm.brk = klimit; exc_lvl_early_init(); irqstack_early_init(); initmem_init(); if ( ppc_md.progress ) ppc_md.progress("setup_arch: initmem", 0x3eab); #ifdef CONFIG_DUMMY_CONSOLE conswitchp = &dummy_con; #endif if (ppc_md.setup_arch) ppc_md.setup_arch(); if ( ppc_md.progress ) ppc_md.progress("arch: exit", 0x3eab); paging_init(); /* Initialize the MMU context management stuff */ mmu_context_init(); }

Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras12765.13%317.65%
benjamin herrenschmidtbenjamin herrenschmidt2211.28%317.65%
kumar galakumar gala2010.26%423.53%
michael ellermanmichael ellerman73.59%211.76%
david gibsondavid gibson73.59%15.88%
grant likelygrant likely63.08%15.88%
anton blanchardanton blanchard31.54%211.76%
david woodhousedavid woodhouse31.54%15.88%
Total195100.00%17100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
paul mackerraspaul mackerras57553.14%714.89%
kumar galakumar gala21920.24%714.89%
benjamin herrenschmidtbenjamin herrenschmidt797.30%714.89%
robert broserobert brose575.27%12.13%
christophe leroychristophe leroy302.77%24.26%
martyn welchmartyn welch282.59%12.13%
dave kleikampdave kleikamp151.39%24.26%
kevin haokevin hao111.02%12.13%
david gibsondavid gibson100.92%24.26%
stephen rothwellstephen rothwell70.65%24.26%
yinghai luyinghai lu70.65%12.13%
michael ellermanmichael ellerman70.65%24.26%
anton blanchardanton blanchard60.55%36.38%
grant likelygrant likely60.55%12.13%
nathan t. lynchnathan t. lynch60.55%12.13%
andrew gabbasovandrew gabbasov50.46%12.13%
laurentiu tudorlaurentiu tudor40.37%12.13%
david woodhousedavid woodhouse30.28%12.13%
dale farnsworthdale farnsworth30.28%12.13%
steven rostedtsteven rostedt20.18%12.13%
mark a. greermark a. greer10.09%12.13%
scott woodscott wood10.09%12.13%
Total1082100.00%47100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}