[POWERPC 03/15] [POWERPC] TQM5200 board support

Grant Likely grant.likely at secretlab.ca
Mon Oct 8 16:21:54 EST 2007


On 10/7/07, Marian Balakowicz <m8 at semihalf.com> wrote:
>
> Add arch/powerpc board support for TQM5200.
>
> Signed-off-by: Marian Balakowicz <m8 at semihalf.com>
> Signed-off-by: Jan Wrobel <wrr at semihalf.com>

Hmmm....

Both this patch and the CM5200 support patch (#6 in your series) are
pretty much clones of lite5200.c.  I don't think this is the right
approach.  Don't duplicate code in this way.  Determine the common
bits and put them in a common place to be usable by any 5200 board
port.

It might even be better just to add a platform that matches on
compatible='mpc5200-generic' which is usable for mpc5200 boards that
don't need any custom setup by the kernel at platform setup time.
(which will probably be most 5200 boards).

More comments below.  (And, yes, I realize that all these comments
also apply to lite5200.c).

> ---
>
>  Kconfig   |    5 +
>  Makefile  |    1
>  tqm5200.c |  174 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 180 insertions(+)
>
> diff --git a/arch/powerpc/platforms/52xx/Kconfig b/arch/powerpc/platforms/52xx/Kconfig
> index 3ffaa06..7c828eb 100644
> --- a/arch/powerpc/platforms/52xx/Kconfig
> +++ b/arch/powerpc/platforms/52xx/Kconfig
> @@ -33,4 +33,9 @@ config PPC_LITE5200
>         select PPC_MPC5200
>         default n
>
> +config PPC_TQM5200
> +       bool "TQM5200 Board"
> +       depends on PPC_MULTIPLATFORM && PPC32

Hmmm; it's looking like every 52xx board is adding this boilerplate
"depends" line... That's probably sub-optimal.  (More a general
thought than a comment on your patch)

