Mostly looks good, a few comments below.

On Fri, Jun 20, 2008 at 10:58:35AM -0600, John Rigby wrote:
> Implements the api defined in include/clk.h
> 
> Current only getting frequencies is supported
> not setting.

Need a more detailed commit message.  This doesn't tell me much.

> 
> Signed-off-by: John Rigby <[EMAIL PROTECTED]>
> ---
>  arch/powerpc/platforms/512x/Makefile |    1 +
>  arch/powerpc/platforms/512x/clock.c  |  729 
> ++++++++++++++++++++++++++++++++++
>  2 files changed, 730 insertions(+), 0 deletions(-)
>  create mode 100644 arch/powerpc/platforms/512x/clock.c
> 
> diff --git a/arch/powerpc/platforms/512x/Makefile 
> b/arch/powerpc/platforms/512x/Makefile
> index 232c89f..ef6c925 100644
> --- a/arch/powerpc/platforms/512x/Makefile
> +++ b/arch/powerpc/platforms/512x/Makefile
> @@ -1,4 +1,5 @@
>  #
>  # Makefile for the Freescale PowerPC 512x linux kernel.
>  #
> +obj-y                                := clock.o

should be +=

>  obj-$(CONFIG_MPC5121_ADS)    += mpc5121_ads.o
> diff --git a/arch/powerpc/platforms/512x/clock.c 
> b/arch/powerpc/platforms/512x/clock.c
> new file mode 100644
> index 0000000..39db722
> --- /dev/null
> +++ b/arch/powerpc/platforms/512x/clock.c
> @@ -0,0 +1,729 @@
> +/*
> + * Copyright (C) 2007,2008 Freescale Semiconductor, Inc. All rights reserved.
> + *
> + * Author: John Rigby <[EMAIL PROTECTED]>
> + *
> + * Implements the clk api defined in include/linux/clk.h
> + *
> + *    Original based on linux/arch/arm/mach-integrator/clock.c
> + *
> + *    Copyright (C) 2004 ARM Limited.
> + *    Written by Deep Blue Solutions Limited.
> + *
> + * 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 <linux/module.h>
> +#include <linux/kernel.h>
> +#include <linux/list.h>
> +#include <linux/errno.h>
> +#include <linux/err.h>
> +#include <linux/string.h>
> +#include <linux/clk.h>
> +#include <linux/mutex.h>
> +#include <linux/io.h>
> +
> +#include <linux/of_platform.h>
> +#include <asm/mpc512x.h>
> +
> +static int clocks_initialized;
> +
> +struct module;

This is already defined in linux/module.h?

> +
> +#undef CLK_DEBUG

I think this line should be at the top of the file to be easier to find
when toggling it.

> +#ifdef CLK_DEBUG
> +void dump_clocks(void)
> +{
> +     struct clk *p;
> +
> +     mutex_lock(&clocks_mutex);
> +     printk(KERN_INFO "CLOCKS:\n");
> +     list_for_each_entry(p, &clocks, node) {
> +             printk(KERN_INFO "  %s %ld", p->name, p->rate);
> +             if (p->parent)
> +                     printk(KERN_INFO " %s %ld", p->parent->name,
> +                            p->parent->rate);
> +             if (p->flags & CLK_HAS_CTRL)
> +                     printk(KERN_INFO " reg/bit %d/%d", p->reg, p->bit);
> +             printk("\n");
> +     }
> +     mutex_unlock(&clocks_mutex);
> +}
> +#define      DEBUG_CLK_DUMP() dump_clocks()
> +#else
> +#define      DEBUG_CLK_DUMP()
> +#endif
> +
> +static long ips_to_ref(unsigned long rate)
> +{
> +     int ips_div = (clockctl->scfr1 >> 23) & 0x7;
> +
> +     rate *= ips_div;        /* csb_clk = ips_clk * ips_div */
> +     rate *= 2;              /* sys_clk = csb_clk * 2 */
> +     return sys_to_ref(rate);
> +}
> +
> +static unsigned long devtree_getfreq(char *nodetype, char *clockname)

Why is nodetype even passed in here?  It isn't used, and besides, you
shouldn't test against device_type anyway.  Test against compatible
instead.

> +{
> +     struct device_node *node;
> +     const unsigned int *fp;
> +     unsigned int val = 0;
> +
> +     node = of_find_node_by_type(NULL, "soc");

Once again; don't look for device_type == "soc".  Use compatible.

> +     if (node) {
> +             fp = of_get_property(node, clockname, NULL);
> +             if (fp)
> +                     val = of_read_ulong(fp, 1);
> +     }
> +     return val;
> +}
> +
> +static void ref_clk_calc(struct clk *clk)
> +{
> +     unsigned long rate;
> +
> +     rate = devtree_getfreq("soc", "ref-frequency");
> +     if (rate == 0) {
> +             /*
> +              * no reference clock in device tree
> +              * get ips clock freq and go backwards from there
> +              */
> +             rate = devtree_getfreq("soc", "bus-frequency");
> +             if (rate == 0) {
> +                     printk(KERN_WARNING
> +                             "No bus-frequency in dev tree using 66MHz\n");
> +                     clk->rate = 66000000;

Is it even worth trying to use a default here?  I think it should fail
loudly instead to reduce the risk of people shipping boards with badly
formed device trees.  I don't think there is any backwards compatibility
need for doing this.

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to