[PATCH 51/62] ARM: samsung: allow serial driver to be disabled
Kukjin Kim
kgene.kim at samsung.com
Thu Mar 20 00:03:40 EDT 2014
Arnd Bergmann wrote:
>
> If CONFIG_SERIAL_SAMSUNG is disabled, we run into build errors
> with some samsung platforms. This adds a couple of #ifdef
> statements to hopefully deal with this more gracefully.
>
> Signed-off-by: Arnd Bergmann <arnd at arndb.de>
> Cc: Tomasz Figa <tomasz.figa at gmail.com>
> Cc: Kukjin Kim <kgene.kim at samsung.com>
Looks good to me,
Acked-by: Kukjin Kim <kgene.kim at samsung.com>
Thanks,
Kukjin
> Cc: Ben Dooks <ben-linux at fluff.org>
> ---
> arch/arm/mach-s3c64xx/irq-pm.c | 12 +++++++++---
> arch/arm/mach-s5p64x0/irq-pm.c | 6 ++++++
> arch/arm/plat-samsung/init.c | 4 ++++
> 3 files changed, 19 insertions(+), 3 deletions(-)
>
> diff --git a/arch/arm/mach-s3c64xx/irq-pm.c b/arch/arm/mach-s3c64xx/irq-
> pm.c
> index a61247b..ae4ea76 100644
> --- a/arch/arm/mach-s3c64xx/irq-pm.c
> +++ b/arch/arm/mach-s3c64xx/irq-pm.c
> @@ -55,7 +55,13 @@ static struct irq_grp_save {
> u32 mask;
> } eint_grp_save[5];
>
> -static u32 irq_uart_mask[CONFIG_SERIAL_SAMSUNG_UARTS];
> +#ifndef CONFIG_SERIAL_SAMSUNG_UARTS
> +#define SERIAL_SAMSUNG_UARTS 0
> +#else
> +#define SERIAL_SAMSUNG_UARTS CONFIG_SERIAL_SAMSUNG_UARTS
> +#endif
> +
> +static u32 irq_uart_mask[SERIAL_SAMSUNG_UARTS];
>
> static int s3c64xx_irq_pm_suspend(void)
> {
> @@ -66,7 +72,7 @@ static int s3c64xx_irq_pm_suspend(void)
>
> s3c_pm_do_save(irq_save, ARRAY_SIZE(irq_save));
>
> - for (i = 0; i < CONFIG_SERIAL_SAMSUNG_UARTS; i++)
> + for (i = 0; i < SERIAL_SAMSUNG_UARTS; i++)
> irq_uart_mask[i] = __raw_readl(S3C_VA_UARTx(i) +
> S3C64XX_UINTM);
>
> for (i = 0; i < ARRAY_SIZE(eint_grp_save); i++, grp++) {
> @@ -87,7 +93,7 @@ static void s3c64xx_irq_pm_resume(void)
>
> s3c_pm_do_restore(irq_save, ARRAY_SIZE(irq_save));
>
> - for (i = 0; i < CONFIG_SERIAL_SAMSUNG_UARTS; i++)
> + for (i = 0; i < SERIAL_SAMSUNG_UARTS; i++)
> __raw_writel(irq_uart_mask[i], S3C_VA_UARTx(i) +
> S3C64XX_UINTM);
>
> for (i = 0; i < ARRAY_SIZE(eint_grp_save); i++, grp++) {
> diff --git a/arch/arm/mach-s5p64x0/irq-pm.c b/arch/arm/mach-s5p64x0/irq-
> pm.c
> index 1c83d28..2ed921e 100644
> --- a/arch/arm/mach-s5p64x0/irq-pm.c
> +++ b/arch/arm/mach-s5p64x0/irq-pm.c
> @@ -34,7 +34,9 @@ static struct irq_grp_save {
> u32 mask;
> } eint_grp_save[4];
>
> +#ifdef CONFIG_SERIAL_SAMSUNG
> static u32 irq_uart_mask[CONFIG_SERIAL_SAMSUNG_UARTS];
> +#endif
>
> static int s5p64x0_irq_pm_suspend(void)
> {
> @@ -45,8 +47,10 @@ static int s5p64x0_irq_pm_suspend(void)
>
> s3c_pm_do_save(irq_save, ARRAY_SIZE(irq_save));
>
> +#ifdef CONFIG_SERIAL_SAMSUNG
> for (i = 0; i < CONFIG_SERIAL_SAMSUNG_UARTS; i++)
> irq_uart_mask[i] = __raw_readl(S3C_VA_UARTx(i) +
> S3C64XX_UINTM);
> +#endif
>
> for (i = 0; i < ARRAY_SIZE(eint_grp_save); i++, grp++) {
> grp->con = __raw_readl(S5P64X0_EINT12CON + (i * 4));
> @@ -66,8 +70,10 @@ static void s5p64x0_irq_pm_resume(void)
>
> s3c_pm_do_restore(irq_save, ARRAY_SIZE(irq_save));
>
> +#ifdef CONFIG_SERIAL_SAMSUNG
> for (i = 0; i < CONFIG_SERIAL_SAMSUNG_UARTS; i++)
> __raw_writel(irq_uart_mask[i], S3C_VA_UARTx(i) +
> S3C64XX_UINTM);
> +#endif
>
> for (i = 0; i < ARRAY_SIZE(eint_grp_save); i++, grp++) {
> __raw_writel(grp->con, S5P64X0_EINT12CON + (i * 4));
> diff --git a/arch/arm/plat-samsung/init.c b/arch/arm/plat-samsung/init.c
> index 0ffc84a..c32df1f 100644
> --- a/arch/arm/plat-samsung/init.c
> +++ b/arch/arm/plat-samsung/init.c
> @@ -96,7 +96,9 @@ void __init s3c24xx_init_clocks(int xtal)
> #if IS_ENABLED(CONFIG_SAMSUNG_ATAGS)
> static int nr_uarts __initdata = 0;
>
> +#ifdef CONFIG_SERIAL_SAMSUNG_UARTS
> static struct s3c2410_uartcfg uart_cfgs[CONFIG_SERIAL_SAMSUNG_UARTS];
> +#endif
>
> /* s3c24xx_init_uartdevs
> *
> @@ -111,6 +113,7 @@ void __init s3c24xx_init_uartdevs(char *name,
> struct s3c24xx_uart_resources *res,
> struct s3c2410_uartcfg *cfg, int no)
> {
> +#ifdef CONFIG_SERIAL_SAMSUNG_UARTS
> struct platform_device *platdev;
> struct s3c2410_uartcfg *cfgptr = uart_cfgs;
> struct s3c24xx_uart_resources *resp;
> @@ -133,6 +136,7 @@ void __init s3c24xx_init_uartdevs(char *name,
> }
>
> nr_uarts = no;
> +#endif
> }
>
> void __init s3c24xx_init_uarts(struct s3c2410_uartcfg *cfg, int no)
> --
> 1.8.3.2
More information about the linux-arm-kernel
mailing list