Commit 4d1d13a5 authored by Stephen Boyd's avatar Stephen Boyd

Merge branches 'clk-remove-asm-clkdev', 'clk-debugfs-fixes', 'clk-renesas' and...

Merge branches 'clk-remove-asm-clkdev', 'clk-debugfs-fixes', 'clk-renesas' and 'clk-meson' into clk-next

* clk-remove-asm-clkdev:
  clk: Move __clk_{get,put}() into private clk.h API
  clk: sunxi: Use CLK_IS_CRITICAL flag for critical clks
  arch: Remove clkdev.h asm-generic from Kbuild
  clk: Prepare to remove asm-generic/clkdev.h
  blackfin: Use generic clkdev.h header

* clk-debugfs-fixes:
  clk: Simplify debugfs registration
  clk: Fix debugfs_create_*() usage
  clk: Show symbolic clock flags in debugfs
  clk: Improve flags doc for of_clk_detect_critical()

* clk-renesas:
  clk: renesas: r8a7796: Add FDP clock
  clk: renesas: cpg-mssr: Keep wakeup sources active during system suspend
  clk: renesas: mstp: Keep wakeup sources active during system suspend
  clk: renesas: r8a77970: Add LVDS clock

* clk-meson:
  clk: meson-axg: fix potential NULL dereference in axg_clkc_probe()
  clk: meson-axg: make local symbol axg_gp0_params_table static
  clk: meson-axg: fix return value check in axg_clkc_probe()
  clk: meson: mpll: use 64-bit maths in params_from_rate
  clk: meson-axg: add clock controller drivers
  clk: meson-axg: add clocks dt-bindings required header
  dt-bindings: clock: add compatible variant for the Meson-AXG
  clk: meson: make the spinlock naming more specific
  clk: meson: gxbb: remove IGNORE_UNUSED from mmc clocks
  clk: meson: gxbb: fix wrong clock for SARADC/SANA
