cregit-Linux how code gets into the kernel

Release 4.14 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 <linux/export.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 <linux/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/code-patching.h>
#include <asm/cpu_has_feature.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];

EXPORT_SYMBOL(smp_hw_index);


unsigned long ISA_DMA_THRESHOLD;

unsigned int DMA_MODE_READ;

unsigned int DMA_MODE_WRITE;


EXPORT_SYMBOL(ISA_DMA_THRESHOLD);

EXPORT_SYMBOL(DMA_MODE_READ);

EXPORT_SYMBOL(DMA_MODE_WRITE);

/*
 * We're called here very early in the boot.
 *
 * 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(); /* 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. */ identify_cpu(offset, mfspr(SPRN_PVR)); apply_feature_fixups(); return KERNELBASE + offset; }

Contributors

PersonTokensPropCommitsCommitProp
Paul Mackerras4983.05%444.44%
Stephen Rothwell58.47%111.11%
Anton Blanchard23.39%111.11%
Mark A. Greer11.69%111.11%
Benjamin Herrenschmidt11.69%111.11%
Steven Rostedt11.69%111.11%
Total59100.00%9100.00%

/* * This is run before start_kernel(), the kernel has been relocated * and we are running with enough of the MMU enabled to have our * proper kernel virtual addresses * * We do the initial parsing of the flat device-tree and prepares * for the MMU to be fully initialized. */ extern unsigned int memset_nocache_branch; /* Insn to be replaced by NOP */
notrace void __init machine_init(u64 dt_ptr) { unsigned int *addr = &memset_nocache_branch; unsigned long insn; /* Configure static keys first, now that we're relocated. */ setup_feature_keys(); /* Enable early debugging if any specified (see udbg.h) */ udbg_early_init(); patch_instruction((unsigned int *)&memcpy, PPC_INST_NOP); insn = create_cond_branch(addr, branch_target(addr), 0x820000); patch_instruction(addr, insn); /* replace b by bne cr0 */ /* Do some early initialization based on the flat device tree */ early_init_devtree(__va(dt_ptr)); early_init_mmu(); setup_kdump_trampoline(); }

Contributors

PersonTokensPropCommitsCommitProp
Christophe Leroy4758.75%327.27%
Paul Mackerras1620.00%19.09%
Benjamin Herrenschmidt67.50%218.18%
David Gibson33.75%19.09%
Dave Kleikamp33.75%19.09%
Dale Farnsworth33.75%19.09%
Steven Rostedt11.25%19.09%
Scott Wood11.25%19.09%
Total80100.00%11100.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 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 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 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 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 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 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 Mackerras43100.00%1100.00%
Total43100.00%1100.00%

arch_initcall(ppc_init);
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 Gala5694.92%133.33%
Yinghai Lu23.39%133.33%
Benjamin Herrenschmidt11.69%133.33%
Total59100.00%3100.00%

#if defined(CONFIG_BOOKE) || defined(CONFIG_40x)
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 Gala7774.04%125.00%
Dave Kleikamp1211.54%125.00%
Kevin Hao1110.58%125.00%
Yinghai Lu43.85%125.00%
Total104100.00%4100.00%

#endif
void __init setup_power_save(void) { #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 }

Contributors

PersonTokensPropCommitsCommitProp
Benjamin Herrenschmidt54100.00%2100.00%
Total54100.00%2100.00%


__init void initialize_cache_info(void) { /* * 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; }

Contributors

PersonTokensPropCommitsCommitProp
Benjamin Herrenschmidt38100.00%1100.00%
Total38100.00%1100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Paul Mackerras39344.71%512.50%
Kumar Gala14916.95%37.50%
Benjamin Herrenschmidt10812.29%1025.00%
Robert Brose576.48%12.50%
Christophe Leroy546.14%37.50%
Martyn Welch283.19%12.50%
Al Viro232.62%12.50%
Dave Kleikamp151.71%25.00%
Kevin Hao141.59%25.00%
Yinghai Lu70.80%12.50%
Stephen Rothwell70.80%25.00%
Nathan T. Lynch60.68%12.50%
Andrew Gabbasov50.57%12.50%
Dale Farnsworth30.34%12.50%
David Gibson30.34%12.50%
Anton Blanchard20.23%12.50%
Steven Rostedt20.23%12.50%
Scott Wood10.11%12.50%
Mark A. Greer10.11%12.50%
Linus Torvalds10.11%12.50%
Total879100.00%40100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.