diff options
Diffstat (limited to 'arch/metag')
31 files changed, 275 insertions, 104 deletions
| diff --git a/arch/metag/Kconfig b/arch/metag/Kconfig index dcd94406030..cfd831c2982 100644 --- a/arch/metag/Kconfig +++ b/arch/metag/Kconfig @@ -30,6 +30,7 @@ config METAG  	select OF  	select OF_EARLY_FLATTREE  	select SPARSE_IRQ +	select HAVE_DEBUG_STACKOVERFLOW  config STACKTRACE_SUPPORT  	def_bool y diff --git a/arch/metag/Kconfig.debug b/arch/metag/Kconfig.debug index e45bbf6a7a5..cb5c9286054 100644 --- a/arch/metag/Kconfig.debug +++ b/arch/metag/Kconfig.debug @@ -6,13 +6,6 @@ config TRACE_IRQFLAGS_SUPPORT  source "lib/Kconfig.debug" -config DEBUG_STACKOVERFLOW -	bool "Check for stack overflows" -	depends on DEBUG_KERNEL -	help -	  This option will cause messages to be printed if free stack space -	  drops below a certain limit. -  config 4KSTACKS  	bool "Use 4Kb for kernel stacks instead of 8Kb"  	depends on DEBUG_KERNEL diff --git a/arch/metag/Kconfig.soc b/arch/metag/Kconfig.soc index ec079cfb7c6..2a3c860c752 100644 --- a/arch/metag/Kconfig.soc +++ b/arch/metag/Kconfig.soc @@ -14,6 +14,18 @@ config META21_FPGA  	help  	  This is a Meta 2.1 FPGA bitstream, just a bare CPU. +config SOC_TZ1090 +	bool "Toumaz Xenif TZ1090 SoC (Comet)" +	select METAG_LNKGET_AROUND_CACHE +	select METAG_META21 +	select METAG_SMP_WRITE_REORDERING +	select PINCTRL +	select PINCTRL_TZ1090 +	select PINCTRL_TZ1090_PDC +	help +	  This is a Toumaz Technology Xenif TZ1090 (A.K.A. Comet) SoC containing +	  a 2-threaded HTP. +  endchoice  menu "SoC configuration" diff --git a/arch/metag/Makefile b/arch/metag/Makefile index b566116b171..9739857bded 100644 --- a/arch/metag/Makefile +++ b/arch/metag/Makefile @@ -20,7 +20,7 @@ checkflags-$(CONFIG_METAG_META12)	+= -DMETAC_1_2  checkflags-$(CONFIG_METAG_META21)	+= -DMETAC_2_1  CHECKFLAGS				+= -D__metag__ $(checkflags-y) -KBUILD_DEFCONFIG			:= meta2_defconfig +KBUILD_DEFCONFIG			:= tz1090_defconfig  sflags-$(CONFIG_METAG_META12)		+= -mmetac=1.2  ifeq ($(CONFIG_METAG_META12),y) diff --git a/arch/metag/boot/.gitignore b/arch/metag/boot/.gitignore index a021da20115..2d6c0c16088 100644 --- a/arch/metag/boot/.gitignore +++ b/arch/metag/boot/.gitignore @@ -1,4 +1,4 @@  vmlinux*  uImage*  ramdisk.* -*.dtb +*.dtb* diff --git a/arch/metag/boot/dts/Makefile b/arch/metag/boot/dts/Makefile index dbd95217733..72c12187942 100644 --- a/arch/metag/boot/dts/Makefile +++ b/arch/metag/boot/dts/Makefile @@ -1,7 +1,9 @@  dtb-y	+= skeleton.dtb +dtb-y	+= tz1090_generic.dtb  # Built-in dtb  builtindtb-y				:= skeleton +builtindtb-$(CONFIG_SOC_TZ1090)		:= tz1090_generic  ifneq ($(CONFIG_METAG_BUILTIN_DTB_NAME),"")  	builtindtb-y			:= $(patsubst "%",%,$(CONFIG_METAG_BUILTIN_DTB_NAME)) diff --git a/arch/metag/boot/dts/include/dt-bindings b/arch/metag/boot/dts/include/dt-bindings new file mode 120000 index 00000000000..08c00e4972f --- /dev/null +++ b/arch/metag/boot/dts/include/dt-bindings @@ -0,0 +1 @@ +../../../../../include/dt-bindings
\ No newline at end of file diff --git a/arch/metag/boot/dts/skeleton.dts b/arch/metag/boot/dts/skeleton.dts index 7244d1f0d55..7a49aeb365d 100644 --- a/arch/metag/boot/dts/skeleton.dts +++ b/arch/metag/boot/dts/skeleton.dts @@ -7,4 +7,4 @@   */  /dts-v1/; -/include/ "skeleton.dtsi" +#include "skeleton.dtsi" diff --git a/arch/metag/boot/dts/tz1090.dtsi b/arch/metag/boot/dts/tz1090.dtsi new file mode 100644 index 00000000000..853744652b9 --- /dev/null +++ b/arch/metag/boot/dts/tz1090.dtsi @@ -0,0 +1,41 @@ +/* + * Copyright (C) 2012 Imagination Technologies Ltd. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ + +#include "skeleton.dtsi" + +/ { +	compatible = "toumaz,tz1090", "img,meta"; + +	interrupt-parent = <&intc>; + +	intc: interrupt-controller { +		compatible = "img,meta-intc"; +		interrupt-controller; +		#interrupt-cells = <2>; +		num-banks = <2>; +	}; + +	soc { +		compatible = "simple-bus"; +		#address-cells = <1>; +		#size-cells = <1>; +		ranges; + +		pinctrl: pinctrl@02005800 { +			#gpio-range-cells = <3>; +			compatible = "img,tz1090-pinctrl"; +			reg = <0x02005800 0xe4>; +		}; + +		pdc_pinctrl: pinctrl@02006500 { +			#gpio-range-cells = <3>; +			compatible = "img,tz1090-pdc-pinctrl"; +			reg = <0x02006500 0x100>; +		}; +	}; +}; diff --git a/arch/metag/boot/dts/tz1090_generic.dts b/arch/metag/boot/dts/tz1090_generic.dts new file mode 100644 index 00000000000..f9609095596 --- /dev/null +++ b/arch/metag/boot/dts/tz1090_generic.dts @@ -0,0 +1,10 @@ +/* + * Copyright (C) 2012 Imagination Technologies Ltd. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + */ +/dts-v1/; + +#include "tz1090.dtsi" diff --git a/arch/metag/configs/tz1090_defconfig b/arch/metag/configs/tz1090_defconfig new file mode 100644 index 00000000000..9f9316a6df2 --- /dev/null +++ b/arch/metag/configs/tz1090_defconfig @@ -0,0 +1,42 @@ +# CONFIG_LOCALVERSION_AUTO is not set +# CONFIG_SWAP is not set +CONFIG_SYSVIPC=y +CONFIG_SYSFS_DEPRECATED=y +CONFIG_SYSFS_DEPRECATED_V2=y +CONFIG_KALLSYMS_ALL=y +# CONFIG_ELF_CORE is not set +CONFIG_SLAB=y +# CONFIG_BLK_DEV_BSG is not set +CONFIG_PARTITION_ADVANCED=y +# CONFIG_MSDOS_PARTITION is not set +# CONFIG_IOSCHED_DEADLINE is not set +# CONFIG_IOSCHED_CFQ is not set +CONFIG_FLATMEM_MANUAL=y +CONFIG_SOC_TZ1090=y +CONFIG_METAG_HALT_ON_PANIC=y +# CONFIG_METAG_FPU is not set +CONFIG_METAG_DA=y +CONFIG_HZ_100=y +CONFIG_DEVTMPFS=y +# CONFIG_STANDALONE is not set +# CONFIG_PREVENT_FIRMWARE_BUILD is not set +# CONFIG_FW_LOADER is not set +CONFIG_BLK_DEV_RAM=y +CONFIG_BLK_DEV_RAM_COUNT=1 +CONFIG_BLK_DEV_RAM_SIZE=16384 +# CONFIG_INPUT is not set +# CONFIG_SERIO is not set +# CONFIG_VT is not set +# CONFIG_LEGACY_PTYS is not set +CONFIG_DA_TTY=y +CONFIG_DA_CONSOLE=y +# CONFIG_DEVKMEM is not set +# CONFIG_HW_RANDOM is not set +CONFIG_GPIOLIB=y +# CONFIG_HWMON is not set +# CONFIG_USB_SUPPORT is not set +# CONFIG_DNOTIFY is not set +CONFIG_TMPFS=y +# CONFIG_MISC_FILESYSTEMS is not set +# CONFIG_SCHED_DEBUG is not set +CONFIG_DEBUG_INFO=y diff --git a/arch/metag/include/asm/bug.h b/arch/metag/include/asm/bug.h index d04b48cefec..9f8967f10f8 100644 --- a/arch/metag/include/asm/bug.h +++ b/arch/metag/include/asm/bug.h @@ -6,7 +6,7 @@  struct pt_regs;  extern const char *trap_name(int trapno); -extern void die(const char *str, struct pt_regs *regs, long err, -		unsigned long addr) __attribute__ ((noreturn)); +extern void __noreturn die(const char *str, struct pt_regs *regs, long err, +		unsigned long addr);  #endif diff --git a/arch/metag/include/asm/checksum.h b/arch/metag/include/asm/checksum.h index 999bf761a73..08dd1cc6579 100644 --- a/arch/metag/include/asm/checksum.h +++ b/arch/metag/include/asm/checksum.h @@ -64,7 +64,8 @@ static inline __wsum csum_tcpudp_nofold(__be32 saddr, __be32 daddr,  					__wsum sum)  {  	unsigned long len_proto = (proto + len) << 8; -	asm ("ADD    %0, %0, %1\n" +	asm ("ADDS   %0, %0, %1\n" +	     "ADDCS  %0, %0, #1\n"  	     "ADDS   %0, %0, %2\n"  	     "ADDCS  %0, %0, #1\n"  	     "ADDS   %0, %0, %3\n" diff --git a/arch/metag/include/asm/clock.h b/arch/metag/include/asm/clock.h index 3e2915a280c..ded4ab2e1fd 100644 --- a/arch/metag/include/asm/clock.h +++ b/arch/metag/include/asm/clock.h @@ -19,6 +19,8 @@   *			core frequency will be determined like this:   *			Meta 1: based on loops_per_jiffy.   *			Meta 2: (EXPAND_TIMER_DIV + 1) MHz. + *			If a "core" clock is provided by the device tree, it + *			will override this function.   */  struct meta_clock_desc {  	unsigned long		(*get_core_freq)(void); @@ -27,6 +29,12 @@ struct meta_clock_desc {  extern struct meta_clock_desc _meta_clock;  /* + * Perform platform clock initialisation, reading clocks from device tree etc. + * Only accessible during boot. + */ +void init_metag_clocks(void); + +/*   * Set up the default clock, ensuring all callbacks are valid - only accessible   * during boot.   */ diff --git a/arch/metag/include/asm/irq.h b/arch/metag/include/asm/irq.h index be0c8f3c5a5..ad6bd0edbc3 100644 --- a/arch/metag/include/asm/irq.h +++ b/arch/metag/include/asm/irq.h @@ -17,6 +17,7 @@ struct pt_regs;  int tbisig_map(unsigned int hw);  extern void do_IRQ(int irq, struct pt_regs *regs); +extern void init_IRQ(void);  #ifdef CONFIG_METAG_SUSPEND_MEM  int traps_save_context(void); diff --git a/arch/metag/include/asm/pgtable.h b/arch/metag/include/asm/pgtable.h index 1cd13d59519..0d9dc548729 100644 --- a/arch/metag/include/asm/pgtable.h +++ b/arch/metag/include/asm/pgtable.h @@ -333,9 +333,6 @@ static inline void update_mmu_cache(struct vm_area_struct *vma,  #define kern_addr_valid(addr)	(1) -#define io_remap_pfn_range(vma, vaddr, pfn, size, prot)		\ -	remap_pfn_range(vma, vaddr, pfn, size, prot) -  /*   * No page table caches to initialise   */ diff --git a/arch/metag/include/asm/processor.h b/arch/metag/include/asm/processor.h index 9b029a7911c..f16477d1f57 100644 --- a/arch/metag/include/asm/processor.h +++ b/arch/metag/include/asm/processor.h @@ -199,4 +199,6 @@ extern void (*soc_halt)(void);  extern void show_trace(struct task_struct *tsk, unsigned long *sp,  		       struct pt_regs *regs); +extern const struct seq_operations cpuinfo_op; +  #endif diff --git a/arch/metag/kernel/cachepart.c b/arch/metag/kernel/cachepart.c index 954548b1bea..0a2385fa2a1 100644 --- a/arch/metag/kernel/cachepart.c +++ b/arch/metag/kernel/cachepart.c @@ -100,22 +100,23 @@ void check_for_cache_aliasing(int thread_id)  		thread_cache_size =  				get_thread_cache_size(cache_type, thread_id);  		if (thread_cache_size < 0) -			pr_emerg("Can't read %s cache size", \ +			pr_emerg("Can't read %s cache size\n",  				 cache_type ? "DCACHE" : "ICACHE");  		else if (thread_cache_size == 0)  			/* Cache is off. No need to check for aliasing */  			continue;  		if (thread_cache_size / CACHE_ASSOCIATIVITY > PAGE_SIZE) { -			pr_emerg("Cache aliasing detected in %s on Thread %d", +			pr_emerg("Potential cache aliasing detected in %s on Thread %d\n",  				 cache_type ? "DCACHE" : "ICACHE", thread_id); -			pr_warn("Total %s size: %u bytes", -				cache_type ? "DCACHE" : "ICACHE ", +			pr_warn("Total %s size: %u bytes\n", +				cache_type ? "DCACHE" : "ICACHE",  				cache_type ? get_dcache_size()  				: get_icache_size()); -			pr_warn("Thread %s size: %d bytes", +			pr_warn("Thread %s size: %d bytes\n",  				cache_type ? "CACHE" : "ICACHE",  				thread_cache_size); -			pr_warn("Page Size: %lu bytes", PAGE_SIZE); +			pr_warn("Page Size: %lu bytes\n", PAGE_SIZE); +			panic("Potential cache aliasing detected");  		}  	}  } diff --git a/arch/metag/kernel/clock.c b/arch/metag/kernel/clock.c index defc84056f1..6339c9c6d0a 100644 --- a/arch/metag/kernel/clock.c +++ b/arch/metag/kernel/clock.c @@ -8,8 +8,10 @@   * published by the Free Software Foundation.   */ +#include <linux/clk.h>  #include <linux/delay.h>  #include <linux/io.h> +#include <linux/of.h>  #include <asm/param.h>  #include <asm/clock.h> @@ -34,8 +36,63 @@ static unsigned long get_core_freq_default(void)  #endif  } +static struct clk *clk_core; + +/* Clk based get_core_freq callback. */ +static unsigned long get_core_freq_clk(void) +{ +	return clk_get_rate(clk_core); +} + +/** + * init_metag_core_clock() - Set up core clock from devicetree. + * + * Checks to see if a "core" clock is provided in the device tree, and overrides + * the get_core_freq callback to use it. + */ +static void __init init_metag_core_clock(void) +{ +	/* +	 * See if a core clock is provided by the devicetree (and +	 * registered by the init callback above). +	 */ +	struct device_node *node; +	node = of_find_compatible_node(NULL, NULL, "img,meta"); +	if (!node) { +		pr_warn("%s: no compatible img,meta DT node found\n", +			__func__); +		return; +	} + +	clk_core = of_clk_get_by_name(node, "core"); +	if (IS_ERR(clk_core)) { +		pr_warn("%s: no core clock found in DT\n", +			__func__); +		return; +	} + +	/* +	 * Override the core frequency callback to use +	 * this clk. +	 */ +	_meta_clock.get_core_freq = get_core_freq_clk; +} + +/** + * init_metag_clocks() - Set up clocks from devicetree. + * + * Set up important clocks from device tree. In particular any needed for clock + * sources. + */ +void __init init_metag_clocks(void) +{ +	init_metag_core_clock(); + +	pr_info("Core clock frequency: %lu Hz\n", get_coreclock()); +} +  /** - * setup_meta_clocks() - Set up the Meta clock. + * setup_meta_clocks() - Early set up of the Meta clock.   * @desc:	Clock descriptor usually provided by machine description   *   * Ensures all callbacks are valid. diff --git a/arch/metag/kernel/irq.c b/arch/metag/kernel/irq.c index 87707efeb0a..2a2c9d55187 100644 --- a/arch/metag/kernel/irq.c +++ b/arch/metag/kernel/irq.c @@ -25,7 +25,7 @@ static union irq_ctx *hardirq_ctx[NR_CPUS] __read_mostly;  static union irq_ctx *softirq_ctx[NR_CPUS] __read_mostly;  #endif -struct irq_domain *root_domain; +static struct irq_domain *root_domain;  static unsigned int startup_meta_irq(struct irq_data *data)  { @@ -279,11 +279,12 @@ static void route_irq(struct irq_data *data, unsigned int irq, unsigned int cpu)  {  	struct irq_desc *desc = irq_to_desc(irq);  	struct irq_chip *chip = irq_data_get_irq_chip(data); +	unsigned long flags; -	raw_spin_lock_irq(&desc->lock); +	raw_spin_lock_irqsave(&desc->lock, flags);  	if (chip->irq_set_affinity)  		chip->irq_set_affinity(data, cpumask_of(cpu), false); -	raw_spin_unlock_irq(&desc->lock); +	raw_spin_unlock_irqrestore(&desc->lock, flags);  }  /* diff --git a/arch/metag/kernel/kick.c b/arch/metag/kernel/kick.c index 50fcbec98cd..beb37762132 100644 --- a/arch/metag/kernel/kick.c +++ b/arch/metag/kernel/kick.c @@ -26,6 +26,8 @@   * pass it as an argument.   */  #include <linux/export.h> +#include <linux/hardirq.h> +#include <linux/irq.h>  #include <linux/kernel.h>  #include <linux/mm.h>  #include <linux/types.h> @@ -66,6 +68,7 @@ EXPORT_SYMBOL(kick_unregister_func);  TBIRES  kick_handler(TBIRES State, int SigNum, int Triggers, int Inst, PTBI pTBI)  { +	struct pt_regs *old_regs;  	struct kick_irq_handler *kh;  	struct list_head *lh;  	int handled = 0; @@ -79,6 +82,9 @@ kick_handler(TBIRES State, int SigNum, int Triggers, int Inst, PTBI pTBI)  	trace_hardirqs_off(); +	old_regs = set_irq_regs((struct pt_regs *)State.Sig.pCtx); +	irq_enter(); +  	/*  	 * There is no need to disable interrupts here because we  	 * can't nest KICK interrupts in a KICK interrupt handler. @@ -97,5 +103,8 @@ kick_handler(TBIRES State, int SigNum, int Triggers, int Inst, PTBI pTBI)  	WARN_ON(!handled); +	irq_exit(); +	set_irq_regs(old_regs); +  	return tail_end(ret);  } diff --git a/arch/metag/kernel/metag_ksyms.c b/arch/metag/kernel/metag_ksyms.c index ec872ef14eb..215c94ad63a 100644 --- a/arch/metag/kernel/metag_ksyms.c +++ b/arch/metag/kernel/metag_ksyms.c @@ -1,5 +1,7 @@  #include <linux/export.h> +#include <linux/types.h> +#include <asm/checksum.h>  #include <asm/div64.h>  #include <asm/ftrace.h>  #include <asm/page.h> @@ -15,6 +17,9 @@ EXPORT_SYMBOL(max_pfn);  EXPORT_SYMBOL(min_low_pfn);  #endif +/* Network checksum functions */ +EXPORT_SYMBOL(csum_partial); +  /* TBI symbols */  EXPORT_SYMBOL(__TBI);  EXPORT_SYMBOL(__TBIFindSeg); diff --git a/arch/metag/kernel/perf/perf_event.c b/arch/metag/kernel/perf/perf_event.c index 366569425c5..5cc4d4dcf3c 100644 --- a/arch/metag/kernel/perf/perf_event.c +++ b/arch/metag/kernel/perf/perf_event.c @@ -813,8 +813,8 @@ static struct metag_pmu _metag_pmu = {  };  /* PMU CPU hotplug notifier */ -static int __cpuinit metag_pmu_cpu_notify(struct notifier_block *b, -		unsigned long action, void *hcpu) +static int metag_pmu_cpu_notify(struct notifier_block *b, unsigned long action, +				void *hcpu)  {  	unsigned int cpu = (unsigned int)hcpu;  	struct cpu_hw_events *cpuc = &per_cpu(cpu_hw_events, cpu); @@ -828,7 +828,7 @@ static int __cpuinit metag_pmu_cpu_notify(struct notifier_block *b,  	return NOTIFY_OK;  } -static struct notifier_block __cpuinitdata metag_pmu_notifier = { +static struct notifier_block metag_pmu_notifier = {  	.notifier_call = metag_pmu_cpu_notify,  }; @@ -882,7 +882,7 @@ static int __init init_hw_perf_events(void)  	}  	register_cpu_notifier(&metag_pmu_notifier); -	ret = perf_pmu_register(&pmu, (char *)metag_pmu->name, PERF_TYPE_RAW); +	ret = perf_pmu_register(&pmu, metag_pmu->name, PERF_TYPE_RAW);  out:  	return ret;  } diff --git a/arch/metag/kernel/setup.c b/arch/metag/kernel/setup.c index 4f5726f1a55..c396cd0b425 100644 --- a/arch/metag/kernel/setup.c +++ b/arch/metag/kernel/setup.c @@ -20,6 +20,7 @@  #include <linux/memblock.h>  #include <linux/mm.h>  #include <linux/of_fdt.h> +#include <linux/of_platform.h>  #include <linux/pfn.h>  #include <linux/root_dev.h>  #include <linux/sched.h> @@ -424,6 +425,9 @@ static int __init customize_machine(void)  	/* customizes platform devices, or adds new ones */  	if (machine_desc->init_machine)  		machine_desc->init_machine(); +	else +		of_platform_populate(NULL, of_default_bus_match_table, NULL, +				     NULL);  	return 0;  }  arch_initcall(customize_machine); @@ -587,20 +591,20 @@ PTBI pTBI_get(unsigned int cpu)  EXPORT_SYMBOL(pTBI_get);  #if defined(CONFIG_METAG_DSP) && defined(CONFIG_METAG_FPU) -char capabilites[] = "dsp fpu"; +static char capabilities[] = "dsp fpu";  #elif defined(CONFIG_METAG_DSP) -char capabilites[] = "dsp"; +static char capabilities[] = "dsp";  #elif defined(CONFIG_METAG_FPU) -char capabilites[] = "fpu"; +static char capabilities[] = "fpu";  #else -char capabilites[] = ""; +static char capabilities[] = "";  #endif  static struct ctl_table caps_kern_table[] = {  	{  		.procname	= "capabilities", -		.data		= capabilites, -		.maxlen		= sizeof(capabilites), +		.data		= capabilities, +		.maxlen		= sizeof(capabilities),  		.mode		= 0444,  		.proc_handler	= proc_dostring,  	}, diff --git a/arch/metag/kernel/smp.c b/arch/metag/kernel/smp.c index f443ec9a7cb..7c011314298 100644 --- a/arch/metag/kernel/smp.c +++ b/arch/metag/kernel/smp.c @@ -8,6 +8,7 @@   * published by the Free Software Foundation.   */  #include <linux/atomic.h> +#include <linux/completion.h>  #include <linux/delay.h>  #include <linux/init.h>  #include <linux/spinlock.h> @@ -62,10 +63,12 @@ static DEFINE_PER_CPU(struct ipi_data, ipi_data) = {  static DEFINE_SPINLOCK(boot_lock); +static DECLARE_COMPLETION(cpu_running); +  /*   * "thread" is assumed to be a valid Meta hardware thread ID.   */ -int __cpuinit boot_secondary(unsigned int thread, struct task_struct *idle) +int boot_secondary(unsigned int thread, struct task_struct *idle)  {  	u32 val; @@ -115,11 +118,9 @@ int __cpuinit boot_secondary(unsigned int thread, struct task_struct *idle)   * If the cache partition has changed, prints a message to the log describing   * those changes.   */ -static __cpuinit void describe_cachepart_change(unsigned int thread, -						const char *label, -						unsigned int sz, -						unsigned int old, -						unsigned int new) +static void describe_cachepart_change(unsigned int thread, const char *label, +				      unsigned int sz, unsigned int old, +				      unsigned int new)  {  	unsigned int lor1, land1, gor1, gand1;  	unsigned int lor2, land2, gor2, gand2; @@ -167,7 +168,7 @@ static __cpuinit void describe_cachepart_change(unsigned int thread,   * Ensures that coherency is enabled and that the threads share the same cache   * partitions.   */ -static __cpuinit void setup_smp_cache(unsigned int thread) +static void setup_smp_cache(unsigned int thread)  {  	unsigned int this_thread, lflags;  	unsigned int dcsz, dcpart_this, dcpart_old, dcpart_new; @@ -212,7 +213,7 @@ static __cpuinit void setup_smp_cache(unsigned int thread)  				  icpart_old, icpart_new);  } -int __cpuinit __cpu_up(unsigned int cpu, struct task_struct *idle) +int __cpu_up(unsigned int cpu, struct task_struct *idle)  {  	unsigned int thread = cpu_2_hwthread_id[cpu];  	int ret; @@ -235,20 +236,12 @@ int __cpuinit __cpu_up(unsigned int cpu, struct task_struct *idle)  	 */  	ret = boot_secondary(thread, idle);  	if (ret == 0) { -		unsigned long timeout; -  		/*  		 * CPU was successfully started, wait for it  		 * to come online or time out.  		 */ -		timeout = jiffies + HZ; -		while (time_before(jiffies, timeout)) { -			if (cpu_online(cpu)) -				break; - -			udelay(10); -			barrier(); -		} +		wait_for_completion_timeout(&cpu_running, +					    msecs_to_jiffies(1000));  		if (!cpu_online(cpu))  			ret = -EIO; @@ -273,10 +266,9 @@ static DECLARE_COMPLETION(cpu_killed);  /*   * __cpu_disable runs on the processor to be shutdown.   */ -int __cpuexit __cpu_disable(void) +int __cpu_disable(void)  {  	unsigned int cpu = smp_processor_id(); -	struct task_struct *p;  	/*  	 * Take this CPU offline.  Once we clear this, we can't return, @@ -296,12 +288,7 @@ int __cpuexit __cpu_disable(void)  	flush_cache_all();  	local_flush_tlb_all(); -	read_lock(&tasklist_lock); -	for_each_process(p) { -		if (p->mm) -			cpumask_clear_cpu(cpu, mm_cpumask(p->mm)); -	} -	read_unlock(&tasklist_lock); +	clear_tasks_mm_cpumask(cpu);  	return 0;  } @@ -310,7 +297,7 @@ int __cpuexit __cpu_disable(void)   * called on the thread which is asking for a CPU to be shutdown -   * waits until shutdown has completed, or it is timed out.   */ -void __cpuexit __cpu_die(unsigned int cpu) +void __cpu_die(unsigned int cpu)  {  	if (!wait_for_completion_timeout(&cpu_killed, msecs_to_jiffies(1)))  		pr_err("CPU%u: unable to kill\n", cpu); @@ -322,7 +309,7 @@ void __cpuexit __cpu_die(unsigned int cpu)   * Note that we do not return from this function. If this cpu is   * brought online again it will need to run secondary_startup().   */ -void __cpuexit cpu_die(void) +void cpu_die(void)  {  	local_irq_disable();  	idle_task_exit(); @@ -337,7 +324,7 @@ void __cpuexit cpu_die(void)   * Called by both boot and secondaries to move global data into   * per-processor storage.   */ -void __cpuinit smp_store_cpu_info(unsigned int cpuid) +void smp_store_cpu_info(unsigned int cpuid)  {  	struct cpuinfo_metag *cpu_info = &per_cpu(cpu_data, cpuid); @@ -385,12 +372,7 @@ asmlinkage void secondary_start_kernel(void)  	setup_priv(); -	/* -	 * Enable local interrupts. -	 */ -	tbi_startup_interrupt(TBID_SIGNUM_TRT);  	notify_cpu_starting(cpu); -	local_irq_enable();  	pr_info("CPU%u (thread %u): Booted secondary processor\n",  		cpu, cpu_2_hwthread_id[cpu]); @@ -402,12 +384,13 @@ asmlinkage void secondary_start_kernel(void)  	 * OK, now it's safe to let the boot CPU continue  	 */  	set_cpu_online(cpu, true); +	complete(&cpu_running);  	/* -	 * Check for cache aliasing. -	 * Preemption is disabled +	 * Enable local interrupts.  	 */ -	check_for_cache_aliasing(cpu); +	tbi_startup_interrupt(TBID_SIGNUM_TRT); +	local_irq_enable();  	/*  	 * OK, it's off to the idle thread for us diff --git a/arch/metag/kernel/time.c b/arch/metag/kernel/time.c index 17dc10733b2..f1c8c53dace 100644 --- a/arch/metag/kernel/time.c +++ b/arch/metag/kernel/time.c @@ -5,11 +5,21 @@   *   */ -#include <linux/init.h> -  #include <clocksource/metag_generic.h> +#include <linux/clk-provider.h> +#include <linux/init.h> +#include <asm/clock.h>  void __init time_init(void)  { +#ifdef CONFIG_COMMON_CLK +	/* Init clocks from device tree */ +	of_clk_init(NULL); +#endif + +	/* Init meta clocks, particularly the core clock */ +	init_metag_clocks(); + +	/* Set up the timer clock sources */  	metag_generic_timer_init();  } diff --git a/arch/metag/kernel/traps.c b/arch/metag/kernel/traps.c index 2ceeaae5b19..25f9d1c2ffe 100644 --- a/arch/metag/kernel/traps.c +++ b/arch/metag/kernel/traps.c @@ -33,6 +33,7 @@  #include <asm/siginfo.h>  #include <asm/traps.h>  #include <asm/hwthread.h> +#include <asm/setup.h>  #include <asm/switch.h>  #include <asm/user_gateway.h>  #include <asm/syscall.h> @@ -87,8 +88,8 @@ const char *trap_name(int trapno)  static DEFINE_SPINLOCK(die_lock); -void die(const char *str, struct pt_regs *regs, long err, -	 unsigned long addr) +void __noreturn die(const char *str, struct pt_regs *regs, +		    long err, unsigned long addr)  {  	static int die_counter; @@ -811,7 +812,7 @@ static void set_trigger_mask(unsigned int mask)  }  #endif -void __cpuinit per_cpu_trap_init(unsigned long cpu) +void per_cpu_trap_init(unsigned long cpu)  {  	TBIRES int_context;  	unsigned int thread = cpu_2_hwthread_id[cpu]; diff --git a/arch/metag/lib/checksum.c b/arch/metag/lib/checksum.c index 44d2e191356..5d6a98a05e9 100644 --- a/arch/metag/lib/checksum.c +++ b/arch/metag/lib/checksum.c @@ -124,7 +124,6 @@ __wsum csum_partial(const void *buff, int len, __wsum wsum)  		result += 1;  	return (__force __wsum)result;  } -EXPORT_SYMBOL(csum_partial);  /*   * this routine is used for miscellaneous IP-like checksums, mainly diff --git a/arch/metag/mm/cache.c b/arch/metag/mm/cache.c index b5d3b2e7c16..a62285284ab 100644 --- a/arch/metag/mm/cache.c +++ b/arch/metag/mm/cache.c @@ -45,7 +45,7 @@ static volatile u32 lnkget_testdata[16] __initdata __aligned(64);  #define LNKGET_CONSTANT 0xdeadbeef -void __init metag_lnkget_probe(void) +static void __init metag_lnkget_probe(void)  {  	int temp;  	long flags; diff --git a/arch/metag/mm/fault.c b/arch/metag/mm/fault.c index 2c75bf7357c..8fddf46e6c6 100644 --- a/arch/metag/mm/fault.c +++ b/arch/metag/mm/fault.c @@ -224,8 +224,10 @@ do_sigbus:  	 */  out_of_memory:  	up_read(&mm->mmap_sem); -	if (user_mode(regs)) -		do_group_exit(SIGKILL); +	if (user_mode(regs)) { +		pagefault_out_of_memory(); +		return 1; +	}  no_context:  	/* Are we prepared to handle this kernel fault?  */ diff --git a/arch/metag/mm/init.c b/arch/metag/mm/init.c index d05b8455c44..28813f16473 100644 --- a/arch/metag/mm/init.c +++ b/arch/metag/mm/init.c @@ -376,34 +376,21 @@ void __init paging_init(unsigned long mem_end)  void __init mem_init(void)  { -	int nid; -  #ifdef CONFIG_HIGHMEM  	unsigned long tmp; + +	/* +	 * Explicitly reset zone->managed_pages because highmem pages are +	 * freed before calling free_all_bootmem(); +	 */ +	reset_all_zones_managed_pages();  	for (tmp = highstart_pfn; tmp < highend_pfn; tmp++)  		free_highmem_page(pfn_to_page(tmp)); -	num_physpages += totalhigh_pages;  #endif /* CONFIG_HIGHMEM */ -	for_each_online_node(nid) { -		pg_data_t *pgdat = NODE_DATA(nid); -		unsigned long node_pages = 0; - -		num_physpages += pgdat->node_present_pages; - -		if (pgdat->node_spanned_pages) -			node_pages = free_all_bootmem_node(pgdat); - -		totalram_pages += node_pages; -	} - -	pr_info("Memory: %luk/%luk available\n", -		(unsigned long)nr_free_pages() << (PAGE_SHIFT - 10), -		num_physpages << (PAGE_SHIFT - 10)); - +	free_all_bootmem(); +	mem_init_print_info(NULL);  	show_mem(0); - -	return;  }  void free_initmem(void) @@ -414,7 +401,8 @@ void free_initmem(void)  #ifdef CONFIG_BLK_DEV_INITRD  void free_initrd_mem(unsigned long start, unsigned long end)  { -	free_reserved_area(start, end, POISON_FREE_INITMEM, "initrd"); +	free_reserved_area((void *)start, (void *)end, POISON_FREE_INITMEM, +			   "initrd");  }  #endif | 