> +       select PPC_MPC5200
> +       default n
>
> diff --git a/arch/powerpc/platforms/52xx/Makefile b/arch/powerpc/platforms/52xx/Makefile
> index b91e39c..4997ebf 100644
> --- a/arch/powerpc/platforms/52xx/Makefile
> +++ b/arch/powerpc/platforms/52xx/Makefile
> @@ -8,5 +8,6 @@ endif
>
>  obj-$(CONFIG_PPC_EFIKA)                += efika.o
>  obj-$(CONFIG_PPC_LITE5200)     += lite5200.o
> +obj-$(CONFIG_PPC_TQM5200)      += tqm5200.o
>
>  obj-$(CONFIG_PM)               += mpc52xx_sleep.o mpc52xx_pm.o
> diff --git a/arch/powerpc/platforms/52xx/tqm5200.c b/arch/powerpc/platforms/52xx/tqm5200.c
> new file mode 100644
> index 0000000..780b79f
> --- /dev/null
> +++ b/arch/powerpc/platforms/52xx/tqm5200.c
> @@ -0,0 +1,174 @@
> +/*
> + * TQM5200 board support
> + *
> + * Written by: Grant Likely <grant.likely at secretlab.ca> for lite5200
> + * Adapted for tqm5200 by: Jan Wrobel <wrr at semihalf.com>
> + *
> + * Copyright (C) Secret Lab Technologies Ltd. 2006. All rights reserved.
> + * Copyright (C) Freescale Semicondutor, Inc. 2006. All rights reserved.
> + *
> + * Description:
> + * This program is free software; you can redistribute  it and/or modify it
> + * under  the terms of  the GNU General  Public License as published by the
> + * Free Software Foundation;  either version 2 of the  License, or (at your
> + * option) any later version.
> + */
> +
> +#undef DEBUG
> +
> +#include <linux/stddef.h>
> +#include <linux/kernel.h>
> +#include <linux/init.h>
> +#include <linux/errno.h>
> +#include <linux/reboot.h>
> +#include <linux/pci.h>
> +#include <linux/kdev_t.h>
> +#include <linux/major.h>
> +#include <linux/console.h>
> +#include <linux/delay.h>
> +#include <linux/seq_file.h>
> +#include <linux/root_dev.h>
> +#include <linux/initrd.h>
> +
> +#include <asm/system.h>
> +#include <asm/atomic.h>
> +#include <asm/time.h>
> +#include <asm/io.h>
> +#include <asm/machdep.h>
> +#include <asm/ipic.h>
> +#include <asm/bootinfo.h>
> +#include <asm/irq.h>
> +#include <asm/prom.h>
> +#include <asm/udbg.h>
> +#include <sysdev/fsl_soc.h>
> +#include <asm/of_platform.h>
> +
> +#include <asm/mpc52xx.h>
> +
> +/* ************************************************************************
> + *
> + * Setup the architecture
> + *
> + */
> +static void __init
> +tqm5200_setup_cpu(void)
> +{
> +       struct mpc52xx_gpio __iomem *gpio;
> +       u32 port_config;
> +
> +       /* Map zones */
> +       gpio = mpc52xx_find_and_map("mpc5200-gpio");
> +       if (!gpio) {
> +               printk(KERN_ERR __FILE__ ": "
> +                       "Error while mapping GPIO register for port config. "
> +                       "Expect some abnormal behavior\n");
> +               goto error;
> +       }
> +
> +       /* Set port config */
> +       port_config = in_be32(&gpio->port_config);
> +
> +       port_config &= ~0x00800000;     /* 48Mhz internal, pin is GPIO  */
> +
> +       port_config &= ~0x00007000;     /* USB port : Differential mode */
> +       port_config |=  0x00001000;     /*            USB 1 only        */
> +
> +       port_config &= ~0x03000000;     /* ATA CS is on csb_4/5         */
> +       port_config |=  0x01000000;

Are you *sure* you want this?  You should only be touching port_config
if firmware fails to set it up correctly.  Don't blindly copy what was
done for the lite5200.

Lite5200 touches it because firmware does *not* do the right thing at
the moment.

> +
> +       pr_debug("port_config: old:%x new:%x\n",
> +                in_be32(&gpio->port_config), port_config);
> +       out_be32(&gpio->port_config, port_config);
> +
> +       /* Unmap zone */
> +error:
> +       iounmap(gpio);
> +}
> +
> +static void __init tqm5200_setup_arch(void)
> +{
> +       struct device_node *np;
> +
> +       if (ppc_md.progress)
> +               ppc_md.progress("tqm5200_setup_arch()", 0);
> +
> +       np = of_find_node_by_type(NULL, "cpu");
> +       if (np) {
> +               unsigned int *fp =
> +                   (int *)of_get_property(np, "clock-frequency", NULL);

Unnecessary cast, and add 'const' to 'fp' declaration.

> +               if (fp != 0)

Use NULL instead of 0 for pointer tests.  'if (fp)' is also good style here.

> +                       loops_per_jiffy = *fp / HZ;
> +               else
> +                       loops_per_jiffy = 50000000 / HZ;
> +               of_node_put(np);
> +       }
> +
> +       /* CPU & Port mux setup */
> +       mpc52xx_setup_cpu();
> +       tqm5200_setup_cpu();
> +
> +#ifdef CONFIG_PCI
> +       np = of_find_node_by_type(NULL, "pci");
> +       if (np) {
> +               mpc52xx_add_bridge(np);
> +               of_node_put(np);
> +       }
> +#endif
> +
> +#ifdef CONFIG_BLK_DEV_INITRD
> +       if (initrd_start)
> +               /*
> +                * We want the proper initrd behavior, i.e., launching of
> +                * /linuxrc from the initial root file system, and not only
> +                * mounting it as the normal root file system.
> +                */
> +               ROOT_DEV = 0x0;
> +       else
> +#endif
> +#ifdef  CONFIG_ROOT_NFS
> +               ROOT_DEV = Root_NFS;
> +#else
> +               ROOT_DEV = Root_HDA1;
> +#endif

Drop all this ROOT_DEV code.  It's brain damaged.

> +
> +}
> +
> +void tqm5200_show_cpuinfo(struct seq_file *m)
> +{
> +       struct device_node* np = of_find_all_nodes(NULL);
> +       const char *model = NULL;
> +
> +       if (np)
> +               model = of_get_property(np, "model", NULL);
> +
> +       seq_printf(m, "vendor\t\t:      Freescale Semiconductor\n");

Freescale?  Really?

> +       seq_printf(m, "machine\t\t:     %s\n", model ? model : "unknown");
> +
> +       of_node_put(np);
> +}
> +
> +/*
> + * Called very early, MMU is off, device-tree isn't unflattened
> + */
> +static int __init tqm5200_probe(void)
> +{
> +       unsigned long node = of_get_flat_dt_root();
> +       const char *model = of_get_flat_dt_prop(node, "model", NULL);
> +
> +       if (!of_flat_dt_is_compatible(node, "fsl,tqm5200"))
> +               return 0;
> +       pr_debug("%s board found\n", model ? model : "unknown");

Drop the pr_debug line and the setting of 'model' above.  The platform
setup call prints out the name of the platform regardless.

> +
> +       return 1;
> +}
> +
> +define_machine(tqm5200) {
> +       .name           = "tqm5200",
> +       .probe          = tqm5200_probe,
> +       .setup_arch     = tqm5200_setup_arch,
> +       .init           = mpc52xx_declare_of_platform_devices,
> +       .init_IRQ       = mpc52xx_init_irq,
> +       .get_irq        = mpc52xx_get_irq,
> +       .show_cpuinfo   = tqm5200_show_cpuinfo,
> +       .calibrate_decr = generic_calibrate_decr,
> +};
>

Cheers,
g.

-- 
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.
grant.likely at secretlab.ca
(403) 399-0195



More information about the Linuxppc-dev mailing list