diff options
Diffstat (limited to 'arch/sh/kernel')
40 files changed, 341 insertions, 420 deletions
diff --git a/arch/sh/kernel/cpu/clock-cpg.c b/arch/sh/kernel/cpu/clock-cpg.c index 8f63a264a84..f59b1f30d44 100644 --- a/arch/sh/kernel/cpu/clock-cpg.c +++ b/arch/sh/kernel/cpu/clock-cpg.c @@ -35,8 +35,6 @@ static struct clk *onchip_clocks[] = {  	&cpu_clk,  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("master_clk", &master_clk), diff --git a/arch/sh/kernel/cpu/sh3/Makefile b/arch/sh/kernel/cpu/sh3/Makefile index ecab274141a..6f13f33a35f 100644 --- a/arch/sh/kernel/cpu/sh3/Makefile +++ b/arch/sh/kernel/cpu/sh3/Makefile @@ -7,15 +7,15 @@ obj-y	:= ex.o probe.o entry.o setup-sh3.o  obj-$(CONFIG_HIBERNATION)		+= swsusp.o  # CPU subtype setup -obj-$(CONFIG_CPU_SUBTYPE_SH7705)	+= setup-sh7705.o -obj-$(CONFIG_CPU_SUBTYPE_SH7706)	+= setup-sh770x.o -obj-$(CONFIG_CPU_SUBTYPE_SH7707)	+= setup-sh770x.o -obj-$(CONFIG_CPU_SUBTYPE_SH7708)	+= setup-sh770x.o -obj-$(CONFIG_CPU_SUBTYPE_SH7709)	+= setup-sh770x.o -obj-$(CONFIG_CPU_SUBTYPE_SH7710)	+= setup-sh7710.o -obj-$(CONFIG_CPU_SUBTYPE_SH7712)	+= setup-sh7710.o -obj-$(CONFIG_CPU_SUBTYPE_SH7720)	+= setup-sh7720.o -obj-$(CONFIG_CPU_SUBTYPE_SH7721)	+= setup-sh7720.o +obj-$(CONFIG_CPU_SUBTYPE_SH7705)	+= setup-sh7705.o serial-sh770x.o +obj-$(CONFIG_CPU_SUBTYPE_SH7706)	+= setup-sh770x.o serial-sh770x.o +obj-$(CONFIG_CPU_SUBTYPE_SH7707)	+= setup-sh770x.o serial-sh770x.o +obj-$(CONFIG_CPU_SUBTYPE_SH7708)	+= setup-sh770x.o serial-sh770x.o +obj-$(CONFIG_CPU_SUBTYPE_SH7709)	+= setup-sh770x.o serial-sh770x.o +obj-$(CONFIG_CPU_SUBTYPE_SH7710)	+= setup-sh7710.o serial-sh7710.o +obj-$(CONFIG_CPU_SUBTYPE_SH7712)	+= setup-sh7710.o serial-sh7710.o +obj-$(CONFIG_CPU_SUBTYPE_SH7720)	+= setup-sh7720.o serial-sh7720.o +obj-$(CONFIG_CPU_SUBTYPE_SH7721)	+= setup-sh7720.o serial-sh7720.o  # Primary on-chip clocks (common)  clock-$(CONFIG_CPU_SH3)			:= clock-sh3.o diff --git a/arch/sh/kernel/cpu/sh3/serial-sh770x.c b/arch/sh/kernel/cpu/sh3/serial-sh770x.c new file mode 100644 index 00000000000..4f7242c676b --- /dev/null +++ b/arch/sh/kernel/cpu/sh3/serial-sh770x.c @@ -0,0 +1,33 @@ +#include <linux/serial_sci.h> +#include <linux/serial_core.h> +#include <linux/io.h> +#include <cpu/serial.h> + +#define SCPCR 0xA4000116 +#define SCPDR 0xA4000136 + +static void sh770x_sci_init_pins(struct uart_port *port, unsigned int cflag) +{ +	unsigned short data; + +	/* We need to set SCPCR to enable RTS/CTS */ +	data = __raw_readw(SCPCR); +	/* Clear out SCP7MD1,0, SCP6MD1,0, SCP4MD1,0*/ +	__raw_writew(data & 0x0fcf, SCPCR); + +	if (!(cflag & CRTSCTS)) { +		/* We need to set SCPCR to enable RTS/CTS */ +		data = __raw_readw(SCPCR); +		/* Clear out SCP7MD1,0, SCP4MD1,0, +		   Set SCP6MD1,0 = {01} (output)  */ +		__raw_writew((data & 0x0fcf) | 0x1000, SCPCR); + +		data = __raw_readb(SCPDR); +		/* Set /RTS2 (bit6) = 0 */ +		__raw_writeb(data & 0xbf, SCPDR); +	} +} + +struct plat_sci_port_ops sh770x_sci_port_ops = { +	.init_pins	= sh770x_sci_init_pins, +}; diff --git a/arch/sh/kernel/cpu/sh3/serial-sh7710.c b/arch/sh/kernel/cpu/sh3/serial-sh7710.c new file mode 100644 index 00000000000..42190ef6aeb --- /dev/null +++ b/arch/sh/kernel/cpu/sh3/serial-sh7710.c @@ -0,0 +1,20 @@ +#include <linux/serial_sci.h> +#include <linux/serial_core.h> +#include <linux/io.h> +#include <cpu/serial.h> + +#define PACR 0xa4050100 +#define PBCR 0xa4050102 + +static void sh7710_sci_init_pins(struct uart_port *port, unsigned int cflag) +{ +	if (port->mapbase == 0xA4400000) { +		__raw_writew(__raw_readw(PACR) & 0xffc0, PACR); +		__raw_writew(__raw_readw(PBCR) & 0x0fff, PBCR); +	} else if (port->mapbase == 0xA4410000) +		__raw_writew(__raw_readw(PBCR) & 0xf003, PBCR); +} + +struct plat_sci_port_ops sh7710_sci_port_ops = { +	.init_pins	= sh7710_sci_init_pins, +}; diff --git a/arch/sh/kernel/cpu/sh3/serial-sh7720.c b/arch/sh/kernel/cpu/sh3/serial-sh7720.c new file mode 100644 index 00000000000..8832c526cdf --- /dev/null +++ b/arch/sh/kernel/cpu/sh3/serial-sh7720.c @@ -0,0 +1,37 @@ +#include <linux/serial_sci.h> +#include <linux/serial_core.h> +#include <linux/io.h> +#include <cpu/serial.h> +#include <asm/gpio.h> + +static void sh7720_sci_init_pins(struct uart_port *port, unsigned int cflag) +{ +	unsigned short data; + +	if (cflag & CRTSCTS) { +		/* enable RTS/CTS */ +		if (port->mapbase == 0xa4430000) { /* SCIF0 */ +			/* Clear PTCR bit 9-2; enable all scif pins but sck */ +			data = __raw_readw(PORT_PTCR); +			__raw_writew((data & 0xfc03), PORT_PTCR); +		} else if (port->mapbase == 0xa4438000) { /* SCIF1 */ +			/* Clear PVCR bit 9-2 */ +			data = __raw_readw(PORT_PVCR); +			__raw_writew((data & 0xfc03), PORT_PVCR); +		} +	} else { +		if (port->mapbase == 0xa4430000) { /* SCIF0 */ +			/* Clear PTCR bit 5-2; enable only tx and rx  */ +			data = __raw_readw(PORT_PTCR); +			__raw_writew((data & 0xffc3), PORT_PTCR); +		} else if (port->mapbase == 0xa4438000) { /* SCIF1 */ +			/* Clear PVCR bit 5-2 */ +			data = __raw_readw(PORT_PVCR); +			__raw_writew((data & 0xffc3), PORT_PVCR); +		} +	} +} + +struct plat_sci_port_ops sh7720_sci_port_ops = { +	.init_pins	= sh7720_sci_init_pins, +}; diff --git a/arch/sh/kernel/cpu/sh3/setup-sh7705.c b/arch/sh/kernel/cpu/sh3/setup-sh7705.c index cd2e702feb7..2309618c015 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh7705.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh7705.c @@ -15,6 +15,7 @@  #include <linux/serial_sci.h>  #include <linux/sh_timer.h>  #include <asm/rtc.h> +#include <cpu/serial.h>  enum {  	UNUSED = 0, @@ -75,6 +76,8 @@ static struct plat_sci_port scif0_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_4,  	.type		= PORT_SCIF,  	.irqs		= { 56, 56, 56 }, +	.ops		= &sh770x_sci_port_ops, +	.regtype	= SCIx_SH7705_SCIF_REGTYPE,  };  static struct platform_device scif0_device = { @@ -92,6 +95,8 @@ static struct plat_sci_port scif1_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_4,  	.type		= PORT_SCIF,  	.irqs		= { 52, 52, 52 }, +	.ops		= &sh770x_sci_port_ops, +	.regtype	= SCIx_SH7705_SCIF_REGTYPE,  };  static struct platform_device scif1_device = { diff --git a/arch/sh/kernel/cpu/sh3/setup-sh770x.c b/arch/sh/kernel/cpu/sh3/setup-sh770x.c index 4551ad647c2..3f3d5fe5892 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh770x.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh770x.c @@ -19,6 +19,7 @@  #include <linux/serial.h>  #include <linux/serial_sci.h>  #include <linux/sh_timer.h> +#include <cpu/serial.h>  enum {  	UNUSED = 0, @@ -108,11 +109,14 @@ static struct platform_device rtc_device = {  static struct plat_sci_port scif0_platform_data = {  	.mapbase	= 0xfffffe80, +	.port_reg	= 0xa4000136,  	.flags		= UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_TE | SCSCR_RE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCI,  	.irqs		= { 23, 23, 23, 0 }, +	.ops		= &sh770x_sci_port_ops, +	.regshift	= 1,  };  static struct platform_device scif0_device = { @@ -132,6 +136,8 @@ static struct plat_sci_port scif1_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCIF,  	.irqs		= { 56, 56, 56, 56 }, +	.ops		= &sh770x_sci_port_ops, +	.regtype	= SCIx_SH3_SCIF_REGTYPE,  };  static struct platform_device scif1_device = { @@ -146,11 +152,14 @@ static struct platform_device scif1_device = {      defined(CONFIG_CPU_SUBTYPE_SH7709)  static struct plat_sci_port scif2_platform_data = {  	.mapbase	= 0xa4000140, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags		= UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_TE | SCSCR_RE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_IRDA,  	.irqs		= { 52, 52, 52, 52 }, +	.ops		= &sh770x_sci_port_ops, +	.regshift	= 1,  };  static struct platform_device scif2_device = { diff --git a/arch/sh/kernel/cpu/sh3/setup-sh7720.c b/arch/sh/kernel/cpu/sh3/setup-sh7720.c index 365b94a6fcb..94920345c14 100644 --- a/arch/sh/kernel/cpu/sh3/setup-sh7720.c +++ b/arch/sh/kernel/cpu/sh3/setup-sh7720.c @@ -20,6 +20,7 @@  #include <linux/serial_sci.h>  #include <linux/sh_timer.h>  #include <asm/rtc.h> +#include <cpu/serial.h>  static struct resource rtc_resources[] = {  	[0] = { @@ -55,6 +56,8 @@ static struct plat_sci_port scif0_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_4,  	.type		= PORT_SCIF,  	.irqs		= { 80, 80, 80, 80 }, +	.ops		= &sh7720_sci_port_ops, +	.regtype	= SCIx_SH7705_SCIF_REGTYPE,  };  static struct platform_device scif0_device = { @@ -72,6 +75,8 @@ static struct plat_sci_port scif1_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_4,  	.type		= PORT_SCIF,  	.irqs           = { 81, 81, 81, 81 }, +	.ops		= &sh7720_sci_port_ops, +	.regtype	= SCIx_SH7705_SCIF_REGTYPE,  };  static struct platform_device scif1_device = { diff --git a/arch/sh/kernel/cpu/sh4/clock-sh4-202.c b/arch/sh/kernel/cpu/sh4/clock-sh4-202.c index 3f6f8e98635..f4e262adb39 100644 --- a/arch/sh/kernel/cpu/sh4/clock-sh4-202.c +++ b/arch/sh/kernel/cpu/sh4/clock-sh4-202.c @@ -147,8 +147,6 @@ static struct clk *sh4202_onchip_clocks[] = {  	&sh4202_shoc_clk,  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("emi_clk", &sh4202_emi_clk), diff --git a/arch/sh/kernel/cpu/sh4/setup-sh7750.c b/arch/sh/kernel/cpu/sh4/setup-sh7750.c index e53b4b38bd1..98cc0c794c7 100644 --- a/arch/sh/kernel/cpu/sh4/setup-sh7750.c +++ b/arch/sh/kernel/cpu/sh4/setup-sh7750.c @@ -1,5 +1,5 @@  /* - * SH7750/SH7751 Setup + * SH7091/SH7750/SH7750S/SH7750R/SH7751/SH7751R Setup   *   *  Copyright (C) 2006  Paul Mundt   *  Copyright (C) 2006  Jamie Lenehan @@ -38,11 +38,13 @@ static struct platform_device rtc_device = {  static struct plat_sci_port sci_platform_data = {  	.mapbase	= 0xffe00000, +	.port_reg	= 0xffe0001C,  	.flags		= UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_TE | SCSCR_RE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCI,  	.irqs		= { 23, 23, 23, 0 }, +	.regshift	= 2,  };  static struct platform_device sci_device = { diff --git a/arch/sh/kernel/cpu/sh4/setup-sh7760.c b/arch/sh/kernel/cpu/sh4/setup-sh7760.c index 78bbf232e39..c0b4c774700 100644 --- a/arch/sh/kernel/cpu/sh4/setup-sh7760.c +++ b/arch/sh/kernel/cpu/sh4/setup-sh7760.c @@ -133,6 +133,7 @@ static struct plat_sci_port scif0_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCIF,  	.irqs		= { 52, 53, 55, 54 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif0_device = { @@ -150,6 +151,7 @@ static struct plat_sci_port scif1_platform_data = {  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.irqs		= { 72, 73, 75, 74 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif1_device = { @@ -167,6 +169,7 @@ static struct plat_sci_port scif2_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCIF,  	.irqs		= { 76, 77, 79, 78 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif2_device = { @@ -184,6 +187,7 @@ static struct plat_sci_port scif3_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCI,  	.irqs		= { 80, 81, 82, 0 }, +	.regshift	= 2,  };  static struct platform_device scif3_device = { diff --git a/arch/sh/kernel/cpu/sh4a/Makefile b/arch/sh/kernel/cpu/sh4a/Makefile index cc122b1d303..c57fb287011 100644 --- a/arch/sh/kernel/cpu/sh4a/Makefile +++ b/arch/sh/kernel/cpu/sh4a/Makefile @@ -10,7 +10,7 @@ obj-$(CONFIG_CPU_SUBTYPE_SH7780)	+= setup-sh7780.o  obj-$(CONFIG_CPU_SUBTYPE_SH7785)	+= setup-sh7785.o  obj-$(CONFIG_CPU_SUBTYPE_SH7786)	+= setup-sh7786.o intc-shx3.o  obj-$(CONFIG_CPU_SUBTYPE_SH7343)	+= setup-sh7343.o -obj-$(CONFIG_CPU_SUBTYPE_SH7722)	+= setup-sh7722.o +obj-$(CONFIG_CPU_SUBTYPE_SH7722)	+= setup-sh7722.o serial-sh7722.o  obj-$(CONFIG_CPU_SUBTYPE_SH7723)	+= setup-sh7723.o  obj-$(CONFIG_CPU_SUBTYPE_SH7724)	+= setup-sh7724.o  obj-$(CONFIG_CPU_SUBTYPE_SH7366)	+= setup-sh7366.o diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7343.c b/arch/sh/kernel/cpu/sh4a/clock-sh7343.c index 93c646072c1..70e45bdaadc 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7343.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7343.c @@ -194,8 +194,6 @@ static struct clk mstp_clks[MSTP_NR] = {  	[MSTP200] = MSTP(&div4_clks[DIV4_B], MSTPCR2, 0, 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("rclk", &r_clk), @@ -233,32 +231,17 @@ static struct clk_lookup lookups[] = {  	CLKDEV_CON_ID("rwdt0", &mstp_clks[MSTP013]),  	CLKDEV_CON_ID("mfi0", &mstp_clks[MSTP011]),  	CLKDEV_CON_ID("flctl0", &mstp_clks[MSTP010]), -	{ -		/* SCIF0 */ -		.dev_id		= "sh-sci.0", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP007], -	}, { -		/* SCIF1 */ -		.dev_id		= "sh-sci.1", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP006], -	}, { -		/* SCIF2 */ -		.dev_id		= "sh-sci.2", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP005], -	}, { -		/* SCIF3 */ -		.dev_id		= "sh-sci.3", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP004], -	}, + +	CLKDEV_ICK_ID("sci_fck", "sh-sci.0", &mstp_clks[MSTP007]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.1", &mstp_clks[MSTP006]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.2", &mstp_clks[MSTP005]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.3", &mstp_clks[MSTP004]), +  	CLKDEV_CON_ID("sio0", &mstp_clks[MSTP003]),  	CLKDEV_CON_ID("siof0", &mstp_clks[MSTP002]),  	CLKDEV_CON_ID("siof1", &mstp_clks[MSTP001]), -	CLKDEV_CON_ID("i2c0", &mstp_clks[MSTP109]), -	CLKDEV_CON_ID("i2c1", &mstp_clks[MSTP108]), +	CLKDEV_DEV_ID("i2c-sh_mobile.0", &mstp_clks[MSTP109]), +	CLKDEV_DEV_ID("i2c-sh_mobile.1", &mstp_clks[MSTP108]),  	CLKDEV_CON_ID("tpu0", &mstp_clks[MSTP225]),  	CLKDEV_CON_ID("irda0", &mstp_clks[MSTP224]),  	CLKDEV_CON_ID("sdhi0", &mstp_clks[MSTP218]), diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7366.c b/arch/sh/kernel/cpu/sh4a/clock-sh7366.c index 049dc0628cc..3c3165000c5 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7366.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7366.c @@ -192,8 +192,6 @@ static struct clk mstp_clks[MSTP_NR] = {  	[MSTP200] = MSTP(&div4_clks[DIV4_B], MSTPCR2, 0, 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("rclk", &r_clk), @@ -231,25 +229,14 @@ static struct clk_lookup lookups[] = {  	CLKDEV_CON_ID("rwdt0", &mstp_clks[MSTP013]),  	CLKDEV_CON_ID("mfi0", &mstp_clks[MSTP011]),  	CLKDEV_CON_ID("flctl0", &mstp_clks[MSTP010]), -	{ -		/* SCIF0 */ -		.dev_id		= "sh-sci.0", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP007], -	}, { -		/* SCIF1 */ -		.dev_id		= "sh-sci.1", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP006], -	}, { -		/* SCIF2 */ -		.dev_id		= "sh-sci.2", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP005], -	}, + +	CLKDEV_ICK_ID("sci_fck", "sh-sci.0", &mstp_clks[MSTP007]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.1", &mstp_clks[MSTP006]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.2", &mstp_clks[MSTP005]), +  	CLKDEV_CON_ID("msiof0", &mstp_clks[MSTP002]),  	CLKDEV_CON_ID("sbr0", &mstp_clks[MSTP001]), -	CLKDEV_CON_ID("i2c0", &mstp_clks[MSTP109]), +	CLKDEV_DEV_ID("i2c-sh_mobile.0", &mstp_clks[MSTP109]),  	CLKDEV_CON_ID("icb0", &mstp_clks[MSTP227]),  	CLKDEV_CON_ID("meram0", &mstp_clks[MSTP226]),  	CLKDEV_CON_ID("dacy1", &mstp_clks[MSTP224]), diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7722.c b/arch/sh/kernel/cpu/sh4a/clock-sh7722.c index 9d23a36f064..c9a48088ad4 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7722.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7722.c @@ -175,8 +175,6 @@ static struct clk mstp_clks[HWBLK_NR] = {  	SH_HWBLK_CLK(HWBLK_LCDC, &div4_clks[DIV4_P], 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("rclk", &r_clk), @@ -201,42 +199,20 @@ static struct clk_lookup lookups[] = {  	/* MSTP clocks */  	CLKDEV_CON_ID("uram0", &mstp_clks[HWBLK_URAM]),  	CLKDEV_CON_ID("xymem0", &mstp_clks[HWBLK_XYMEM]), -	{ -		/* TMU0 */ -		.dev_id		= "sh_tmu.0", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU], -	}, { -		/* TMU1 */ -		.dev_id		= "sh_tmu.1", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU], -	}, { -		/* TMU2 */ -		.dev_id		= "sh_tmu.2", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU], -	}, + +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.0", &mstp_clks[HWBLK_TMU]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.1", &mstp_clks[HWBLK_TMU]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.2", &mstp_clks[HWBLK_TMU]), +  	CLKDEV_CON_ID("cmt_fck", &mstp_clks[HWBLK_CMT]),  	CLKDEV_CON_ID("rwdt0", &mstp_clks[HWBLK_RWDT]),  	CLKDEV_CON_ID("flctl0", &mstp_clks[HWBLK_FLCTL]), -	{ -		/* SCIF0 */ -		.dev_id		= "sh-sci.0", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF0], -	}, { -		/* SCIF1 */ -		.dev_id		= "sh-sci.1", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF1], -	}, { -		/* SCIF2 */ -		.dev_id		= "sh-sci.2", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF2], -	}, -	CLKDEV_CON_ID("i2c0", &mstp_clks[HWBLK_IIC]), + +	CLKDEV_ICK_ID("sci_fck", "sh-sci.0", &mstp_clks[HWBLK_SCIF0]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.1", &mstp_clks[HWBLK_SCIF1]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.2", &mstp_clks[HWBLK_SCIF2]), + +	CLKDEV_DEV_ID("i2c-sh_mobile.0", &mstp_clks[HWBLK_IIC]),  	CLKDEV_CON_ID("rtc0", &mstp_clks[HWBLK_RTC]),  	CLKDEV_CON_ID("sdhi0", &mstp_clks[HWBLK_SDHI]),  	CLKDEV_CON_ID("keysc0", &mstp_clks[HWBLK_KEYSC]), diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7723.c b/arch/sh/kernel/cpu/sh4a/clock-sh7723.c index 55493cd5bd8..3cc3827380e 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7723.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7723.c @@ -200,8 +200,6 @@ static struct clk mstp_clks[] = {  	SH_HWBLK_CLK(HWBLK_LCDC, &div4_clks[DIV4_B], 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("rclk", &r_clk), @@ -305,7 +303,7 @@ static struct clk_lookup lookups[] = {  	CLKDEV_CON_ID("msiof0", &mstp_clks[HWBLK_MSIOF0]),  	CLKDEV_CON_ID("msiof1", &mstp_clks[HWBLK_MSIOF1]),  	CLKDEV_CON_ID("meram0", &mstp_clks[HWBLK_MERAM]), -	CLKDEV_CON_ID("i2c0", &mstp_clks[HWBLK_IIC]), +	CLKDEV_DEV_ID("i2c-sh_mobile.0", &mstp_clks[HWBLK_IIC]),  	CLKDEV_CON_ID("rtc0", &mstp_clks[HWBLK_RTC]),  	CLKDEV_CON_ID("atapi0", &mstp_clks[HWBLK_ATAPI]),  	CLKDEV_CON_ID("adc0", &mstp_clks[HWBLK_ADC]), diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7724.c b/arch/sh/kernel/cpu/sh4a/clock-sh7724.c index d08fa953c88..8668f557e0a 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7724.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7724.c @@ -252,8 +252,6 @@ static struct clk mstp_clks[HWBLK_NR] = {  	SH_HWBLK_CLK(HWBLK_LCDC, &div4_clks[DIV4_B], 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("rclk", &r_clk), @@ -289,77 +287,31 @@ static struct clk_lookup lookups[] = {  	CLKDEV_CON_ID("sh0", &mstp_clks[HWBLK_SHYWAY]),  	CLKDEV_CON_ID("hudi0", &mstp_clks[HWBLK_HUDI]),  	CLKDEV_CON_ID("ubc0", &mstp_clks[HWBLK_UBC]), -	{ -		/* TMU0 */ -		.dev_id		= "sh_tmu.0", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU0], -	}, { -		/* TMU1 */ -		.dev_id		= "sh_tmu.1", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU0], -	}, { -		/* TMU2 */ -		.dev_id		= "sh_tmu.2", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU0], -	}, { -		/* TMU3 */ -		.dev_id		= "sh_tmu.3", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU1], -	}, + +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.0", &mstp_clks[HWBLK_TMU0]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.1", &mstp_clks[HWBLK_TMU0]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.2", &mstp_clks[HWBLK_TMU0]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.3", &mstp_clks[HWBLK_TMU1]), +  	CLKDEV_CON_ID("cmt_fck", &mstp_clks[HWBLK_CMT]),  	CLKDEV_CON_ID("rwdt0", &mstp_clks[HWBLK_RWDT]),  	CLKDEV_CON_ID("dmac1", &mstp_clks[HWBLK_DMAC1]), -	{ -		/* TMU4 */ -		.dev_id		= "sh_tmu.4", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU1], -	}, { -		/* TMU5 */ -		.dev_id		= "sh_tmu.5", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[HWBLK_TMU1], -	}, { -		/* SCIF0 */ -		.dev_id		= "sh-sci.0", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF0], -	}, { -		/* SCIF1 */ -		.dev_id		= "sh-sci.1", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF1], -	}, { -		/* SCIF2 */ -		.dev_id		= "sh-sci.2", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF2], -	}, { -		/* SCIF3 */ -		.dev_id		= "sh-sci.3", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF3], -	}, { -		/* SCIF4 */ -		.dev_id		= "sh-sci.4", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF4], -	}, { -		/* SCIF5 */ -		.dev_id		= "sh-sci.5", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[HWBLK_SCIF5], -	}, + +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.4", &mstp_clks[HWBLK_TMU1]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.5", &mstp_clks[HWBLK_TMU1]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.0", &mstp_clks[HWBLK_SCIF0]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.1", &mstp_clks[HWBLK_SCIF1]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.2", &mstp_clks[HWBLK_SCIF2]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.3", &mstp_clks[HWBLK_SCIF3]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.4", &mstp_clks[HWBLK_SCIF4]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.5", &mstp_clks[HWBLK_SCIF5]), +  	CLKDEV_CON_ID("msiof0", &mstp_clks[HWBLK_MSIOF0]),  	CLKDEV_CON_ID("msiof1", &mstp_clks[HWBLK_MSIOF1]),  	CLKDEV_CON_ID("keysc0", &mstp_clks[HWBLK_KEYSC]),  	CLKDEV_CON_ID("rtc0", &mstp_clks[HWBLK_RTC]), -	CLKDEV_CON_ID("i2c0", &mstp_clks[HWBLK_IIC0]), -	CLKDEV_CON_ID("i2c1", &mstp_clks[HWBLK_IIC1]), +	CLKDEV_DEV_ID("i2c-sh_mobile.0", &mstp_clks[HWBLK_IIC0]), +	CLKDEV_DEV_ID("i2c-sh_mobile.1", &mstp_clks[HWBLK_IIC1]),  	CLKDEV_CON_ID("mmc0", &mstp_clks[HWBLK_MMC]),  	CLKDEV_CON_ID("eth0", &mstp_clks[HWBLK_ETHER]),  	CLKDEV_CON_ID("atapi0", &mstp_clks[HWBLK_ATAPI]), diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7757.c b/arch/sh/kernel/cpu/sh4a/clock-sh7757.c index eedddad1383..3b097b09a3b 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7757.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7757.c @@ -101,8 +101,6 @@ static struct clk mstp_clks[MSTP_NR] = {  	[MSTP220] = SH_CLK_MSTP32(&div4_clks[DIV4_P], MSTPCR2, 20, 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("extal", &extal_clk), @@ -116,33 +114,13 @@ static struct clk_lookup lookups[] = {  	/* MSTP32 clocks */  	CLKDEV_CON_ID("sdhi0", &mstp_clks[MSTP004]),  	CLKDEV_CON_ID("riic", &mstp_clks[MSTP000]), -	{ -		/* TMU0 */ -		.dev_id		= "sh_tmu.0", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP113], -	}, { -		/* TMU1 */ -		.dev_id		= "sh_tmu.1", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP114], -	}, -	{ -		/* SCIF4 (But, ID is 2) */ -		.dev_id		= "sh-sci.2", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP112], -	}, { -		/* SCIF3 */ -		.dev_id		= "sh-sci.1", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP111], -	}, { -		/* SCIF2 */ -		.dev_id		= "sh-sci.0", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP110], -	}, + +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.0", &mstp_clks[MSTP113]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.1", &mstp_clks[MSTP114]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.2", &mstp_clks[MSTP112]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.1", &mstp_clks[MSTP111]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.0", &mstp_clks[MSTP110]), +  	CLKDEV_CON_ID("usb0", &mstp_clks[MSTP102]),  	CLKDEV_CON_ID("mmc0", &mstp_clks[MSTP220]),  }; diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7763.c b/arch/sh/kernel/cpu/sh4a/clock-sh7763.c index 599630fc4d3..2d4c7fd79c0 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7763.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7763.c @@ -91,8 +91,6 @@ static struct clk *sh7763_onchip_clocks[] = {  	&sh7763_shyway_clk,  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("shyway_clk", &sh7763_shyway_clk), diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7780.c b/arch/sh/kernel/cpu/sh4a/clock-sh7780.c index 8894926479a..3b53348fe2f 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7780.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7780.c @@ -97,8 +97,6 @@ static struct clk *sh7780_onchip_clocks[] = {  	&sh7780_shyway_clk,  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("shyway_clk", &sh7780_shyway_clk), diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7785.c b/arch/sh/kernel/cpu/sh4a/clock-sh7785.c index 2d960247f3e..e5b420cc126 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7785.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7785.c @@ -116,8 +116,6 @@ static struct clk mstp_clks[MSTP_NR] = {  	[MSTP100] = SH_CLK_MSTP32(NULL, MSTPCR1, 0, 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("extal", &extal_clk), @@ -134,74 +132,27 @@ static struct clk_lookup lookups[] = {  	CLKDEV_CON_ID("cpu_clk", &div4_clks[DIV4_I]),  	/* MSTP32 clocks */ -	{ -		/* SCIF5 */ -		.dev_id		= "sh-sci.5", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP029], -	}, { -		/* SCIF4 */ -		.dev_id		= "sh-sci.4", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP028], -	}, { -		/* SCIF3 */ -		.dev_id		= "sh-sci.3", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP027], -	}, { -		/* SCIF2 */ -		.dev_id		= "sh-sci.2", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP026], -	}, { -		/* SCIF1 */ -		.dev_id		= "sh-sci.1", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP025], -	}, { -		/* SCIF0 */ -		.dev_id		= "sh-sci.0", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP024], -	}, +	CLKDEV_ICK_ID("sci_fck", "sh-sci.5", &mstp_clks[MSTP029]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.4", &mstp_clks[MSTP028]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.3", &mstp_clks[MSTP027]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.2", &mstp_clks[MSTP026]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.1", &mstp_clks[MSTP025]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.0", &mstp_clks[MSTP024]), +  	CLKDEV_CON_ID("ssi1_fck", &mstp_clks[MSTP021]),  	CLKDEV_CON_ID("ssi0_fck", &mstp_clks[MSTP020]),  	CLKDEV_CON_ID("hac1_fck", &mstp_clks[MSTP017]),  	CLKDEV_CON_ID("hac0_fck", &mstp_clks[MSTP016]),  	CLKDEV_CON_ID("mmcif_fck", &mstp_clks[MSTP013]),  	CLKDEV_CON_ID("flctl_fck", &mstp_clks[MSTP012]), -	{ -		/* TMU0 */ -		.dev_id		= "sh_tmu.0", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU1 */ -		.dev_id		= "sh_tmu.1", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU2 */ -		.dev_id		= "sh_tmu.2", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU3 */ -		.dev_id		= "sh_tmu.3", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, { -		/* TMU4 */ -		.dev_id		= "sh_tmu.4", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, { -		/* TMU5 */ -		.dev_id		= "sh_tmu.5", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, + +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.0", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.1", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.2", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.3", &mstp_clks[MSTP009]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.4", &mstp_clks[MSTP009]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.5", &mstp_clks[MSTP009]), +  	CLKDEV_CON_ID("siof_fck", &mstp_clks[MSTP003]),  	CLKDEV_CON_ID("hspi_fck", &mstp_clks[MSTP002]),  	CLKDEV_CON_ID("hudi_fck", &mstp_clks[MSTP119]), diff --git a/arch/sh/kernel/cpu/sh4a/clock-sh7786.c b/arch/sh/kernel/cpu/sh4a/clock-sh7786.c index 42e403be907..f6c0c3d5599 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-sh7786.c +++ b/arch/sh/kernel/cpu/sh4a/clock-sh7786.c @@ -125,8 +125,6 @@ static struct clk mstp_clks[MSTP_NR] = {  	[MSTP102] = SH_CLK_MSTP32(NULL, MSTPCR1, 2, 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("extal", &extal_clk), @@ -141,37 +139,13 @@ static struct clk_lookup lookups[] = {  	CLKDEV_CON_ID("cpu_clk", &div4_clks[DIV4_I]),  	/* MSTP32 clocks */ -	{ -		/* SCIF5 */ -		.dev_id		= "sh-sci.5", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP029], -	}, { -		/* SCIF4 */ -		.dev_id		= "sh-sci.4", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP028], -	}, { -		/* SCIF3 */ -		.dev_id		= "sh-sci.3", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP027], -	}, { -		/* SCIF2 */ -		.dev_id		= "sh-sci.2", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP026], -	}, { -		/* SCIF1 */ -		.dev_id		= "sh-sci.1", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP025], -	}, { -		/* SCIF0 */ -		.dev_id		= "sh-sci.0", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP024], -	}, +	CLKDEV_ICK_ID("sci_fck", "sh-sci.5", &mstp_clks[MSTP029]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.4", &mstp_clks[MSTP028]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.3", &mstp_clks[MSTP027]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.2", &mstp_clks[MSTP026]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.1", &mstp_clks[MSTP025]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.0", &mstp_clks[MSTP024]), +  	CLKDEV_CON_ID("ssi3_fck", &mstp_clks[MSTP023]),  	CLKDEV_CON_ID("ssi2_fck", &mstp_clks[MSTP022]),  	CLKDEV_CON_ID("ssi1_fck", &mstp_clks[MSTP021]), @@ -180,67 +154,20 @@ static struct clk_lookup lookups[] = {  	CLKDEV_CON_ID("hac0_fck", &mstp_clks[MSTP016]),  	CLKDEV_CON_ID("i2c1_fck", &mstp_clks[MSTP015]),  	CLKDEV_CON_ID("i2c0_fck", &mstp_clks[MSTP014]), -	{ -		/* TMU0 */ -		.dev_id		= "sh_tmu.0", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU1 */ -		.dev_id		= "sh_tmu.1", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU2 */ -		.dev_id		= "sh_tmu.2", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU3 */ -		.dev_id		= "sh_tmu.3", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, { -		/* TMU4 */ -		.dev_id		= "sh_tmu.4", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, { -		/* TMU5 */ -		.dev_id		= "sh_tmu.5", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, { -		/* TMU6 */ -		.dev_id		= "sh_tmu.6", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP010], -	}, { -		/* TMU7 */ -		.dev_id		= "sh_tmu.7", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP010], -	}, { -		/* TMU8 */ -		.dev_id		= "sh_tmu.8", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP010], -	}, { -		/* TMU9 */ -		.dev_id		= "sh_tmu.9", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP011], -	}, { -		/* TMU10 */ -		.dev_id		= "sh_tmu.10", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP011], -	}, { -		/* TMU11 */ -		.dev_id		= "sh_tmu.11", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP011], -	}, + +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.0", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.1", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.2", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.3", &mstp_clks[MSTP009]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.4", &mstp_clks[MSTP009]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.5", &mstp_clks[MSTP009]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.6", &mstp_clks[MSTP010]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.7", &mstp_clks[MSTP010]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.8", &mstp_clks[MSTP010]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.9", &mstp_clks[MSTP011]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.10", &mstp_clks[MSTP011]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.11", &mstp_clks[MSTP011]), +  	CLKDEV_CON_ID("sdif1_fck", &mstp_clks[MSTP005]),  	CLKDEV_CON_ID("sdif0_fck", &mstp_clks[MSTP004]),  	CLKDEV_CON_ID("hspi_fck", &mstp_clks[MSTP002]), diff --git a/arch/sh/kernel/cpu/sh4a/clock-shx3.c b/arch/sh/kernel/cpu/sh4a/clock-shx3.c index 1afdb93b8cc..bf2d00b8b90 100644 --- a/arch/sh/kernel/cpu/sh4a/clock-shx3.c +++ b/arch/sh/kernel/cpu/sh4a/clock-shx3.c @@ -100,8 +100,6 @@ static struct clk mstp_clks[MSTP_NR] = {  	[MSTP104] = SH_CLK_MSTP32(NULL, MSTPCR1, 4, 0),  }; -#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk } -  static struct clk_lookup lookups[] = {  	/* main clocks */  	CLKDEV_CON_ID("extal", &extal_clk), @@ -116,62 +114,23 @@ static struct clk_lookup lookups[] = {  	CLKDEV_CON_ID("cpu_clk", &div4_clks[DIV4_I]),  	/* MSTP32 clocks */ -	{ -		/* SCIF3 */ -		.dev_id		= "sh-sci.3", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP027], -	}, { -		/* SCIF2 */ -		.dev_id		= "sh-sci.2", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP026], -	}, { -		/* SCIF1 */ -		.dev_id		= "sh-sci.1", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP025], -	}, { -		/* SCIF0 */ -		.dev_id		= "sh-sci.0", -		.con_id		= "sci_fck", -		.clk		= &mstp_clks[MSTP024], -	}, +	CLKDEV_ICK_ID("sci_fck", "sh-sci.3", &mstp_clks[MSTP027]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.2", &mstp_clks[MSTP026]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.1", &mstp_clks[MSTP025]), +	CLKDEV_ICK_ID("sci_fck", "sh-sci.0", &mstp_clks[MSTP024]), +  	CLKDEV_CON_ID("h8ex_fck", &mstp_clks[MSTP003]),  	CLKDEV_CON_ID("csm_fck", &mstp_clks[MSTP002]),  	CLKDEV_CON_ID("fe1_fck", &mstp_clks[MSTP001]),  	CLKDEV_CON_ID("fe0_fck", &mstp_clks[MSTP000]), -	{ -		/* TMU0 */ -		.dev_id		= "sh_tmu.0", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU1 */ -		.dev_id		= "sh_tmu.1", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU2 */ -		.dev_id		= "sh_tmu.2", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP008], -	}, { -		/* TMU3 */ -		.dev_id		= "sh_tmu.3", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, { -		/* TMU4 */ -		.dev_id		= "sh_tmu.4", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, { -		/* TMU5 */ -		.dev_id		= "sh_tmu.5", -		.con_id		= "tmu_fck", -		.clk		= &mstp_clks[MSTP009], -	}, + +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.0", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.1", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.2", &mstp_clks[MSTP008]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.3", &mstp_clks[MSTP009]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.4", &mstp_clks[MSTP009]), +	CLKDEV_ICK_ID("tmu_fck", "sh_tmu.5", &mstp_clks[MSTP009]), +  	CLKDEV_CON_ID("hudi_fck", &mstp_clks[MSTP119]),  	CLKDEV_CON_ID("dmac_11_6_fck", &mstp_clks[MSTP105]),  	CLKDEV_CON_ID("dmac_5_0_fck", &mstp_clks[MSTP104]), diff --git a/arch/sh/kernel/cpu/sh4a/serial-sh7722.c b/arch/sh/kernel/cpu/sh4a/serial-sh7722.c new file mode 100644 index 00000000000..59bc3a72702 --- /dev/null +++ b/arch/sh/kernel/cpu/sh4a/serial-sh7722.c @@ -0,0 +1,23 @@ +#include <linux/serial_sci.h> +#include <linux/serial_core.h> +#include <linux/io.h> + +#define PSCR 0xA405011E + +static void sh7722_sci_init_pins(struct uart_port *port, unsigned int cflag) +{ +	unsigned short data; + +	if (port->mapbase == 0xffe00000) { +		data = __raw_readw(PSCR); +		data &= ~0x03cf; +		if (!(cflag & CRTSCTS)) +			data |= 0x0340; + +		__raw_writew(data, PSCR); +	} +} + +struct plat_sci_port_ops sh7722_sci_port_ops = { +	.init_pins	= sh7722_sci_init_pins, +}; diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7366.c b/arch/sh/kernel/cpu/sh4a/setup-sh7366.c index 82616af64d6..87773869a2f 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7366.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7366.c @@ -20,6 +20,7 @@  static struct plat_sci_port scif0_platform_data = {  	.mapbase	= 0xffe00000, +	.port_reg	= 0xa405013e,  	.flags		= UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_2, diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7722.c b/arch/sh/kernel/cpu/sh4a/setup-sh7722.c index 5813d802361..278a0e57215 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7722.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7722.c @@ -22,6 +22,7 @@  #include <cpu/dma-register.h>  #include <cpu/sh7722.h> +#include <cpu/serial.h>  static const struct sh_dmae_slave_config sh7722_dmae_slaves[] = {  	{ @@ -185,6 +186,8 @@ static struct plat_sci_port scif0_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 80, 80, 80, 80 }, +	.ops		= &sh7722_sci_port_ops, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif0_device = { @@ -202,6 +205,8 @@ static struct plat_sci_port scif1_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 81, 81, 81, 81 }, +	.ops		= &sh7722_sci_port_ops, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif1_device = { @@ -219,6 +224,8 @@ static struct plat_sci_port scif2_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 82, 82, 82, 82 }, +	.ops		= &sh7722_sci_port_ops, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif2_device = { diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7723.c b/arch/sh/kernel/cpu/sh4a/setup-sh7723.c index 072382280f9..3c2810d8f72 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7723.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7723.c @@ -23,11 +23,13 @@  /* Serial */  static struct plat_sci_port scif0_platform_data = {  	.mapbase        = 0xffe00000, +	.port_reg	= 0xa4050160,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 80, 80, 80, 80 }, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif0_device = { @@ -40,11 +42,13 @@ static struct platform_device scif0_device = {  static struct plat_sci_port scif1_platform_data = {  	.mapbase        = 0xffe10000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 81, 81, 81, 81 }, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif1_device = { @@ -57,11 +61,13 @@ static struct platform_device scif1_device = {  static struct plat_sci_port scif2_platform_data = {  	.mapbase        = 0xffe20000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 82, 82, 82, 82 }, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif2_device = { @@ -75,6 +81,7 @@ static struct platform_device scif2_device = {  static struct plat_sci_port scif3_platform_data = {  	.mapbase        = 0xa4e30000,  	.flags          = UPF_BOOT_AUTOCONF, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_3,  	.type           = PORT_SCIFA, @@ -91,6 +98,7 @@ static struct platform_device scif3_device = {  static struct plat_sci_port scif4_platform_data = {  	.mapbase        = 0xa4e40000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_3, @@ -108,6 +116,7 @@ static struct platform_device scif4_device = {  static struct plat_sci_port scif5_platform_data = {  	.mapbase        = 0xa4e50000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_3, diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7724.c b/arch/sh/kernel/cpu/sh4a/setup-sh7724.c index 134a397b191..a37dd72c367 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7724.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7724.c @@ -296,11 +296,13 @@ static struct platform_device dma1_device = {  /* Serial */  static struct plat_sci_port scif0_platform_data = {  	.mapbase        = 0xffe00000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 80, 80, 80, 80 }, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif0_device = { @@ -313,11 +315,13 @@ static struct platform_device scif0_device = {  static struct plat_sci_port scif1_platform_data = {  	.mapbase        = 0xffe10000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 81, 81, 81, 81 }, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif1_device = { @@ -330,11 +334,13 @@ static struct platform_device scif1_device = {  static struct plat_sci_port scif2_platform_data = {  	.mapbase        = 0xffe20000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE | SCSCR_REIE,  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type           = PORT_SCIF,  	.irqs           = { 82, 82, 82, 82 }, +	.regtype	= SCIx_SH4_SCIF_NO_SCSPTR_REGTYPE,  };  static struct platform_device scif2_device = { @@ -347,6 +353,7 @@ static struct platform_device scif2_device = {  static struct plat_sci_port scif3_platform_data = {  	.mapbase        = 0xa4e30000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE,  	.scbrr_algo_id	= SCBRR_ALGO_3, @@ -364,6 +371,7 @@ static struct platform_device scif3_device = {  static struct plat_sci_port scif4_platform_data = {  	.mapbase        = 0xa4e40000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE,  	.scbrr_algo_id	= SCBRR_ALGO_3, @@ -381,6 +389,7 @@ static struct platform_device scif4_device = {  static struct plat_sci_port scif5_platform_data = {  	.mapbase        = 0xa4e50000, +	.port_reg	= SCIx_NOT_SUPPORTED,  	.flags          = UPF_BOOT_AUTOCONF,  	.scscr		= SCSCR_RE | SCSCR_TE,  	.scbrr_algo_id	= SCBRR_ALGO_3, diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7757.c b/arch/sh/kernel/cpu/sh4a/setup-sh7757.c index e915deafac8..05559295d2c 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7757.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7757.c @@ -15,6 +15,7 @@  #include <linux/serial_sci.h>  #include <linux/io.h>  #include <linux/mm.h> +#include <linux/dma-mapping.h>  #include <linux/sh_timer.h>  #include <linux/sh_dma.h> diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7763.c b/arch/sh/kernel/cpu/sh4a/setup-sh7763.c index 593eca6509b..00113515f23 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7763.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7763.c @@ -23,6 +23,7 @@ static struct plat_sci_port scif0_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCIF,  	.irqs		= { 40, 40, 40, 40 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif0_device = { @@ -40,6 +41,7 @@ static struct plat_sci_port scif1_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCIF,  	.irqs		= { 76, 76, 76, 76 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif1_device = { @@ -57,6 +59,7 @@ static struct plat_sci_port scif2_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_2,  	.type		= PORT_SCIF,  	.irqs		= { 104, 104, 104, 104 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif2_device = { diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7780.c b/arch/sh/kernel/cpu/sh4a/setup-sh7780.c index 08add7fa684..3d4d2075c19 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7780.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7780.c @@ -14,7 +14,6 @@  #include <linux/serial_sci.h>  #include <linux/sh_dma.h>  #include <linux/sh_timer.h> -  #include <cpu/dma-register.h>  static struct plat_sci_port scif0_platform_data = { @@ -24,6 +23,7 @@ static struct plat_sci_port scif0_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 40, 40, 40, 40 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif0_device = { @@ -41,6 +41,7 @@ static struct plat_sci_port scif1_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 76, 76, 76, 76 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif1_device = { diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7785.c b/arch/sh/kernel/cpu/sh4a/setup-sh7785.c index 18d8fc136fb..b29e6340414 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7785.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7785.c @@ -15,9 +15,7 @@  #include <linux/mm.h>  #include <linux/sh_dma.h>  #include <linux/sh_timer.h> -  #include <asm/mmzone.h> -  #include <cpu/dma-register.h>  static struct plat_sci_port scif0_platform_data = { @@ -27,6 +25,7 @@ static struct plat_sci_port scif0_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 40, 40, 40, 40 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif0_device = { @@ -44,6 +43,7 @@ static struct plat_sci_port scif1_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 44, 44, 44, 44 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif1_device = { @@ -61,6 +61,7 @@ static struct plat_sci_port scif2_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 60, 60, 60, 60 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif2_device = { @@ -78,6 +79,7 @@ static struct plat_sci_port scif3_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 61, 61, 61, 61 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif3_device = { @@ -95,6 +97,7 @@ static struct plat_sci_port scif4_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 62, 62, 62, 62 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif4_device = { @@ -112,6 +115,7 @@ static struct plat_sci_port scif5_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 63, 63, 63, 63 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif5_device = { diff --git a/arch/sh/kernel/cpu/sh4a/setup-sh7786.c b/arch/sh/kernel/cpu/sh4a/setup-sh7786.c index beba32beb6d..dd5e709f982 100644 --- a/arch/sh/kernel/cpu/sh4a/setup-sh7786.c +++ b/arch/sh/kernel/cpu/sh4a/setup-sh7786.c @@ -1,7 +1,7 @@  /*   * SH7786 Setup   * - * Copyright (C) 2009 - 2010  Renesas Solutions Corp. + * Copyright (C) 2009 - 2011  Renesas Solutions Corp.   * Kuninori Morimoto <morimoto.kuninori@renesas.com>   * Paul Mundt <paul.mundt@renesas.com>   * @@ -33,6 +33,7 @@ static struct plat_sci_port scif0_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 40, 41, 43, 42 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif0_device = { @@ -53,6 +54,7 @@ static struct plat_sci_port scif1_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 44, 44, 44, 44 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif1_device = { @@ -70,6 +72,7 @@ static struct plat_sci_port scif2_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 50, 50, 50, 50 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif2_device = { @@ -87,6 +90,7 @@ static struct plat_sci_port scif3_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 51, 51, 51, 51 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif3_device = { @@ -104,6 +108,7 @@ static struct plat_sci_port scif4_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 52, 52, 52, 52 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif4_device = { @@ -121,6 +126,7 @@ static struct plat_sci_port scif5_platform_data = {  	.scbrr_algo_id	= SCBRR_ALGO_1,  	.type		= PORT_SCIF,  	.irqs		= { 53, 53, 53, 53 }, +	.regtype	= SCIx_SH4_SCIF_FIFODATA_REGTYPE,  };  static struct platform_device scif5_device = { diff --git a/arch/sh/kernel/idle.c b/arch/sh/kernel/idle.c index 425d604e3a2..db4ecd731a0 100644 --- a/arch/sh/kernel/idle.c +++ b/arch/sh/kernel/idle.c @@ -16,12 +16,13 @@  #include <linux/thread_info.h>  #include <linux/irqflags.h>  #include <linux/smp.h> +#include <linux/cpuidle.h>  #include <asm/pgalloc.h>  #include <asm/system.h> -#include <asm/atomic.h> +#include <linux/atomic.h>  #include <asm/smp.h> -void (*pm_idle)(void) = NULL; +void (*pm_idle)(void);  static int hlt_counter; @@ -100,7 +101,8 @@ void cpu_idle(void)  			local_irq_disable();  			/* Don't trace irqs off for idle */  			stop_critical_timings(); -			pm_idle(); +			if (cpuidle_idle_call()) +				pm_idle();  			/*  			 * Sanity check to ensure that pm_idle() returns  			 * with IRQs enabled diff --git a/arch/sh/kernel/smp.c b/arch/sh/kernel/smp.c index 6207561ea34..3147a9a6fb8 100644 --- a/arch/sh/kernel/smp.c +++ b/arch/sh/kernel/smp.c @@ -21,7 +21,7 @@  #include <linux/cpu.h>  #include <linux/interrupt.h>  #include <linux/sched.h> -#include <asm/atomic.h> +#include <linux/atomic.h>  #include <asm/processor.h>  #include <asm/system.h>  #include <asm/mmu_context.h> diff --git a/arch/sh/kernel/syscalls_32.S b/arch/sh/kernel/syscalls_32.S index 39b051de4c7..293e39c59c0 100644 --- a/arch/sh/kernel/syscalls_32.S +++ b/arch/sh/kernel/syscalls_32.S @@ -185,7 +185,7 @@ ENTRY(sys_call_table)  	.long sys_ni_syscall	/* vm86 */  	.long sys_ni_syscall	/* old "query_module" */  	.long sys_poll -	.long sys_nfsservctl +	.long sys_ni_syscall	/* was nfsservctl */  	.long sys_setresgid16	/* 170 */  	.long sys_getresgid16  	.long sys_prctl diff --git a/arch/sh/kernel/syscalls_64.S b/arch/sh/kernel/syscalls_64.S index 089c4d825d0..ceb34b94afa 100644 --- a/arch/sh/kernel/syscalls_64.S +++ b/arch/sh/kernel/syscalls_64.S @@ -189,7 +189,7 @@ sys_call_table:  	.long sys_ni_syscall	/* vm86 */  	.long sys_ni_syscall	/* old "query_module" */  	.long sys_poll -	.long sys_nfsservctl +	.long sys_ni_syscall	/* was nfsservctl */  	.long sys_setresgid16		/* 170 */  	.long sys_getresgid16  	.long sys_prctl diff --git a/arch/sh/kernel/traps_32.c b/arch/sh/kernel/traps_32.c index d9006f8ffc1..7bbef95c9d1 100644 --- a/arch/sh/kernel/traps_32.c +++ b/arch/sh/kernel/traps_32.c @@ -316,6 +316,35 @@ static int handle_unaligned_ins(insn_size_t instruction, struct pt_regs *regs,  			break;  		}  		break; + +	case 9: /* mov.w @(disp,PC),Rn */ +		srcu = (unsigned char __user *)regs->pc; +		srcu += 4; +		srcu += (instruction & 0x00FF) << 1; +		dst = (unsigned char *)rn; +		*(unsigned long *)dst = 0; + +#if !defined(__LITTLE_ENDIAN__) +		dst += 2; +#endif + +		if (ma->from(dst, srcu, 2)) +			goto fetch_fault; +		sign_extend(2, dst); +		ret = 0; +		break; + +	case 0xd: /* mov.l @(disp,PC),Rn */ +		srcu = (unsigned char __user *)(regs->pc & ~0x3); +		srcu += 4; +		srcu += (instruction & 0x00FF) << 2; +		dst = (unsigned char *)rn; +		*(unsigned long *)dst = 0; + +		if (ma->from(dst, srcu, 4)) +			goto fetch_fault; +		ret = 0; +		break;  	}  	return ret; @@ -466,6 +495,7 @@ int handle_unaligned_access(insn_size_t instruction, struct pt_regs *regs,  		case 0x0500: /* mov.w @(disp,Rm),R0 */  			goto simple;  		case 0x0B00: /* bf   lab - no delayslot*/ +			ret = 0;  			break;  		case 0x0F00: /* bf/s lab */  			ret = handle_delayslot(regs, instruction, ma); @@ -479,6 +509,7 @@ int handle_unaligned_access(insn_size_t instruction, struct pt_regs *regs,  			}  			break;  		case 0x0900: /* bt   lab - no delayslot */ +			ret = 0;  			break;  		case 0x0D00: /* bt/s lab */  			ret = handle_delayslot(regs, instruction, ma); @@ -494,6 +525,9 @@ int handle_unaligned_access(insn_size_t instruction, struct pt_regs *regs,  		}  		break; +	case 0x9000: /* mov.w @(disp,Rm),Rn */ +		goto simple; +  	case 0xA000: /* bra label */  		ret = handle_delayslot(regs, instruction, ma);  		if (ret==0) @@ -507,6 +541,9 @@ int handle_unaligned_access(insn_size_t instruction, struct pt_regs *regs,  			regs->pc += SH_PC_12BIT_OFFSET(instruction);  		}  		break; + +	case 0xD000: /* mov.l @(disp,Rm),Rn */ +		goto simple;  	}  	return ret; diff --git a/arch/sh/kernel/traps_64.c b/arch/sh/kernel/traps_64.c index 67110be83fd..cd3a4048329 100644 --- a/arch/sh/kernel/traps_64.c +++ b/arch/sh/kernel/traps_64.c @@ -28,7 +28,7 @@  #include <asm/system.h>  #include <asm/uaccess.h>  #include <asm/io.h> -#include <asm/atomic.h> +#include <linux/atomic.h>  #include <asm/processor.h>  #include <asm/pgtable.h>  #include <asm/fpu.h> diff --git a/arch/sh/kernel/unwinder.c b/arch/sh/kernel/unwinder.c index 468889d958f..521b5432471 100644 --- a/arch/sh/kernel/unwinder.c +++ b/arch/sh/kernel/unwinder.c @@ -13,7 +13,7 @@  #include <linux/spinlock.h>  #include <linux/module.h>  #include <asm/unwinder.h> -#include <asm/atomic.h> +#include <linux/atomic.h>  /*   * This is the most basic stack unwinder an architecture can  |