Message ID | 1351181518-11882-4-git-send-email-m-karicheri2@ti.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Thu, Oct 25, 2012 at 6:11 PM, Murali Karicheri <m-karicheri2@ti.com> wrote: > This is the common clk driver initialization functions for DaVinci > SoCs and other SoCs that uses similar hardware architecture. > clock.h also defines struct types for clock definitions in a SoC > and clock data type for configuring clk-mux. The initialization > functions are used by clock initialization code in a specific > platform/SoC. > > Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> This is looking good. Acked-by: Linus Walleij <linus.walleij@linaro.org> Yours, Linus Walleij
On 10/28/2012 03:25 PM, Linus Walleij wrote: > On Thu, Oct 25, 2012 at 6:11 PM, Murali Karicheri <m-karicheri2@ti.com> wrote: > >> This is the common clk driver initialization functions for DaVinci >> SoCs and other SoCs that uses similar hardware architecture. >> clock.h also defines struct types for clock definitions in a SoC >> and clock data type for configuring clk-mux. The initialization >> functions are used by clock initialization code in a specific >> platform/SoC. >> >> Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> > This is looking good. > Acked-by: Linus Walleij <linus.walleij@linaro.org> > > Yours, > Linus Walleij > Linus, Thanks. I will add your Acked-by in the next revision of the patch. Murali
On 10/25/2012 9:41 PM, Murali Karicheri wrote: > This is the common clk driver initialization functions for DaVinci > SoCs and other SoCs that uses similar hardware architecture. > clock.h also defines struct types for clock definitions in a SoC > and clock data type for configuring clk-mux. The initialization > functions are used by clock initialization code in a specific > platform/SoC. > > Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> > +struct clk *davinci_plldiv_clk(const char *name, const char *parent, > + struct clk_plldiv_data *data) > +{ > + /* > + * This is a PLL divider clock with divider specified by > + * div_reg in pll_div_data. > + */ > + data->reg = ioremap(data->phys_div_reg, 4); > + if (WARN_ON(!data->reg)) > + return NULL; > + > + return clk_register_davinci_plldiv(NULL, name, parent, data, &_lock); This function does not exist at this point. Looks like you need to swap 3/11 with 4/11. Also, you should also add build infrastructure (makefile, Kconfig) changes in the same patch that creates the file. There is no point in adding those separately. Thanks, Sekhar
On 11/01/2012 08:41 AM, Sekhar Nori wrote: > On 10/25/2012 9:41 PM, Murali Karicheri wrote: >> This is the common clk driver initialization functions for DaVinci >> SoCs and other SoCs that uses similar hardware architecture. >> clock.h also defines struct types for clock definitions in a SoC >> and clock data type for configuring clk-mux. The initialization >> functions are used by clock initialization code in a specific >> platform/SoC. >> >> Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> >> +struct clk *davinci_plldiv_clk(const char *name, const char *parent, >> + struct clk_plldiv_data *data) >> +{ >> + /* >> + * This is a PLL divider clock with divider specified by >> + * div_reg in pll_div_data. >> + */ >> + data->reg = ioremap(data->phys_div_reg, 4); >> + if (WARN_ON(!data->reg)) >> + return NULL; >> + >> + return clk_register_davinci_plldiv(NULL, name, parent, data, &_lock); > This function does not exist at this point. Looks like you need to swap > 3/11 with 4/11. Also, you should also add build infrastructure > (makefile, Kconfig) changes in the same patch that creates the file. > There is no point in adding those separately. > > Thanks, > Sekhar > Sekhar, So the Makefile, Kconfig and new files should be in the same patch. Also will re-order the 3/11 and 4/11 in the next revision. Murali
On 10/25/2012 9:41 PM, Murali Karicheri wrote: > This is the common clk driver initialization functions for DaVinci > SoCs and other SoCs that uses similar hardware architecture. > clock.h also defines struct types for clock definitions in a SoC > and clock data type for configuring clk-mux. The initialization > functions are used by clock initialization code in a specific > platform/SoC. > > Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> > --- > drivers/clk/davinci/clock.c | 112 +++++++++++++++++++++++++++++++++++++++++++ > drivers/clk/davinci/clock.h | 80 +++++++++++++++++++++++++++++++ > 2 files changed, 192 insertions(+) > create mode 100644 drivers/clk/davinci/clock.c > create mode 100644 drivers/clk/davinci/clock.h > > diff --git a/drivers/clk/davinci/clock.c b/drivers/clk/davinci/clock.c > new file mode 100644 > index 0000000..ad02149 > --- /dev/null > +++ b/drivers/clk/davinci/clock.c > @@ -0,0 +1,112 @@ > +/* > + * clock.c - davinci clock initialization functions for various clocks > + * > + * Copyright (C) 2006-2012 Texas Instruments. > + * Copyright (C) 2008-2009 Deep Root Systems, LLC > + * > + * 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. > + */ > +#include <linux/init.h> > +#include <linux/clk-provider.h> > +#include <linux/clkdev.h> > +#include <linux/io.h> > +#include <linux/slab.h> > + > +#include "clk-pll.h" > +#include "clk-psc.h" > +#include "clk-div.h" > +#include "clock.h" > + > +static DEFINE_SPINLOCK(_lock); > + > +#ifdef CONFIG_CLK_DAVINCI_PLL > +struct clk *davinci_pll_clk(const char *name, const char *parent, > + u32 phys_pllm, u32 phys_prediv, u32 phys_postdiv, > + struct clk_pll_data *pll_data) > +{ > + struct clk *clkp = NULL; > + > + pll_data->reg_pllm = ioremap(phys_pllm, 4); > + if (WARN_ON(!pll_data->reg_pllm)) > + return clkp; I would prefer ERR_PTR(-ENOMEM) here. Same comment applies to other instances elsewhere in the patch. > diff --git a/drivers/clk/davinci/clock.h b/drivers/clk/davinci/clock.h > new file mode 100644 > index 0000000..73204b8 > --- /dev/null > +++ b/drivers/clk/davinci/clock.h > @@ -0,0 +1,80 @@ > +/* > + * TI DaVinci Clock definitions - Contains Macros and Types used for > + * defining various clocks on a DaVinci SoC > + * > + * Copyright (C) 2012 Texas Instruments > + * > + * 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 version 2. > + * > + * This program is distributed "as is" WITHOUT ANY WARRANTY of any > + * kind, whether express or implied; without even the implied warranty > + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + */ > +#ifndef __DAVINCI_CLOCK_H > +#define __DAVINCI_CLOCK_H > + > +#include <linux/types.h> > + > +/* general flags: */ > +#define ALWAYS_ENABLED BIT(0) This is not used in this patch. Can you add the define along with its usage so it is immediately clear why you need it? > +/** > + * struct davinci_clk - struct for defining DaVinci clocks for a SoC. > + * > + * @name: name of the clock > + * @parent: name of parent clock > + * @flags: General flags for all drivers used by platform clock init code > + * @data: data specific to a clock used by the driver > + * @dev_id: dev_id used to look up this clock. If this is NULL > + * clock name is used for lookup. > + */ > +struct davinci_clk { > + const char *name; > + const char *parent; > + u32 flags; > + void *data; > + char *dev_id; Similarly dont see this being used as well. Thanks, Sekhar
On 11/03/2012 08:35 AM, Sekhar Nori wrote: > On 10/25/2012 9:41 PM, Murali Karicheri wrote: >> This is the common clk driver initialization functions for DaVinci >> SoCs and other SoCs that uses similar hardware architecture. >> clock.h also defines struct types for clock definitions in a SoC >> and clock data type for configuring clk-mux. The initialization >> functions are used by clock initialization code in a specific >> platform/SoC. >> >> Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> >> --- >> drivers/clk/davinci/clock.c | 112 +++++++++++++++++++++++++++++++++++++++++++ >> drivers/clk/davinci/clock.h | 80 +++++++++++++++++++++++++++++++ >> 2 files changed, 192 insertions(+) >> create mode 100644 drivers/clk/davinci/clock.c >> create mode 100644 drivers/clk/davinci/clock.h >> >> diff --git a/drivers/clk/davinci/clock.c b/drivers/clk/davinci/clock.c >> new file mode 100644 >> index 0000000..ad02149 >> --- /dev/null >> +++ b/drivers/clk/davinci/clock.c >> @@ -0,0 +1,112 @@ >> +/* >> + * clock.c - davinci clock initialization functions for various clocks >> + * >> + * Copyright (C) 2006-2012 Texas Instruments. >> + * Copyright (C) 2008-2009 Deep Root Systems, LLC >> + * >> + * 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. >> + */ >> +#include <linux/init.h> >> +#include <linux/clk-provider.h> >> +#include <linux/clkdev.h> >> +#include <linux/io.h> >> +#include <linux/slab.h> >> + >> +#include "clk-pll.h" >> +#include "clk-psc.h" >> +#include "clk-div.h" >> +#include "clock.h" >> + >> +static DEFINE_SPINLOCK(_lock); >> + >> +#ifdef CONFIG_CLK_DAVINCI_PLL >> +struct clk *davinci_pll_clk(const char *name, const char *parent, >> + u32 phys_pllm, u32 phys_prediv, u32 phys_postdiv, >> + struct clk_pll_data *pll_data) >> +{ >> + struct clk *clkp = NULL; >> + >> + pll_data->reg_pllm = ioremap(phys_pllm, 4); >> + if (WARN_ON(!pll_data->reg_pllm)) >> + return clkp; > I would prefer ERR_PTR(-ENOMEM) here. Same comment applies to other > instances elsewhere in the patch. > >> diff --git a/drivers/clk/davinci/clock.h b/drivers/clk/davinci/clock.h >> new file mode 100644 >> index 0000000..73204b8 >> --- /dev/null >> +++ b/drivers/clk/davinci/clock.h >> @@ -0,0 +1,80 @@ >> +/* >> + * TI DaVinci Clock definitions - Contains Macros and Types used for >> + * defining various clocks on a DaVinci SoC >> + * >> + * Copyright (C) 2012 Texas Instruments >> + * >> + * 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 version 2. >> + * >> + * This program is distributed "as is" WITHOUT ANY WARRANTY of any >> + * kind, whether express or implied; without even the implied warranty >> + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >> + * GNU General Public License for more details. >> + */ >> +#ifndef __DAVINCI_CLOCK_H >> +#define __DAVINCI_CLOCK_H >> + >> +#include <linux/types.h> >> + >> +/* general flags: */ >> +#define ALWAYS_ENABLED BIT(0) > This is not used in this patch. Can you add the define along with its > usage so it is immediately clear why you need it? This is used on the next patch as this adds a bunch of utilities or types for the platform specific clock code. Do you want to combine this patch with 05/11? It will become a bigger patch then? Is that fine. IMO, this is a logical group that can be a standalone patch than combining with 05/11. >> +/** >> + * struct davinci_clk - struct for defining DaVinci clocks for a SoC. >> + * >> + * @name: name of the clock >> + * @parent: name of parent clock >> + * @flags: General flags for all drivers used by platform clock init code >> + * @data: data specific to a clock used by the driver >> + * @dev_id: dev_id used to look up this clock. If this is NULL >> + * clock name is used for lookup. >> + */ >> +struct davinci_clk { >> + const char *name; >> + const char *parent; >> + u32 flags; >> + void *data; >> + char *dev_id; > Similarly dont see this being used as well. For this and previous one, check lpsc_clk() macro usage. dev_id is used where a specific device id is used to look up the clk as is done for davinci_emac.1, davinci_mmc.0 etc. > > Thanks, > Sekhar >
On 11/5/2012 8:50 PM, Murali Karicheri wrote: > On 11/03/2012 08:35 AM, Sekhar Nori wrote: >> On 10/25/2012 9:41 PM, Murali Karicheri wrote: >>> This is the common clk driver initialization functions for DaVinci >>> SoCs and other SoCs that uses similar hardware architecture. >>> clock.h also defines struct types for clock definitions in a SoC >>> and clock data type for configuring clk-mux. The initialization >>> functions are used by clock initialization code in a specific >>> platform/SoC. >>> >>> Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> >>> --- >>> drivers/clk/davinci/clock.c | 112 >>> +++++++++++++++++++++++++++++++++++++++++++ >>> drivers/clk/davinci/clock.h | 80 +++++++++++++++++++++++++++++++ >>> 2 files changed, 192 insertions(+) >>> create mode 100644 drivers/clk/davinci/clock.c >>> create mode 100644 drivers/clk/davinci/clock.h >>> >>> diff --git a/drivers/clk/davinci/clock.c b/drivers/clk/davinci/clock.c >>> new file mode 100644 >>> index 0000000..ad02149 >>> --- /dev/null >>> +++ b/drivers/clk/davinci/clock.c >>> @@ -0,0 +1,112 @@ >>> +/* >>> + * clock.c - davinci clock initialization functions for various clocks >>> + * >>> + * Copyright (C) 2006-2012 Texas Instruments. >>> + * Copyright (C) 2008-2009 Deep Root Systems, LLC >>> + * >>> + * 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. >>> + */ >>> +#include <linux/init.h> >>> +#include <linux/clk-provider.h> >>> +#include <linux/clkdev.h> >>> +#include <linux/io.h> >>> +#include <linux/slab.h> >>> + >>> +#include "clk-pll.h" >>> +#include "clk-psc.h" >>> +#include "clk-div.h" >>> +#include "clock.h" >>> + >>> +static DEFINE_SPINLOCK(_lock); >>> + >>> +#ifdef CONFIG_CLK_DAVINCI_PLL >>> +struct clk *davinci_pll_clk(const char *name, const char *parent, >>> + u32 phys_pllm, u32 phys_prediv, u32 phys_postdiv, >>> + struct clk_pll_data *pll_data) >>> +{ >>> + struct clk *clkp = NULL; >>> + >>> + pll_data->reg_pllm = ioremap(phys_pllm, 4); >>> + if (WARN_ON(!pll_data->reg_pllm)) >>> + return clkp; >> I would prefer ERR_PTR(-ENOMEM) here. Same comment applies to other >> instances elsewhere in the patch. >> >>> diff --git a/drivers/clk/davinci/clock.h b/drivers/clk/davinci/clock.h >>> new file mode 100644 >>> index 0000000..73204b8 >>> --- /dev/null >>> +++ b/drivers/clk/davinci/clock.h >>> @@ -0,0 +1,80 @@ >>> +/* >>> + * TI DaVinci Clock definitions - Contains Macros and Types used for >>> + * defining various clocks on a DaVinci SoC >>> + * >>> + * Copyright (C) 2012 Texas Instruments >>> + * >>> + * 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 version 2. >>> + * >>> + * This program is distributed "as is" WITHOUT ANY WARRANTY of any >>> + * kind, whether express or implied; without even the implied warranty >>> + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >>> + * GNU General Public License for more details. >>> + */ >>> +#ifndef __DAVINCI_CLOCK_H >>> +#define __DAVINCI_CLOCK_H >>> + >>> +#include <linux/types.h> >>> + >>> +/* general flags: */ >>> +#define ALWAYS_ENABLED BIT(0) >> This is not used in this patch. Can you add the define along with its >> usage so it is immediately clear why you need it? > This is used on the next patch as this adds a bunch of utilities or > types for the platform specific clock code. Do you want to combine this > patch with 05/11? It will become a bigger patch then? Is that fine. > IMO, this is a logical group that can be a standalone patch than > combining with 05/11. It is more important to divide patches in logical functional blocks rather than split it based on files. Reading this patch, I have no idea what that define is for. Thanks, Sekhar
On 11/06/2012 04:31 AM, Sekhar Nori wrote: > > On 11/5/2012 8:50 PM, Murali Karicheri wrote: >> On 11/03/2012 08:35 AM, Sekhar Nori wrote: >>> On 10/25/2012 9:41 PM, Murali Karicheri wrote: >>>> This is the common clk driver initialization functions for DaVinci >>>> SoCs and other SoCs that uses similar hardware architecture. >>>> clock.h also defines struct types for clock definitions in a SoC >>>> and clock data type for configuring clk-mux. The initialization >>>> functions are used by clock initialization code in a specific >>>> platform/SoC. >>>> >>>> Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> >>>> --- >>>> drivers/clk/davinci/clock.c | 112 >>>> +++++++++++++++++++++++++++++++++++++++++++ >>>> drivers/clk/davinci/clock.h | 80 +++++++++++++++++++++++++++++++ >>>> 2 files changed, 192 insertions(+) >>>> create mode 100644 drivers/clk/davinci/clock.c >>>> create mode 100644 drivers/clk/davinci/clock.h >>>> >>>> diff --git a/drivers/clk/davinci/clock.c b/drivers/clk/davinci/clock.c >>>> new file mode 100644 >>>> index 0000000..ad02149 >>>> --- /dev/null >>>> +++ b/drivers/clk/davinci/clock.c >>>> @@ -0,0 +1,112 @@ >>>> +/* >>>> + * clock.c - davinci clock initialization functions for various clocks >>>> + * >>>> + * Copyright (C) 2006-2012 Texas Instruments. >>>> + * Copyright (C) 2008-2009 Deep Root Systems, LLC >>>> + * >>>> + * 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. >>>> + */ >>>> +#include <linux/init.h> >>>> +#include <linux/clk-provider.h> >>>> +#include <linux/clkdev.h> >>>> +#include <linux/io.h> >>>> +#include <linux/slab.h> >>>> + >>>> +#include "clk-pll.h" >>>> +#include "clk-psc.h" >>>> +#include "clk-div.h" >>>> +#include "clock.h" >>>> + >>>> +static DEFINE_SPINLOCK(_lock); >>>> + >>>> +#ifdef CONFIG_CLK_DAVINCI_PLL >>>> +struct clk *davinci_pll_clk(const char *name, const char *parent, >>>> + u32 phys_pllm, u32 phys_prediv, u32 phys_postdiv, >>>> + struct clk_pll_data *pll_data) >>>> +{ >>>> + struct clk *clkp = NULL; >>>> + >>>> + pll_data->reg_pllm = ioremap(phys_pllm, 4); >>>> + if (WARN_ON(!pll_data->reg_pllm)) >>>> + return clkp; >>> I would prefer ERR_PTR(-ENOMEM) here. Same comment applies to other >>> instances elsewhere in the patch. >>> >>>> diff --git a/drivers/clk/davinci/clock.h b/drivers/clk/davinci/clock.h >>>> new file mode 100644 >>>> index 0000000..73204b8 >>>> --- /dev/null >>>> +++ b/drivers/clk/davinci/clock.h >>>> @@ -0,0 +1,80 @@ >>>> +/* >>>> + * TI DaVinci Clock definitions - Contains Macros and Types used for >>>> + * defining various clocks on a DaVinci SoC >>>> + * >>>> + * Copyright (C) 2012 Texas Instruments >>>> + * >>>> + * 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 version 2. >>>> + * >>>> + * This program is distributed "as is" WITHOUT ANY WARRANTY of any >>>> + * kind, whether express or implied; without even the implied warranty >>>> + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the >>>> + * GNU General Public License for more details. >>>> + */ >>>> +#ifndef __DAVINCI_CLOCK_H >>>> +#define __DAVINCI_CLOCK_H >>>> + >>>> +#include <linux/types.h> >>>> + >>>> +/* general flags: */ >>>> +#define ALWAYS_ENABLED BIT(0) >>> This is not used in this patch. Can you add the define along with its >>> usage so it is immediately clear why you need it? >> This is used on the next patch as this adds a bunch of utilities or >> types for the platform specific clock code. Do you want to combine this >> patch with 05/11? It will become a bigger patch then? Is that fine. >> IMO, this is a logical group that can be a standalone patch than >> combining with 05/11. > It is more important to divide patches in logical functional blocks > rather than split it based on files. Reading this patch, I have no idea > what that define is for. > > Thanks, > Sekhar > > Will combine with 05/11 since utilities are used by the clock init code in dm644x. Murali
diff --git a/drivers/clk/davinci/clock.c b/drivers/clk/davinci/clock.c new file mode 100644 index 0000000..ad02149 --- /dev/null +++ b/drivers/clk/davinci/clock.c @@ -0,0 +1,112 @@ +/* + * clock.c - davinci clock initialization functions for various clocks + * + * Copyright (C) 2006-2012 Texas Instruments. + * Copyright (C) 2008-2009 Deep Root Systems, LLC + * + * 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. + */ +#include <linux/init.h> +#include <linux/clk-provider.h> +#include <linux/clkdev.h> +#include <linux/io.h> +#include <linux/slab.h> + +#include "clk-pll.h" +#include "clk-psc.h" +#include "clk-div.h" +#include "clock.h" + +static DEFINE_SPINLOCK(_lock); + +#ifdef CONFIG_CLK_DAVINCI_PLL +struct clk *davinci_pll_clk(const char *name, const char *parent, + u32 phys_pllm, u32 phys_prediv, u32 phys_postdiv, + struct clk_pll_data *pll_data) +{ + struct clk *clkp = NULL; + + pll_data->reg_pllm = ioremap(phys_pllm, 4); + if (WARN_ON(!pll_data->reg_pllm)) + return clkp; + + pll_data->reg_prediv = ioremap(phys_prediv, 4); + if (WARN_ON(!pll_data->reg_prediv)) + goto error1; + + pll_data->reg_postdiv = ioremap(phys_postdiv, 4); + if (WARN_ON(!pll_data->reg_postdiv)) + goto error2; + + return clk_register_davinci_pll(NULL, name, parent, pll_data); +error1: + iounmap(pll_data->reg_pllm); +error2: + iounmap(pll_data->reg_prediv); + return clkp; +} +#else +struct clk *davinci_pll_clk(const char *name, const char *parent, + u32 phys_pllm, u32 phys_prediv, u32 phys_postdiv, + struct clk_pll_data *pll_data) +{ + return NULL; +} +#endif + +struct clk *davinci_mux_clk(const char *name, u8 num_parents, + const char **parents, struct clk_mux_data *data) + +{ + void __iomem *reg; + + reg = ioremap(data->phys_reg, 4); + if (WARN_ON(!reg)) + return NULL; + + return clk_register_mux(NULL, name, parents, num_parents, data->flags, + reg, data->shift, data->width, data->mux_flags, + &_lock); +} + +struct clk *davinci_plldiv_clk(const char *name, const char *parent, + struct clk_plldiv_data *data) +{ + /* + * This is a PLL divider clock with divider specified by + * div_reg in pll_div_data. + */ + data->reg = ioremap(data->phys_div_reg, 4); + if (WARN_ON(!data->reg)) + return NULL; + + return clk_register_davinci_plldiv(NULL, name, parent, data, &_lock); +} + +inline struct clk *davinci_fixed_factor_clk(const char *name, + const char *parent, unsigned long flags, + unsigned int mult, unsigned int div) +{ + if (WARN_ON(!mult)) + return NULL; + + if (WARN_ON(!div)) + return NULL; + + return clk_register_fixed_factor(NULL, name, parent, flags, mult, div); +} + +inline struct clk *davinci_fixed_ref_clk(const char *name, + unsigned long rate) +{ + return clk_register_fixed_rate(NULL, name, NULL, CLK_IS_ROOT, rate); +} + +inline struct clk *davinci_psc_clk(const char *name, const char *parent, + struct clk_psc_data *data) +{ + return clk_register_davinci_psc(NULL, name, parent, data); +} diff --git a/drivers/clk/davinci/clock.h b/drivers/clk/davinci/clock.h new file mode 100644 index 0000000..73204b8 --- /dev/null +++ b/drivers/clk/davinci/clock.h @@ -0,0 +1,80 @@ +/* + * TI DaVinci Clock definitions - Contains Macros and Types used for + * defining various clocks on a DaVinci SoC + * + * Copyright (C) 2012 Texas Instruments + * + * 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 version 2. + * + * This program is distributed "as is" WITHOUT ANY WARRANTY of any + * kind, whether express or implied; without even the implied warranty + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + */ +#ifndef __DAVINCI_CLOCK_H +#define __DAVINCI_CLOCK_H + +#include <linux/types.h> + +/* general flags: */ +#define ALWAYS_ENABLED BIT(0) + +/** + * struct clk_mux_data - struct for clk mux data to configure clk-mux + * + * @flags: base flags for clk driver + * @mux_flags: mux driver flags + * @shift: shift applied to mux selector bits + * @width: width of the mux selctor bits + * @phys_reg: physical address of the mux register + */ +struct clk_mux_data { + u32 flags; + u8 mux_flags; + u8 shift; + u8 width; + u32 phys_reg; +}; + +/** + * struct davinci_clk - struct for defining DaVinci clocks for a SoC. + * + * @name: name of the clock + * @parent: name of parent clock + * @flags: General flags for all drivers used by platform clock init code + * @data: data specific to a clock used by the driver + * @dev_id: dev_id used to look up this clock. If this is NULL + * clock name is used for lookup. + */ +struct davinci_clk { + const char *name; + const char *parent; + u32 flags; + void *data; + char *dev_id; +}; + +/* function prototypes for initializing various clocks */ +struct clk *davinci_fixed_ref_clk(const char *name, + unsigned long rate); + +struct clk *davinci_pll_clk(const char *name, const char *parent, + u32 phys_pllm, u32 phys_prediv, u32 phys_postdiv, + struct clk_pll_data *pll_data); + + +struct clk *davinci_mux_clk(const char *name, u8 num_parents, + const char **parents, struct clk_mux_data *data); + +struct clk *davinci_plldiv_clk(const char *name, const char *parent, + struct clk_plldiv_data *data); + +struct clk *davinci_psc_clk(const char *name, const char *parent, + struct clk_psc_data *data); + +struct clk *davinci_fixed_factor_clk(const char *name, + const char *parent, unsigned long flags, + unsigned int mult, unsigned int div); +#endif
This is the common clk driver initialization functions for DaVinci SoCs and other SoCs that uses similar hardware architecture. clock.h also defines struct types for clock definitions in a SoC and clock data type for configuring clk-mux. The initialization functions are used by clock initialization code in a specific platform/SoC. Signed-off-by: Murali Karicheri <m-karicheri2@ti.com> --- drivers/clk/davinci/clock.c | 112 +++++++++++++++++++++++++++++++++++++++++++ drivers/clk/davinci/clock.h | 80 +++++++++++++++++++++++++++++++ 2 files changed, 192 insertions(+) create mode 100644 drivers/clk/davinci/clock.c create mode 100644 drivers/clk/davinci/clock.h