...@@ -5,8 +5,11 @@ controllers within the SoC. ...@@ -5,8 +5,11 @@ controllers within the SoC.
Required Properties: Required Properties:
- compatible: should be "amlogic,gxbb-clkc" for GXBB SoC, - compatible: should be:
or "amlogic,gxl-clkc" for GXL and GXM SoC. "amlogic,gxbb-clkc" for GXBB SoC,
"amlogic,gxl-clkc" for GXL and GXM SoC,
"amlogic,axg-clkc" for AXG SoC.
- reg: physical base address of the clock controller and length of memory - reg: physical base address of the clock controller and length of memory
mapped region. mapped region.
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: GPL-2.0
generic-y += clkdev.h
generic-y += exec.h generic-y += exec.h
generic-y += export.h generic-y += export.h
generic-y += fb.h generic-y += fb.h
......
# SPDX-License-Identifier: GPL-2.0 # SPDX-License-Identifier: GPL-2.0
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
generic-y += emergency-restart.h generic-y += emergency-restart.h
......
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += early_ioremap.h generic-y += early_ioremap.h
generic-y += emergency-restart.h generic-y += emergency-restart.h
......
...@@ -105,6 +105,7 @@ config ARCH_MESON ...@@ -105,6 +105,7 @@ config ARCH_MESON
select PINCTRL_MESON select PINCTRL_MESON
select COMMON_CLK_AMLOGIC select COMMON_CLK_AMLOGIC
select COMMON_CLK_GXBB select COMMON_CLK_GXBB
select COMMON_CLK_AXG
select MESON_IRQ_GPIO select MESON_IRQ_GPIO
help help
This enables support for the Amlogic S905 SoCs. This enables support for the Amlogic S905 SoCs.
......
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += delay.h generic-y += delay.h
generic-y += div64.h generic-y += div64.h
generic-y += dma.h generic-y += dma.h
......
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __ASM_CLKDEV__H_
#define __ASM_CLKDEV__H_
#include <linux/slab.h>
static inline struct clk_lookup_alloc *__clkdev_alloc(size_t size)
{
return kzalloc(size, GFP_KERNEL);
}
#ifndef CONFIG_COMMON_CLK
#define __clk_put(clk)
#define __clk_get(clk) ({ 1; })
#endif
#endif
generic-y += atomic.h generic-y += atomic.h
generic-y += barrier.h generic-y += barrier.h
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
......
generic-y += atomic.h generic-y += atomic.h
generic-y += barrier.h generic-y += barrier.h
generic-y += clkdev.h
generic-y += cmpxchg.h generic-y += cmpxchg.h
generic-y += current.h generic-y += current.h
generic-y += device.h generic-y += device.h
......
generic-y += clkdev.h
generic-y += device.h generic-y += device.h
generic-y += exec.h generic-y += exec.h
generic-y += extable.h generic-y += extable.h
......
...@@ -3,7 +3,6 @@ generic-y += barrier.h ...@@ -3,7 +3,6 @@ generic-y += barrier.h
generic-y += bugs.h generic-y += bugs.h
generic-y += cacheflush.h generic-y += cacheflush.h
generic-y += checksum.h generic-y += checksum.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += delay.h generic-y += delay.h
generic-y += device.h generic-y += device.h
......
...@@ -2,7 +2,6 @@ ...@@ -2,7 +2,6 @@
generic-y += barrier.h generic-y += barrier.h
generic-y += bug.h generic-y += bug.h
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
......
generic-y += clkdev.h
generic-y += exec.h generic-y += exec.h
generic-y += irq_work.h generic-y += irq_work.h
generic-y += mcs_spinlock.h generic-y += mcs_spinlock.h
......
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += exec.h generic-y += exec.h
generic-y += extable.h generic-y += extable.h
......
generic-y += barrier.h generic-y += barrier.h
generic-y += clkdev.h
generic-y += device.h generic-y += device.h
generic-y += emergency-restart.h generic-y += emergency-restart.h
generic-y += exec.h generic-y += exec.h
......
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += device.h generic-y += device.h
generic-y += dma.h generic-y += dma.h
......
...@@ -2,7 +2,6 @@ generic-y += barrier.h ...@@ -2,7 +2,6 @@ generic-y += barrier.h
generic-y += bitops.h generic-y += bitops.h
generic-y += bug.h generic-y += bug.h
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
generic-y += emergency-restart.h generic-y += emergency-restart.h
......
# MIPS headers # MIPS headers
generic-(CONFIG_GENERIC_CSUM) += checksum.h generic-(CONFIG_GENERIC_CSUM) += checksum.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += dma-contiguous.h generic-y += dma-contiguous.h
generic-y += emergency-restart.h generic-y += emergency-restart.h
......
generic-y += barrier.h generic-y += barrier.h
generic-y += clkdev.h
generic-y += device.h generic-y += device.h
generic-y += exec.h generic-y += exec.h
generic-y += extable.h generic-y += extable.h
......
...@@ -3,7 +3,6 @@ generic-y += barrier.h ...@@ -3,7 +3,6 @@ generic-y += barrier.h
generic-y += bitops.h generic-y += bitops.h
generic-y += bug.h generic-y += bug.h
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += cmpxchg.h generic-y += cmpxchg.h
generic-y += current.h generic-y += current.h
generic-y += device.h generic-y += device.h
......
...@@ -2,7 +2,6 @@ generic-y += barrier.h ...@@ -2,7 +2,6 @@ generic-y += barrier.h
generic-y += bug.h generic-y += bug.h
generic-y += bugs.h generic-y += bugs.h
generic-y += checksum.h generic-y += checksum.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
......
generic-y += barrier.h generic-y += barrier.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
......
generic-y += clkdev.h
generic-y += div64.h generic-y += div64.h
generic-y += export.h generic-y += export.h
generic-y += irq_regs.h generic-y += irq_regs.h
......
generic-y += bugs.h generic-y += bugs.h
generic-y += cacheflush.h generic-y += cacheflush.h
generic-y += checksum.h generic-y += checksum.h
generic-y += clkdev.h
generic-y += cputime.h generic-y += cputime.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
......
generic-y += asm-offsets.h generic-y += asm-offsets.h
generic-y += cacheflush.h generic-y += cacheflush.h
generic-y += clkdev.h
generic-y += device.h generic-y += device.h
generic-y += dma-contiguous.h generic-y += dma-contiguous.h
generic-y += div64.h generic-y += div64.h
......
generic-y += barrier.h generic-y += barrier.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += extable.h generic-y += extable.h
generic-y += irq_work.h generic-y += irq_work.h
......
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += delay.h generic-y += delay.h
generic-y += div64.h generic-y += div64.h
......
# User exported sparc header files # User exported sparc header files
generic-y += clkdev.h
generic-y += div64.h generic-y += div64.h
generic-y += emergency-restart.h generic-y += emergency-restart.h
generic-y += exec.h generic-y += exec.h
......
generic-y += bug.h generic-y += bug.h
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += emergency-restart.h generic-y += emergency-restart.h
generic-y += exec.h generic-y += exec.h
generic-y += extable.h generic-y += extable.h
......
generic-y += barrier.h generic-y += barrier.h
generic-y += bug.h generic-y += bug.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += delay.h generic-y += delay.h
generic-y += device.h generic-y += device.h
......
generic-y += atomic.h generic-y += atomic.h
generic-y += bugs.h generic-y += bugs.h
generic-y += clkdev.h
generic-y += current.h generic-y += current.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
......
...@@ -6,7 +6,6 @@ generated-y += unistd_32_ia32.h ...@@ -6,7 +6,6 @@ generated-y += unistd_32_ia32.h
generated-y += unistd_64_x32.h generated-y += unistd_64_x32.h
generated-y += xen-hypercalls.h generated-y += xen-hypercalls.h
generic-y += clkdev.h
generic-y += dma-contiguous.h generic-y += dma-contiguous.h
generic-y += early_ioremap.h generic-y += early_ioremap.h
generic-y += mcs_spinlock.h generic-y += mcs_spinlock.h
......
generic-y += bug.h generic-y += bug.h
generic-y += clkdev.h
generic-y += device.h generic-y += device.h
generic-y += div64.h generic-y += div64.h
generic-y += dma-contiguous.h generic-y += dma-contiguous.h
......
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <linux/sched.h> #include <linux/sched.h>
#include <linux/clkdev.h> #include <linux/clkdev.h>
#include <linux/stringify.h>
#include "clk.h" #include "clk.h"
...@@ -2559,6 +2560,58 @@ static const struct file_operations clk_dump_fops = { ...@@ -2559,6 +2560,58 @@ static const struct file_operations clk_dump_fops = {
.release = single_release, .release = single_release,
}; };
static const struct {
unsigned long flag;
const char *name;
} clk_flags[] = {
#define ENTRY(f) { f, __stringify(f) }
ENTRY(CLK_SET_RATE_GATE),
ENTRY(CLK_SET_PARENT_GATE),
ENTRY(CLK_SET_RATE_PARENT),
ENTRY(CLK_IGNORE_UNUSED),
ENTRY(CLK_IS_BASIC),
ENTRY(CLK_GET_RATE_NOCACHE),
ENTRY(CLK_SET_RATE_NO_REPARENT),
ENTRY(CLK_GET_ACCURACY_NOCACHE),
ENTRY(CLK_RECALC_NEW_RATES),
ENTRY(CLK_SET_RATE_UNGATE),
ENTRY(CLK_IS_CRITICAL),
ENTRY(CLK_OPS_PARENT_ENABLE),
#undef ENTRY
};
static int clk_flags_dump(struct seq_file *s, void *data)
{
struct clk_core *core = s->private;
unsigned long flags = core->flags;
unsigned int i;
for (i = 0; flags && i < ARRAY_SIZE(clk_flags); i++) {
if (flags & clk_flags[i].flag) {
seq_printf(s, "%s\n", clk_flags[i].name);
flags &= ~clk_flags[i].flag;
}
}
if (flags) {
/* Unknown flags */
seq_printf(s, "0x%lx\n", flags);
}
return 0;
}
static int clk_flags_open(struct inode *inode, struct file *file)
{
return single_open(file, clk_flags_dump, inode->i_private);
}
static const struct file_operations clk_flags_fops = {
.open = clk_flags_open,
.read = seq_read,
.llseek = seq_lseek,
.release = single_release,
};
static int possible_parents_dump(struct seq_file *s, void *data) static int possible_parents_dump(struct seq_file *s, void *data)
{ {
struct clk_core *core = s->private; struct clk_core *core = s->private;
...@@ -2600,48 +2653,46 @@ static int clk_debug_create_one(struct clk_core *core, struct dentry *pdentry) ...@@ -2600,48 +2653,46 @@ static int clk_debug_create_one(struct clk_core *core, struct dentry *pdentry)
core->dentry = d; core->dentry = d;
d = debugfs_create_u32("clk_rate", S_IRUGO, core->dentry, d = debugfs_create_ulong("clk_rate", 0444, core->dentry, &core->rate);
(u32 *)&core->rate);
if (!d) if (!d)
goto err_out; goto err_out;
d = debugfs_create_u32("clk_accuracy", S_IRUGO, core->dentry, d = debugfs_create_ulong("clk_accuracy", 0444, core->dentry,
(u32 *)&core->accuracy); &core->accuracy);
if (!d) if (!d)
goto err_out; goto err_out;
d = debugfs_create_u32("clk_phase", S_IRUGO, core->dentry, d = debugfs_create_u32("clk_phase", 0444, core->dentry, &core->phase);
(u32 *)&core->phase);
if (!d) if (!d)
goto err_out; goto err_out;
d = debugfs_create_x32("clk_flags", S_IRUGO, core->dentry, d = debugfs_create_file("clk_flags", 0444, core->dentry, core,
(u32 *)&core->flags); &clk_flags_fops);
if (!d) if (!d)
goto err_out; goto err_out;
d = debugfs_create_u32("clk_prepare_count", S_IRUGO, core->dentry, d = debugfs_create_u32("clk_prepare_count", 0444, core->dentry,
(u32 *)&core->prepare_count); &core->prepare_count);
if (!d) if (!d)
goto err_out; goto err_out;
d = debugfs_create_u32("clk_enable_count", S_IRUGO, core->dentry, d = debugfs_create_u32("clk_enable_count", 0444, core->dentry,
(u32 *)&core->enable_count); &core->enable_count);
if (!d) if (!d)
goto err_out; goto err_out;
d = debugfs_create_u32("clk_protect_count", S_IRUGO, core->dentry, d = debugfs_create_u32("clk_protect_count", 0444, core->dentry,
(u32 *)&core->protect_count); &core->protect_count);
if (!d) if (!d)
goto err_out; goto err_out;
d = debugfs_create_u32("clk_notifier_count", S_IRUGO, core->dentry, d = debugfs_create_u32("clk_notifier_count", 0444, core->dentry,
(u32 *)&core->notifier_count); &core->notifier_count);
if (!d) if (!d)
goto err_out; goto err_out;
if (core->num_parents > 1) { if (core->num_parents > 1) {
d = debugfs_create_file("clk_possible_parents", S_IRUGO, d = debugfs_create_file("clk_possible_parents", 0444,
core->dentry, core, &possible_parents_fops); core->dentry, core, &possible_parents_fops);
if (!d) if (!d)
goto err_out; goto err_out;
...@@ -2677,12 +2728,8 @@ static int clk_debug_register(struct clk_core *core) ...@@ -2677,12 +2728,8 @@ static int clk_debug_register(struct clk_core *core)
mutex_lock(&clk_debug_lock); mutex_lock(&clk_debug_lock);
hlist_add_head(&core->debug_node, &clk_debug_list); hlist_add_head(&core->debug_node, &clk_debug_list);
if (inited)
if (!inited)
goto unlock;
ret = clk_debug_create_one(core, rootdir); ret = clk_debug_create_one(core, rootdir);
unlock:
mutex_unlock(&clk_debug_lock); mutex_unlock(&clk_debug_lock);
return ret; return ret;
...@@ -2737,22 +2784,22 @@ static int __init clk_debug_init(void) ...@@ -2737,22 +2784,22 @@ static int __init clk_debug_init(void)
if (!rootdir) if (!rootdir)
return -ENOMEM; return -ENOMEM;
d = debugfs_create_file("clk_summary", S_IRUGO, rootdir, &all_lists, d = debugfs_create_file("clk_summary", 0444, rootdir, &all_lists,
&clk_summary_fops); &clk_summary_fops);
if (!d) if (!d)
return -ENOMEM; return -ENOMEM;
d = debugfs_create_file("clk_dump", S_IRUGO, rootdir, &all_lists, d = debugfs_create_file("clk_dump", 0444, rootdir, &all_lists,
&clk_dump_fops); &clk_dump_fops);
if (!d) if (!d)
return -ENOMEM; return -ENOMEM;
d = debugfs_create_file("clk_orphan_summary", S_IRUGO, rootdir, d = debugfs_create_file("clk_orphan_summary", 0444, rootdir,
&orphan_list, &clk_summary_fops); &orphan_list, &clk_summary_fops);
if (!d) if (!d)
return -ENOMEM; return -ENOMEM;
d = debugfs_create_file("clk_orphan_dump", S_IRUGO, rootdir, d = debugfs_create_file("clk_orphan_dump", 0444, rootdir,
&orphan_list, &clk_dump_fops); &orphan_list, &clk_dump_fops);
if (!d) if (!d)
return -ENOMEM; return -ENOMEM;
...@@ -3927,7 +3974,7 @@ static int parent_ready(struct device_node *np) ...@@ -3927,7 +3974,7 @@ static int parent_ready(struct device_node *np)
* of_clk_detect_critical() - set CLK_IS_CRITICAL flag from Device Tree * of_clk_detect_critical() - set CLK_IS_CRITICAL flag from Device Tree
* @np: Device node pointer associated with clock provider * @np: Device node pointer associated with clock provider
* @index: clock index * @index: clock index
* @flags: pointer to clk_core->flags * @flags: pointer to top-level framework flags
* *
* Detects if the clock-critical property exists and, if so, sets the * Detects if the clock-critical property exists and, if so, sets the
* corresponding CLK_IS_CRITICAL flag. * corresponding CLK_IS_CRITICAL flag.
......
...@@ -20,6 +20,8 @@ struct clk *__of_clk_get_from_provider(struct of_phandle_args *clkspec, ...@@ -20,6 +20,8 @@ struct clk *__of_clk_get_from_provider(struct of_phandle_args *clkspec,
struct clk *__clk_create_clk(struct clk_hw *hw, const char *dev_id, struct clk *__clk_create_clk(struct clk_hw *hw, const char *dev_id,
const char *con_id); const char *con_id);
void __clk_free_clk(struct clk *clk); void __clk_free_clk(struct clk *clk);
int __clk_get(struct clk *clk);
void __clk_put(struct clk *clk);
#else #else
/* All these casts to avoid ifdefs in clkdev... */ /* All these casts to avoid ifdefs in clkdev... */
static inline struct clk * static inline struct clk *
...@@ -32,5 +34,7 @@ static struct clk_hw *__clk_get_hw(struct clk *clk) ...@@ -32,5 +34,7 @@ static struct clk_hw *__clk_get_hw(struct clk *clk)
{ {
return (struct clk_hw *)clk; return (struct clk_hw *)clk;
} }
static inline int __clk_get(struct clk *clk) { return 1; }
static inline void __clk_put(struct clk *clk) { }
#endif #endif
...@@ -256,7 +256,7 @@ vclkdev_alloc(struct clk_hw *hw, const char *con_id, const char *dev_fmt, ...@@ -256,7 +256,7 @@ vclkdev_alloc(struct clk_hw *hw, const char *con_id, const char *dev_fmt,
{ {
struct clk_lookup_alloc *cla; struct clk_lookup_alloc *cla;
cla = __clkdev_alloc(sizeof(*cla)); cla = kzalloc(sizeof(*cla), GFP_KERNEL);
if (!cla) if (!cla)
return NULL; return NULL;
......
...@@ -19,3 +19,11 @@ config COMMON_CLK_GXBB ...@@ -19,3 +19,11 @@ config COMMON_CLK_GXBB
help help
Support for the clock controller on AmLogic S905 devices, aka gxbb. Support for the clock controller on AmLogic S905 devices, aka gxbb.
Say Y if you want peripherals and CPU frequency scaling to work. Say Y if you want peripherals and CPU frequency scaling to work.
config COMMON_CLK_AXG
bool
depends on COMMON_CLK_AMLOGIC
select RESET_CONTROLLER
help
Support for the clock controller on AmLogic A113D devices, aka axg.
Say Y if you want peripherals and CPU frequency scaling to work.
...@@ -5,3 +5,4 @@ ...@@ -5,3 +5,4 @@
obj-$(CONFIG_COMMON_CLK_AMLOGIC) += clk-pll.o clk-cpu.o clk-mpll.o clk-audio-divider.o obj-$(CONFIG_COMMON_CLK_AMLOGIC) += clk-pll.o clk-cpu.o clk-mpll.o clk-audio-divider.o
obj-$(CONFIG_COMMON_CLK_MESON8B) += meson8b.o obj-$(CONFIG_COMMON_CLK_MESON8B) += meson8b.o
obj-$(CONFIG_COMMON_CLK_GXBB) += gxbb.o gxbb-aoclk.o gxbb-aoclk-regmap.o gxbb-aoclk-32k.o obj-$(CONFIG_COMMON_CLK_GXBB) += gxbb.o gxbb-aoclk.o gxbb-aoclk-regmap.o gxbb-aoclk-32k.o
obj-$(CONFIG_COMMON_CLK_AXG) += axg.o
This diff is collapsed.
/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
/*
* Copyright (c) 2016 AmLogic, Inc.
* Author: Michael Turquette <mturquette@baylibre.com>
*
* Copyright (c) 2017 Amlogic, inc.
* Author: Qiufang Dai <qiufang.dai@amlogic.com>
*
*/
#ifndef __AXG_H
#define __AXG_H
/*
* Clock controller register offsets
*
* Register offsets from the data sheet must be multiplied by 4 before
* adding them to the base address to get the right value.
*/
#define HHI_GP0_PLL_CNTL 0x40
#define HHI_GP0_PLL_CNTL2 0x44
#define HHI_GP0_PLL_CNTL3 0x48
#define HHI_GP0_PLL_CNTL4 0x4c
#define HHI_GP0_PLL_CNTL5 0x50
#define HHI_GP0_PLL_STS 0x54
#define HHI_GP0_PLL_CNTL1 0x58
#define HHI_HIFI_PLL_CNTL 0x80
#define HHI_HIFI_PLL_CNTL2 0x84
#define HHI_HIFI_PLL_CNTL3 0x88
#define HHI_HIFI_PLL_CNTL4 0x8C
#define HHI_HIFI_PLL_CNTL5 0x90
#define HHI_HIFI_PLL_STS 0x94
#define HHI_HIFI_PLL_CNTL1 0x98
#define HHI_XTAL_DIVN_CNTL 0xbc
#define HHI_GCLK2_MPEG0 0xc0
#define HHI_GCLK2_MPEG1 0xc4
#define HHI_GCLK2_MPEG2 0xc8
#define HHI_GCLK2_OTHER 0xd0
#define HHI_GCLK2_AO 0xd4
#define HHI_PCIE_PLL_CNTL 0xd8
#define HHI_PCIE_PLL_CNTL1 0xdC
#define HHI_PCIE_PLL_CNTL2 0xe0
#define HHI_PCIE_PLL_CNTL3 0xe4
#define HHI_PCIE_PLL_CNTL4 0xe8
#define HHI_PCIE_PLL_CNTL5 0xec
#define HHI_PCIE_PLL_CNTL6 0xf0
#define HHI_PCIE_PLL_STS 0xf4
#define HHI_MEM_PD_REG0 0x100
#define HHI_VPU_MEM_PD_REG0 0x104
#define HHI_VIID_CLK_DIV 0x128
#define HHI_VIID_CLK_CNTL 0x12c
#define HHI_GCLK_MPEG0 0x140
#define HHI_GCLK_MPEG1 0x144
#define HHI_GCLK_MPEG2 0x148
#define HHI_GCLK_OTHER 0x150
#define HHI_GCLK_AO 0x154
#define HHI_SYS_CPU_CLK_CNTL1 0x15c
#define HHI_SYS_CPU_RESET_CNTL 0x160
#define HHI_VID_CLK_DIV 0x164
#define HHI_SPICC_HCLK_CNTL 0x168
#define HHI_MPEG_CLK_CNTL 0x174
#define HHI_VID_CLK_CNTL 0x17c
#define HHI_TS_CLK_CNTL 0x190
#define HHI_VID_CLK_CNTL2 0x194
#define HHI_SYS_CPU_CLK_CNTL0 0x19c
#define HHI_VID_PLL_CLK_DIV 0x1a0
#define HHI_VPU_CLK_CNTL 0x1bC
#define HHI_VAPBCLK_CNTL 0x1F4
#define HHI_GEN_CLK_CNTL 0x228
#define HHI_VDIN_MEAS_CLK_CNTL 0x250
#define HHI_NAND_CLK_CNTL 0x25C
#define HHI_SD_EMMC_CLK_CNTL 0x264
#define HHI_MPLL_CNTL 0x280
#define HHI_MPLL_CNTL2 0x284
#define HHI_MPLL_CNTL3 0x288
#define HHI_MPLL_CNTL4 0x28C
#define HHI_MPLL_CNTL5 0x290
#define HHI_MPLL_CNTL6 0x294
#define HHI_MPLL_CNTL7 0x298
#define HHI_MPLL_CNTL8 0x29C
#define HHI_MPLL_CNTL9 0x2A0
#define HHI_MPLL_CNTL10 0x2A4
#define HHI_MPLL3_CNTL0 0x2E0
#define HHI_MPLL3_CNTL1 0x2E4
#define HHI_PLL_TOP_MISC 0x2E8
#define HHI_SYS_PLL_CNTL1 0x2FC
#define HHI_SYS_PLL_CNTL 0x300
#define HHI_SYS_PLL_CNTL2 0x304
#define HHI_SYS_PLL_CNTL3 0x308
#define HHI_SYS_PLL_CNTL4 0x30c
#define HHI_SYS_PLL_CNTL5 0x310
#define HHI_SYS_PLL_STS 0x314
#define HHI_DPLL_TOP_I 0x318
#define HHI_DPLL_TOP2_I 0x31C
/*
* CLKID index values
*
* These indices are entirely contrived and do not map onto the hardware.
* It has now been decided to expose everything by default in the DT header:
* include/dt-bindings/clock/axg-clkc.h. Only the clocks ids we don't want
* to expose, such as the internal muxes and dividers of composite clocks,
* will remain defined here.
*/
#define CLKID_MPEG_SEL 8
#define CLKID_MPEG_DIV 9
#define CLKID_SD_EMMC_B_CLK0_SEL 61
#define CLKID_SD_EMMC_B_CLK0_DIV 62
#define CLKID_SD_EMMC_C_CLK0_SEL 63
#define CLKID_SD_EMMC_C_CLK0_DIV 64
#define NR_CLKS 65
/* include the CLKIDs that have been made part of the DT binding */
#include <dt-bindings/clock/axg-clkc.h>
#endif /* __AXG_H */
...@@ -98,7 +98,7 @@ static void params_from_rate(unsigned long requested_rate, ...@@ -98,7 +98,7 @@ static void params_from_rate(unsigned long requested_rate,
*sdm = SDM_DEN - 1; *sdm = SDM_DEN - 1;
} else { } else {
*n2 = div; *n2 = div;
*sdm = DIV_ROUND_UP(rem * SDM_DEN, requested_rate); *sdm = DIV_ROUND_UP_ULL((u64)rem * SDM_DEN, requested_rate);
} }
} }
......
...@@ -134,7 +134,7 @@ struct meson_clk_audio_divider { ...@@ -134,7 +134,7 @@ struct meson_clk_audio_divider {
struct clk_gate _name = { \ struct clk_gate _name = { \
.reg = (void __iomem *) _reg, \ .reg = (void __iomem *) _reg, \
.bit_idx = (_bit), \ .bit_idx = (_bit), \
.lock = &clk_lock, \ .lock = &meson_clk_lock, \
.hw.init = &(struct clk_init_data) { \ .hw.init = &(struct clk_init_data) { \
.name = #_name, \ .name = #_name, \
.ops = &clk_gate_ops, \ .ops = &clk_gate_ops, \
......
This diff is collapsed.
...@@ -32,7 +32,7 @@ ...@@ -32,7 +32,7 @@
#include "clkc.h" #include "clkc.h"
#include "meson8b.h" #include "meson8b.h"
static DEFINE_SPINLOCK(clk_lock); static DEFINE_SPINLOCK(meson_clk_lock);
static void __iomem *clk_base; static void __iomem *clk_base;
...@@ -136,7 +136,7 @@ static struct meson_clk_pll meson8b_fixed_pll = { ...@@ -136,7 +136,7 @@ static struct meson_clk_pll meson8b_fixed_pll = {
.shift = 16, .shift = 16,
.width = 2, .width = 2,
}, },
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "fixed_pll", .name = "fixed_pll",
.ops = &meson_clk_pll_ro_ops, .ops = &meson_clk_pll_ro_ops,
...@@ -162,7 +162,7 @@ static struct meson_clk_pll meson8b_vid_pll = { ...@@ -162,7 +162,7 @@ static struct meson_clk_pll meson8b_vid_pll = {
.shift = 16, .shift = 16,
.width = 2, .width = 2,
}, },
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "vid_pll", .name = "vid_pll",
.ops = &meson_clk_pll_ro_ops, .ops = &meson_clk_pll_ro_ops,
...@@ -190,7 +190,7 @@ static struct meson_clk_pll meson8b_sys_pll = { ...@@ -190,7 +190,7 @@ static struct meson_clk_pll meson8b_sys_pll = {
}, },
.rate_table = sys_pll_rate_table, .rate_table = sys_pll_rate_table,
.rate_count = ARRAY_SIZE(sys_pll_rate_table), .rate_count = ARRAY_SIZE(sys_pll_rate_table),
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "sys_pll", .name = "sys_pll",
.ops = &meson_clk_pll_ops, .ops = &meson_clk_pll_ops,
...@@ -281,7 +281,7 @@ static struct meson_clk_mpll meson8b_mpll0 = { ...@@ -281,7 +281,7 @@ static struct meson_clk_mpll meson8b_mpll0 = {
.shift = 25, .shift = 25,
.width = 1, .width = 1,
}, },
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "mpll0", .name = "mpll0",
.ops = &meson_clk_mpll_ops, .ops = &meson_clk_mpll_ops,
...@@ -311,7 +311,7 @@ static struct meson_clk_mpll meson8b_mpll1 = { ...@@ -311,7 +311,7 @@ static struct meson_clk_mpll meson8b_mpll1 = {
.shift = 14, .shift = 14,
.width = 1, .width = 1,
}, },
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "mpll1", .name = "mpll1",
.ops = &meson_clk_mpll_ops, .ops = &meson_clk_mpll_ops,
...@@ -341,7 +341,7 @@ static struct meson_clk_mpll meson8b_mpll2 = { ...@@ -341,7 +341,7 @@ static struct meson_clk_mpll meson8b_mpll2 = {
.shift = 14, .shift = 14,
.width = 1, .width = 1,
}, },
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "mpll2", .name = "mpll2",
.ops = &meson_clk_mpll_ops, .ops = &meson_clk_mpll_ops,
...@@ -375,7 +375,7 @@ struct clk_mux meson8b_mpeg_clk_sel = { ...@@ -375,7 +375,7 @@ struct clk_mux meson8b_mpeg_clk_sel = {
.shift = 12, .shift = 12,
.flags = CLK_MUX_READ_ONLY, .flags = CLK_MUX_READ_ONLY,
.table = mux_table_clk81, .table = mux_table_clk81,
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "mpeg_clk_sel", .name = "mpeg_clk_sel",
.ops = &clk_mux_ro_ops, .ops = &clk_mux_ro_ops,
...@@ -395,7 +395,7 @@ struct clk_divider meson8b_mpeg_clk_div = { ...@@ -395,7 +395,7 @@ struct clk_divider meson8b_mpeg_clk_div = {
.reg = (void *)HHI_MPEG_CLK_CNTL, .reg = (void *)HHI_MPEG_CLK_CNTL,
.shift = 0, .shift = 0,
.width = 7, .width = 7,
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "mpeg_clk_div", .name = "mpeg_clk_div",
.ops = &clk_divider_ops, .ops = &clk_divider_ops,
...@@ -408,7 +408,7 @@ struct clk_divider meson8b_mpeg_clk_div = { ...@@ -408,7 +408,7 @@ struct clk_divider meson8b_mpeg_clk_div = {
struct clk_gate meson8b_clk81 = { struct clk_gate meson8b_clk81 = {
.reg = (void *)HHI_MPEG_CLK_CNTL, .reg = (void *)HHI_MPEG_CLK_CNTL,
.bit_idx = 7, .bit_idx = 7,
.lock = &clk_lock, .lock = &meson_clk_lock,
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "clk81", .name = "clk81",
.ops = &clk_gate_ops, .ops = &clk_gate_ops,
...@@ -773,7 +773,7 @@ static int meson8b_clk_reset_update(struct reset_controller_dev *rcdev, ...@@ -773,7 +773,7 @@ static int meson8b_clk_reset_update(struct reset_controller_dev *rcdev,
reset = &meson8b_clk_reset_bits[id]; reset = &meson8b_clk_reset_bits[id];
spin_lock_irqsave(&clk_lock, flags); spin_lock_irqsave(&meson_clk_lock, flags);
val = readl(meson8b_clk_reset->base + reset->reg); val = readl(meson8b_clk_reset->base + reset->reg);
if (assert) if (assert)
...@@ -782,7 +782,7 @@ static int meson8b_clk_reset_update(struct reset_controller_dev *rcdev, ...@@ -782,7 +782,7 @@ static int meson8b_clk_reset_update(struct reset_controller_dev *rcdev,
val &= ~BIT(reset->bit_idx); val &= ~BIT(reset->bit_idx);
writel(val, meson8b_clk_reset->base + reset->reg); writel(val, meson8b_clk_reset->base + reset->reg);
spin_unlock_irqrestore(&clk_lock, flags); spin_unlock_irqrestore(&meson_clk_lock, flags);
return 0; return 0;
} }
......
...@@ -341,7 +341,7 @@ void __init cpg_mstp_add_clk_domain(struct device_node *np) ...@@ -341,7 +341,7 @@ void __init cpg_mstp_add_clk_domain(struct device_node *np)
return; return;
pd->name = np->name; pd->name = np->name;
pd->flags = GENPD_FLAG_PM_CLK; pd->flags = GENPD_FLAG_PM_CLK | GENPD_FLAG_ACTIVE_WAKEUP;
pd->attach_dev = cpg_mstp_attach_dev; pd->attach_dev = cpg_mstp_attach_dev;
pd->detach_dev = cpg_mstp_detach_dev; pd->detach_dev = cpg_mstp_detach_dev;
pm_genpd_init(pd, &pm_domain_always_on_gov, false); pm_genpd_init(pd, &pm_domain_always_on_gov, false);
......
...@@ -115,6 +115,7 @@ static const struct cpg_core_clk r8a7796_core_clks[] __initconst = { ...@@ -115,6 +115,7 @@ static const struct cpg_core_clk r8a7796_core_clks[] __initconst = {
}; };
static const struct mssr_mod_clk r8a7796_mod_clks[] __initconst = { static const struct mssr_mod_clk r8a7796_mod_clks[] __initconst = {
DEF_MOD("fdp1-0", 119, R8A7796_CLK_S0D1),
DEF_MOD("scif5", 202, R8A7796_CLK_S3D4), DEF_MOD("scif5", 202, R8A7796_CLK_S3D4),
DEF_MOD("scif4", 203, R8A7796_CLK_S3D4), DEF_MOD("scif4", 203, R8A7796_CLK_S3D4),
DEF_MOD("scif3", 204, R8A7796_CLK_S3D4), DEF_MOD("scif3", 204, R8A7796_CLK_S3D4),
......
...@@ -105,6 +105,7 @@ static const struct mssr_mod_clk r8a77970_mod_clks[] __initconst = { ...@@ -105,6 +105,7 @@ static const struct mssr_mod_clk r8a77970_mod_clks[] __initconst = {
DEF_MOD("vspd0", 623, R8A77970_CLK_S2D1), DEF_MOD("vspd0", 623, R8A77970_CLK_S2D1),
DEF_MOD("csi40", 716, R8A77970_CLK_CSI0), DEF_MOD("csi40", 716, R8A77970_CLK_CSI0),
DEF_MOD("du0", 724, R8A77970_CLK_S2D1), DEF_MOD("du0", 724, R8A77970_CLK_S2D1),
DEF_MOD("lvds", 727, R8A77970_CLK_S2D1),
DEF_MOD("vin3", 808, R8A77970_CLK_S2D1), DEF_MOD("vin3", 808, R8A77970_CLK_S2D1),
DEF_MOD("vin2", 809, R8A77970_CLK_S2D1), DEF_MOD("vin2", 809, R8A77970_CLK_S2D1),
DEF_MOD("vin1", 810, R8A77970_CLK_S2D1), DEF_MOD("vin1", 810, R8A77970_CLK_S2D1),
......
...@@ -513,7 +513,7 @@ static int __init cpg_mssr_add_clk_domain(struct device *dev, ...@@ -513,7 +513,7 @@ static int __init cpg_mssr_add_clk_domain(struct device *dev,
genpd = &pd->genpd; genpd = &pd->genpd;
genpd->name = np->name; genpd->name = np->name;
genpd->flags = GENPD_FLAG_PM_CLK; genpd->flags = GENPD_FLAG_PM_CLK | GENPD_FLAG_ACTIVE_WAKEUP;
genpd->attach_dev = cpg_mssr_attach_dev; genpd->attach_dev = cpg_mssr_attach_dev;
genpd->detach_dev = cpg_mssr_detach_dev; genpd->detach_dev = cpg_mssr_detach_dev;
pm_genpd_init(genpd, &pm_domain_always_on_gov, false); pm_genpd_init(genpd, &pm_domain_always_on_gov, false);
......
...@@ -176,10 +176,10 @@ static const struct clk_ops clk_factors_ops = { ...@@ -176,10 +176,10 @@ static const struct clk_ops clk_factors_ops = {
.set_rate = clk_factors_set_rate, .set_rate = clk_factors_set_rate,
}; };
struct clk *sunxi_factors_register(struct device_node *node, static struct clk *__sunxi_factors_register(struct device_node *node,
const struct factors_data *data, const struct factors_data *data,
spinlock_t *lock, spinlock_t *lock, void __iomem *reg,
void __iomem *reg) unsigned long flags)
{ {
struct clk *clk; struct clk *clk;
struct clk_factors *factors; struct clk_factors *factors;
...@@ -249,7 +249,7 @@ struct clk *sunxi_factors_register(struct device_node *node, ...@@ -249,7 +249,7 @@ struct clk *sunxi_factors_register(struct device_node *node,
parents, i, parents, i,
mux_hw, &clk_mux_ops, mux_hw, &clk_mux_ops,
&factors->hw, &clk_factors_ops, &factors->hw, &clk_factors_ops,
gate_hw, &clk_gate_ops, 0); gate_hw, &clk_gate_ops, CLK_IS_CRITICAL);
if (IS_ERR(clk)) if (IS_ERR(clk))
goto err_register; goto err_register;
...@@ -272,6 +272,22 @@ struct clk *sunxi_factors_register(struct device_node *node, ...@@ -272,6 +272,22 @@ struct clk *sunxi_factors_register(struct device_node *node,
return NULL; return NULL;
} }
struct clk *sunxi_factors_register(struct device_node *node,
const struct factors_data *data,
spinlock_t *lock,
void __iomem *reg)
{
return __sunxi_factors_register(node, data, lock, reg, 0);
}
struct clk *sunxi_factors_register_critical(struct device_node *node,
const struct factors_data *data,
spinlock_t *lock,
void __iomem *reg)
{
return __sunxi_factors_register(node, data, lock, reg, CLK_IS_CRITICAL);
}
void sunxi_factors_unregister(struct device_node *node, struct clk *clk) void sunxi_factors_unregister(struct device_node *node, struct clk *clk)
{ {
struct clk_hw *hw = __clk_get_hw(clk); struct clk_hw *hw = __clk_get_hw(clk);
......
...@@ -55,6 +55,10 @@ struct clk *sunxi_factors_register(struct device_node *node, ...@@ -55,6 +55,10 @@ struct clk *sunxi_factors_register(struct device_node *node,
const struct factors_data *data, const struct factors_data *data,
spinlock_t *lock, spinlock_t *lock,
void __iomem *reg); void __iomem *reg);
struct clk *sunxi_factors_register_critical(struct device_node *node,
const struct factors_data *data,
spinlock_t *lock,
void __iomem *reg);
void sunxi_factors_unregister(struct device_node *node, struct clk *clk); void sunxi_factors_unregister(struct device_node *node, struct clk *clk);
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
*/ */
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/clkdev.h>
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
#include <linux/of_address.h> #include <linux/of_address.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
...@@ -155,7 +154,6 @@ static DEFINE_SPINLOCK(sun5i_a13_mbus_lock); ...@@ -155,7 +154,6 @@ static DEFINE_SPINLOCK(sun5i_a13_mbus_lock);
static void __init sun5i_a13_mbus_setup(struct device_node *node) static void __init sun5i_a13_mbus_setup(struct device_node *node)
{ {
struct clk *mbus;
void __iomem *reg; void __iomem *reg;
reg = of_iomap(node, 0); reg = of_iomap(node, 0);
...@@ -164,12 +162,9 @@ static void __init sun5i_a13_mbus_setup(struct device_node *node) ...@@ -164,12 +162,9 @@ static void __init sun5i_a13_mbus_setup(struct device_node *node)
return; return;
} }
mbus = sunxi_factors_register(node, &sun4i_a10_mod0_data,
&sun5i_a13_mbus_lock, reg);
/* The MBUS clocks needs to be always enabled */ /* The MBUS clocks needs to be always enabled */
__clk_get(mbus); sunxi_factors_register_critical(node, &sun4i_a10_mod0_data,
clk_prepare_enable(mbus); &sun5i_a13_mbus_lock, reg);
} }
CLK_OF_DECLARE(sun5i_a13_mbus, "allwinner,sun5i-a13-mbus-clk", sun5i_a13_mbus_setup); CLK_OF_DECLARE(sun5i_a13_mbus, "allwinner,sun5i-a13-mbus-clk", sun5i_a13_mbus_setup);
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
*/ */
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/clkdev.h>
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
...@@ -82,11 +81,12 @@ static void __init sun8i_a23_mbus_setup(struct device_node *node) ...@@ -82,11 +81,12 @@ static void __init sun8i_a23_mbus_setup(struct device_node *node)
mux->mask = SUN8I_MBUS_MUX_MASK; mux->mask = SUN8I_MBUS_MUX_MASK;
mux->lock = &sun8i_a23_mbus_lock; mux->lock = &sun8i_a23_mbus_lock;
/* The MBUS clocks needs to be always enabled */
clk = clk_register_composite(NULL, clk_name, parents, num_parents, clk = clk_register_composite(NULL, clk_name, parents, num_parents,
&mux->hw, &clk_mux_ops, &mux->hw, &clk_mux_ops,
&div->hw, &clk_divider_ops, &div->hw, &clk_divider_ops,
&gate->hw, &clk_gate_ops, &gate->hw, &clk_gate_ops,
0); CLK_IS_CRITICAL);
if (IS_ERR(clk)) if (IS_ERR(clk))
goto err_free_gate; goto err_free_gate;
...@@ -95,9 +95,6 @@ static void __init sun8i_a23_mbus_setup(struct device_node *node) ...@@ -95,9 +95,6 @@ static void __init sun8i_a23_mbus_setup(struct device_node *node)
goto err_unregister_clk; goto err_unregister_clk;
kfree(parents); /* parents is deep copied */ kfree(parents); /* parents is deep copied */
/* The MBUS clocks needs to be always enabled */
__clk_get(clk);
clk_prepare_enable(clk);
return; return;
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
*/ */
#include <linux/clk.h> #include <linux/clk.h>
#include <linux/clkdev.h>
#include <linux/clk-provider.h> #include <linux/clk-provider.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/of_address.h> #include <linux/of_address.h>
...@@ -140,7 +139,6 @@ static DEFINE_SPINLOCK(sun9i_a80_gt_lock); ...@@ -140,7 +139,6 @@ static DEFINE_SPINLOCK(sun9i_a80_gt_lock);
static void __init sun9i_a80_gt_setup(struct device_node *node) static void __init sun9i_a80_gt_setup(struct device_node *node)
{ {
void __iomem *reg; void __iomem *reg;
struct clk *gt;
reg = of_io_request_and_map(node, 0, of_node_full_name(node)); reg = of_io_request_and_map(node, 0, of_node_full_name(node));
if (IS_ERR(reg)) { if (IS_ERR(reg)) {
...@@ -149,12 +147,9 @@ static void __init sun9i_a80_gt_setup(struct device_node *node) ...@@ -149,12 +147,9 @@ static void __init sun9i_a80_gt_setup(struct device_node *node)
return; return;
} }
gt = sunxi_factors_register(node, &sun9i_a80_gt_data,
&sun9i_a80_gt_lock, reg);
/* The GT bus clock needs to be always enabled */ /* The GT bus clock needs to be always enabled */
__clk_get(gt); sunxi_factors_register_critical(node, &sun9i_a80_gt_data,
clk_prepare_enable(gt); &sun9i_a80_gt_lock, reg);
} }
CLK_OF_DECLARE(sun9i_a80_gt, "allwinner,sun9i-a80-gt-clk", sun9i_a80_gt_setup); CLK_OF_DECLARE(sun9i_a80_gt, "allwinner,sun9i-a80-gt-clk", sun9i_a80_gt_setup);
......
...@@ -656,7 +656,8 @@ static const struct mux_data sun8i_h3_ahb2_mux_data __initconst = { ...@@ -656,7 +656,8 @@ static const struct mux_data sun8i_h3_ahb2_mux_data __initconst = {
}; };
static struct clk * __init sunxi_mux_clk_setup(struct device_node *node, static struct clk * __init sunxi_mux_clk_setup(struct device_node *node,
const struct mux_data *data) const struct mux_data *data,
unsigned long flags)
{ {
struct clk *clk; struct clk *clk;
const char *clk_name = node->name; const char *clk_name = node->name;
...@@ -678,7 +679,7 @@ static struct clk * __init sunxi_mux_clk_setup(struct device_node *node, ...@@ -678,7 +679,7 @@ static struct clk * __init sunxi_mux_clk_setup(struct device_node *node,
} }
clk = clk_register_mux(NULL, clk_name, parents, i, clk = clk_register_mux(NULL, clk_name, parents, i,
CLK_SET_RATE_PARENT, reg, CLK_SET_RATE_PARENT | flags, reg,
data->shift, SUNXI_MUX_GATE_WIDTH, data->shift, SUNXI_MUX_GATE_WIDTH,
0, &clk_lock); 0, &clk_lock);
...@@ -703,29 +704,22 @@ static struct clk * __init sunxi_mux_clk_setup(struct device_node *node, ...@@ -703,29 +704,22 @@ static struct clk * __init sunxi_mux_clk_setup(struct device_node *node,
static void __init sun4i_cpu_clk_setup(struct device_node *node) static void __init sun4i_cpu_clk_setup(struct device_node *node)
{ {
struct clk *clk;
clk = sunxi_mux_clk_setup(node, &sun4i_cpu_mux_data);
if (!clk)
return;
/* Protect CPU clock */ /* Protect CPU clock */
__clk_get(clk); sunxi_mux_clk_setup(node, &sun4i_cpu_mux_data, CLK_IS_CRITICAL);
clk_prepare_enable(clk);
} }
CLK_OF_DECLARE(sun4i_cpu, "allwinner,sun4i-a10-cpu-clk", CLK_OF_DECLARE(sun4i_cpu, "allwinner,sun4i-a10-cpu-clk",
sun4i_cpu_clk_setup); sun4i_cpu_clk_setup);
static void __init sun6i_ahb1_mux_clk_setup(struct device_node *node) static void __init sun6i_ahb1_mux_clk_setup(struct device_node *node)
{ {
sunxi_mux_clk_setup(node, &sun6i_a31_ahb1_mux_data); sunxi_mux_clk_setup(node, &sun6i_a31_ahb1_mux_data, 0);
} }
CLK_OF_DECLARE(sun6i_ahb1_mux, "allwinner,sun6i-a31-ahb1-mux-clk", CLK_OF_DECLARE(sun6i_ahb1_mux, "allwinner,sun6i-a31-ahb1-mux-clk",
sun6i_ahb1_mux_clk_setup); sun6i_ahb1_mux_clk_setup);
static void __init sun8i_ahb2_clk_setup(struct device_node *node) static void __init sun8i_ahb2_clk_setup(struct device_node *node)
{ {
sunxi_mux_clk_setup(node, &sun8i_h3_ahb2_mux_data); sunxi_mux_clk_setup(node, &sun8i_h3_ahb2_mux_data, 0);
} }
CLK_OF_DECLARE(sun8i_ahb2, "allwinner,sun8i-h3-ahb2-clk", CLK_OF_DECLARE(sun8i_ahb2, "allwinner,sun8i-h3-ahb2-clk",
sun8i_ahb2_clk_setup); sun8i_ahb2_clk_setup);
...@@ -900,6 +894,7 @@ struct divs_data { ...@@ -900,6 +894,7 @@ struct divs_data {
u8 shift; /* otherwise it's a normal divisor with this shift */ u8 shift; /* otherwise it's a normal divisor with this shift */
u8 pow; /* is it power-of-two based? */ u8 pow; /* is it power-of-two based? */
u8 gate; /* is it independently gateable? */ u8 gate; /* is it independently gateable? */
bool critical;
} div[SUNXI_DIVS_MAX_QTY]; } div[SUNXI_DIVS_MAX_QTY];
}; };
...@@ -915,7 +910,8 @@ static const struct divs_data pll5_divs_data __initconst = { ...@@ -915,7 +910,8 @@ static const struct divs_data pll5_divs_data __initconst = {
.factors = &sun4i_pll5_data, .factors = &sun4i_pll5_data,
.ndivs = 2, .ndivs = 2,
.div = { .div = {
{ .shift = 0, .pow = 0, }, /* M, DDR */ /* Protect PLL5_DDR */
{ .shift = 0, .pow = 0, .critical = true }, /* M, DDR */
{ .shift = 16, .pow = 1, }, /* P, other */ { .shift = 16, .pow = 1, }, /* P, other */
/* No output for the base factor clock */ /* No output for the base factor clock */
} }
...@@ -1089,7 +1085,9 @@ static struct clk ** __init sunxi_divs_clk_setup(struct device_node *node, ...@@ -1089,7 +1085,9 @@ static struct clk ** __init sunxi_divs_clk_setup(struct device_node *node,
NULL, NULL, NULL, NULL,
rate_hw, rate_ops, rate_hw, rate_ops,
gate_hw, &clk_gate_ops, gate_hw, &clk_gate_ops,
clkflags); clkflags |
data->div[i].critical ?
CLK_IS_CRITICAL : 0);
WARN_ON(IS_ERR(clk_data->clks[i])); WARN_ON(IS_ERR(clk_data->clks[i]));
} }
...@@ -1117,15 +1115,7 @@ static struct clk ** __init sunxi_divs_clk_setup(struct device_node *node, ...@@ -1117,15 +1115,7 @@ static struct clk ** __init sunxi_divs_clk_setup(struct device_node *node,
static void __init sun4i_pll5_clk_setup(struct device_node *node) static void __init sun4i_pll5_clk_setup(struct device_node *node)
{ {
struct clk **clks; sunxi_divs_clk_setup(node, &pll5_divs_data);
clks = sunxi_divs_clk_setup(node, &pll5_divs_data);
if (!clks)
return;
/* Protect PLL5_DDR */
__clk_get(clks[0]);
clk_prepare_enable(clks[0]);
} }
CLK_OF_DECLARE(sun4i_pll5, "allwinner,sun4i-a10-pll5-clk", CLK_OF_DECLARE(sun4i_pll5, "allwinner,sun4i-a10-pll5-clk",
sun4i_pll5_clk_setup); sun4i_pll5_clk_setup);
......
/*
* include/asm-generic/clkdev.h
*
* Based on the ARM clkdev.h:
* Copyright (C) 2008 Russell King.
*
* 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.
*
* Helper for the clk API to assist looking up a struct clk.
*/
#ifndef __ASM_CLKDEV_H
#define __ASM_CLKDEV_H
#include <linux/slab.h>
#ifndef CONFIG_COMMON_CLK
struct clk;
static inline int __clk_get(struct clk *clk) { return 1; }
static inline void __clk_put(struct clk *clk) { }
#endif
static inline struct clk_lookup_alloc *__clkdev_alloc(size_t size)
{
return kzalloc(size, GFP_KERNEL);
}
#endif
/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
/*
* Meson-AXG clock tree IDs
*
* Copyright (c) 2017 Amlogic, Inc. All rights reserved.
*/
#ifndef __AXG_CLKC_H
#define __AXG_CLKC_H
#define CLKID_SYS_PLL 0
#define CLKID_FIXED_PLL 1
#define CLKID_FCLK_DIV2 2
#define CLKID_FCLK_DIV3 3
#define CLKID_FCLK_DIV4 4
#define CLKID_FCLK_DIV5 5
#define CLKID_FCLK_DIV7 6
#define CLKID_GP0_PLL 7
#define CLKID_CLK81 10
#define CLKID_MPLL0 11
#define CLKID_MPLL1 12
#define CLKID_MPLL2 13
#define CLKID_MPLL3 14
#define CLKID_DDR 15
#define CLKID_AUDIO_LOCKER 16
#define CLKID_MIPI_DSI_HOST 17
#define CLKID_ISA 18
#define CLKID_PL301 19
#define CLKID_PERIPHS 20
#define CLKID_SPICC0 21
#define CLKID_I2C 22
#define CLKID_RNG0 23
#define CLKID_UART0 24
#define CLKID_MIPI_DSI_PHY 25
#define CLKID_SPICC1 26
#define CLKID_PCIE_A 27
#define CLKID_PCIE_B 28
#define CLKID_HIU_IFACE 29
#define CLKID_ASSIST_MISC 30
#define CLKID_SD_EMMC_B 31
#define CLKID_SD_EMMC_C 32
#define CLKID_DMA 33
#define CLKID_SPI 34
#define CLKID_AUDIO 35
#define CLKID_ETH 36
#define CLKID_UART1 37
#define CLKID_G2D 38
#define CLKID_USB0 39
#define CLKID_USB1 40
#define CLKID_RESET 41
#define CLKID_USB 42
#define CLKID_AHB_ARB0 43
#define CLKID_EFUSE 44
#define CLKID_BOOT_ROM 45
#define CLKID_AHB_DATA_BUS 46
#define CLKID_AHB_CTRL_BUS 47
#define CLKID_USB1_DDR_BRIDGE 48
#define CLKID_USB0_DDR_BRIDGE 49
#define CLKID_MMC_PCLK 50
#define CLKID_VPU_INTR 51
#define CLKID_SEC_AHB_AHB3_BRIDGE 52
#define CLKID_GIC 53
#define CLKID_AO_MEDIA_CPU 54
#define CLKID_AO_AHB_SRAM 55
#define CLKID_AO_AHB_BUS 56
#define CLKID_AO_IFACE 57
#define CLKID_AO_I2C 58
#define CLKID_SD_EMMC_B_CLK0 59
#define CLKID_SD_EMMC_C_CLK0 60
#endif /* __AXG_CLKC_H */
...@@ -20,6 +20,8 @@ ...@@ -20,6 +20,8 @@
* flags used across common struct clk. these flags should only affect the * flags used across common struct clk. these flags should only affect the
* top-level framework. custom flags for dealing with hardware specifics * top-level framework. custom flags for dealing with hardware specifics
* belong in struct clk_foo * belong in struct clk_foo
*
* Please update clk_flags[] in drivers/clk/clk.c when making changes here!
*/ */
#define CLK_SET_RATE_GATE BIT(0) /* must be gated across rate change */ #define CLK_SET_RATE_GATE BIT(0) /* must be gated across rate change */
#define CLK_SET_PARENT_GATE BIT(1) /* must be gated across re-parent */ #define CLK_SET_PARENT_GATE BIT(1) /* must be gated across re-parent */
......
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
#ifndef __CLKDEV_H #ifndef __CLKDEV_H
#define __CLKDEV_H #define __CLKDEV_H
#include <asm/clkdev.h> #include <linux/slab.h>
struct clk; struct clk;
struct clk_hw; struct clk_hw;
...@@ -52,9 +52,4 @@ int clk_add_alias(const char *, const char *, const char *, struct device *); ...@@ -52,9 +52,4 @@ int clk_add_alias(const char *, const char *, const char *, struct device *);
int clk_register_clkdev(struct clk *, const char *, const char *); int clk_register_clkdev(struct clk *, const char *, const char *);
int clk_hw_register_clkdev(struct clk_hw *, const char *, const char *); int clk_hw_register_clkdev(struct clk_hw *, const char *, const char *);
#ifdef CONFIG_COMMON_CLK
int __clk_get(struct clk *clk);
void __clk_put(struct clk *clk);
#endif
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment