diff options
Diffstat (limited to 'arch/tile/kernel')
| -rw-r--r-- | arch/tile/kernel/irq.c | 2 | ||||
| -rw-r--r-- | arch/tile/kernel/messaging.c | 2 | ||||
| -rw-r--r-- | arch/tile/kernel/setup.c | 32 | ||||
| -rw-r--r-- | arch/tile/kernel/smpboot.c | 8 | ||||
| -rw-r--r-- | arch/tile/kernel/stack.c | 2 | ||||
| -rw-r--r-- | arch/tile/kernel/time.c | 2 | ||||
| -rw-r--r-- | arch/tile/kernel/vmlinux.lds.S | 4 | 
7 files changed, 27 insertions, 25 deletions
| diff --git a/arch/tile/kernel/irq.c b/arch/tile/kernel/irq.c index 02e628065012..3ccf2cd7182e 100644 --- a/arch/tile/kernel/irq.c +++ b/arch/tile/kernel/irq.c @@ -220,7 +220,7 @@ void __init init_IRQ(void)  	ipi_init();  } -void __cpuinit setup_irq_regs(void) +void setup_irq_regs(void)  {  	/* Enable interrupt delivery. */  	unmask_irqs(~0UL); diff --git a/arch/tile/kernel/messaging.c b/arch/tile/kernel/messaging.c index 0858ee6b520f..00331af9525d 100644 --- a/arch/tile/kernel/messaging.c +++ b/arch/tile/kernel/messaging.c @@ -25,7 +25,7 @@  /* All messages are stored here */  static DEFINE_PER_CPU(HV_MsgState, msg_state); -void __cpuinit init_messaging(void) +void init_messaging(void)  {  	/* Allocate storage for messages in kernel space */  	HV_MsgState *state = &__get_cpu_var(msg_state); diff --git a/arch/tile/kernel/setup.c b/arch/tile/kernel/setup.c index 7a5aa1a7864e..eceb8344280f 100644 --- a/arch/tile/kernel/setup.c +++ b/arch/tile/kernel/setup.c @@ -58,8 +58,8 @@ struct pglist_data node_data[MAX_NUMNODES] __read_mostly;  EXPORT_SYMBOL(node_data);  /* Information on the NUMA nodes that we compute early */ -unsigned long __cpuinitdata node_start_pfn[MAX_NUMNODES]; -unsigned long __cpuinitdata node_end_pfn[MAX_NUMNODES]; +unsigned long node_start_pfn[MAX_NUMNODES]; +unsigned long node_end_pfn[MAX_NUMNODES];  unsigned long __initdata node_memmap_pfn[MAX_NUMNODES];  unsigned long __initdata node_percpu_pfn[MAX_NUMNODES];  unsigned long __initdata node_free_pfn[MAX_NUMNODES]; @@ -84,7 +84,7 @@ unsigned long __initdata boot_pc = (unsigned long)start_kernel;  #ifdef CONFIG_HIGHMEM  /* Page frame index of end of lowmem on each controller. */ -unsigned long __cpuinitdata node_lowmem_end_pfn[MAX_NUMNODES]; +unsigned long node_lowmem_end_pfn[MAX_NUMNODES];  /* Number of pages that can be mapped into lowmem. */  static unsigned long __initdata mappable_physpages; @@ -290,7 +290,7 @@ static void *__init setup_pa_va_mapping(void)   * This is up to 4 mappings for lowmem, one mapping per memory   * controller, plus one for our text segment.   */ -static void __cpuinit store_permanent_mappings(void) +static void store_permanent_mappings(void)  {  	int i; @@ -307,8 +307,8 @@ static void __cpuinit store_permanent_mappings(void)  		hv_store_mapping(addr, pages << PAGE_SHIFT, pa);  	} -	hv_store_mapping((HV_VirtAddr)_stext, -			 (uint32_t)(_einittext - _stext), 0); +	hv_store_mapping((HV_VirtAddr)_text, +			 (uint32_t)(_einittext - _text), 0);  }  /* @@ -329,6 +329,7 @@ static void __init setup_memory(void)  #if defined(CONFIG_HIGHMEM) || defined(__tilegx__)  	long lowmem_pages;  #endif +	unsigned long physpages = 0;  	/* We are using a char to hold the cpu_2_node[] mapping */  	BUILD_BUG_ON(MAX_NUMNODES > 127); @@ -388,8 +389,8 @@ static void __init setup_memory(void)  				continue;  			}  		} -		if (num_physpages + PFN_DOWN(range.size) > maxmem_pfn) { -			int max_size = maxmem_pfn - num_physpages; +		if (physpages + PFN_DOWN(range.size) > maxmem_pfn) { +			int max_size = maxmem_pfn - physpages;  			if (max_size > 0) {  				pr_err("Maxmem reduced node %d to %d pages\n",  				       i, max_size); @@ -446,7 +447,7 @@ static void __init setup_memory(void)  		node_start_pfn[i] = start;  		node_end_pfn[i] = end;  		node_controller[i] = range.controller; -		num_physpages += size; +		physpages += size;  		max_pfn = end;  		/* Mark node as online */ @@ -465,7 +466,7 @@ static void __init setup_memory(void)  	 * we're willing to use at 8 million pages (32GB of 4KB pages).  	 */  	cap = 8 * 1024 * 1024;  /* 8 million pages */ -	if (num_physpages > cap) { +	if (physpages > cap) {  		int num_nodes = num_online_nodes();  		int cap_each = cap / num_nodes;  		unsigned long dropped_pages = 0; @@ -476,10 +477,10 @@ static void __init setup_memory(void)  				node_end_pfn[i] = node_start_pfn[i] + cap_each;  			}  		} -		num_physpages -= dropped_pages; +		physpages -= dropped_pages;  		pr_warning("Only using %ldMB memory;"  		       " ignoring %ldMB.\n", -		       num_physpages >> (20 - PAGE_SHIFT), +		       physpages >> (20 - PAGE_SHIFT),  		       dropped_pages >> (20 - PAGE_SHIFT));  		pr_warning("Consider using a larger page size.\n");  	} @@ -497,7 +498,7 @@ static void __init setup_memory(void)  	lowmem_pages = (mappable_physpages > MAXMEM_PFN) ?  		MAXMEM_PFN : mappable_physpages; -	highmem_pages = (long) (num_physpages - lowmem_pages); +	highmem_pages = (long) (physpages - lowmem_pages);  	pr_notice("%ldMB HIGHMEM available.\n",  	       pages_to_mb(highmem_pages > 0 ? highmem_pages : 0)); @@ -514,7 +515,6 @@ static void __init setup_memory(void)  		pr_warning("Use a HIGHMEM enabled kernel.\n");  		max_low_pfn = MAXMEM_PFN;  		max_pfn = MAXMEM_PFN; -		num_physpages = MAXMEM_PFN;  		node_end_pfn[0] = MAXMEM_PFN;  	} else {  		pr_notice("%ldMB memory available.\n", @@ -935,7 +935,7 @@ subsys_initcall(topology_init);   * So the values we set up here in the hypervisor may be overridden on   * the boot cpu as arguments are parsed.   */ -static __cpuinit void init_super_pages(void) +static void init_super_pages(void)  {  #ifdef CONFIG_HUGETLB_SUPER_PAGES  	int i; @@ -950,7 +950,7 @@ static __cpuinit void init_super_pages(void)   *   * Called from setup_arch() on the boot cpu, or online_secondary().   */ -void __cpuinit setup_cpu(int boot) +void setup_cpu(int boot)  {  	/* The boot cpu sets up its permanent mappings much earlier. */  	if (!boot) diff --git a/arch/tile/kernel/smpboot.c b/arch/tile/kernel/smpboot.c index 44bab29bf2f3..a535655b7089 100644 --- a/arch/tile/kernel/smpboot.c +++ b/arch/tile/kernel/smpboot.c @@ -133,14 +133,14 @@ static __init int reset_init_affinity(void)  }  late_initcall(reset_init_affinity); -static struct cpumask cpu_started __cpuinitdata; +static struct cpumask cpu_started;  /*   * Activate a secondary processor.  Very minimal; don't add anything   * to this path without knowing what you're doing, since SMP booting   * is pretty fragile.   */ -static void __cpuinit start_secondary(void) +static void start_secondary(void)  {  	int cpuid = smp_processor_id(); @@ -183,7 +183,7 @@ static void __cpuinit start_secondary(void)  /*   * Bring a secondary processor online.   */ -void __cpuinit online_secondary(void) +void online_secondary(void)  {  	/*  	 * low-memory mappings have been cleared, flush them from @@ -210,7 +210,7 @@ void __cpuinit online_secondary(void)  	cpu_startup_entry(CPUHP_ONLINE);  } -int __cpuinit __cpu_up(unsigned int cpu, struct task_struct *tidle) +int __cpu_up(unsigned int cpu, struct task_struct *tidle)  {  	/* Wait 5s total for all CPUs for them to come online */  	static int timeout; diff --git a/arch/tile/kernel/stack.c b/arch/tile/kernel/stack.c index ed258b8ae320..af8dfc9665f6 100644 --- a/arch/tile/kernel/stack.c +++ b/arch/tile/kernel/stack.c @@ -442,7 +442,7 @@ void _KBacktraceIterator_init_current(struct KBacktraceIterator *kbt, ulong pc,  				regs_to_pt_regs(®s, pc, lr, sp, r52));  } -/* This is called only from kernel/sched.c, with esp == NULL */ +/* This is called only from kernel/sched/core.c, with esp == NULL */  void show_stack(struct task_struct *task, unsigned long *esp)  {  	struct KBacktraceIterator kbt; diff --git a/arch/tile/kernel/time.c b/arch/tile/kernel/time.c index 5ac397ec6986..7c353d8c2da9 100644 --- a/arch/tile/kernel/time.c +++ b/arch/tile/kernel/time.c @@ -159,7 +159,7 @@ static DEFINE_PER_CPU(struct clock_event_device, tile_timer) = {  	.set_mode = tile_timer_set_mode,  }; -void __cpuinit setup_tile_timer(void) +void setup_tile_timer(void)  {  	struct clock_event_device *evt = &__get_cpu_var(tile_timer); diff --git a/arch/tile/kernel/vmlinux.lds.S b/arch/tile/kernel/vmlinux.lds.S index 631f10de12fe..a13ed902afbb 100644 --- a/arch/tile/kernel/vmlinux.lds.S +++ b/arch/tile/kernel/vmlinux.lds.S @@ -27,7 +27,6 @@ SECTIONS    .intrpt1 (LOAD_OFFSET) : AT ( 0 )   /* put at the start of physical memory */    {      _text = .; -    _stext = .;      *(.intrpt1)    } :intrpt1 =0 @@ -36,6 +35,7 @@ SECTIONS    /* Now the real code */    . = ALIGN(0x20000); +  _stext = .;    .text : AT (ADDR(.text) - LOAD_OFFSET) {      HEAD_TEXT      SCHED_TEXT @@ -58,11 +58,13 @@ SECTIONS    #define LOAD_OFFSET PAGE_OFFSET    . = ALIGN(PAGE_SIZE); +  __init_begin = .;    VMLINUX_SYMBOL(_sinitdata) = .;    INIT_DATA_SECTION(16) :data =0    PERCPU_SECTION(L2_CACHE_BYTES)    . = ALIGN(PAGE_SIZE);    VMLINUX_SYMBOL(_einitdata) = .; +  __init_end = .;    _sdata = .;                   /* Start of data section */ |