Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
clk-gate2.c
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2010-2011 Canonical Ltd <[email protected]>
3  * Copyright (C) 2011-2012 Mike Turquette, Linaro Ltd <[email protected]>
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation.
8  *
9  * Gated clock implementation
10  */
11 
12 #include <linux/clk-provider.h>
13 #include <linux/module.h>
14 #include <linux/slab.h>
15 #include <linux/io.h>
16 #include <linux/err.h>
17 #include <linux/string.h>
18 
29 #define to_clk_gate(_hw) container_of(_hw, struct clk_gate, hw)
30 
31 static int clk_gate2_enable(struct clk_hw *hw)
32 {
33  struct clk_gate *gate = to_clk_gate(hw);
34  u32 reg;
35  unsigned long flags = 0;
36 
37  if (gate->lock)
38  spin_lock_irqsave(gate->lock, flags);
39 
40  reg = readl(gate->reg);
41  reg |= 3 << gate->bit_idx;
42  writel(reg, gate->reg);
43 
44  if (gate->lock)
45  spin_unlock_irqrestore(gate->lock, flags);
46 
47  return 0;
48 }
49 
50 static void clk_gate2_disable(struct clk_hw *hw)
51 {
52  struct clk_gate *gate = to_clk_gate(hw);
53  u32 reg;
54  unsigned long flags = 0;
55 
56  if (gate->lock)
57  spin_lock_irqsave(gate->lock, flags);
58 
59  reg = readl(gate->reg);
60  reg &= ~(3 << gate->bit_idx);
61  writel(reg, gate->reg);
62 
63  if (gate->lock)
64  spin_unlock_irqrestore(gate->lock, flags);
65 }
66 
67 static int clk_gate2_is_enabled(struct clk_hw *hw)
68 {
69  u32 reg;
70  struct clk_gate *gate = to_clk_gate(hw);
71 
72  reg = readl(gate->reg);
73 
74  if (((reg >> gate->bit_idx) & 3) == 3)
75  return 1;
76 
77  return 0;
78 }
79 
80 static struct clk_ops clk_gate2_ops = {
81  .enable = clk_gate2_enable,
82  .disable = clk_gate2_disable,
83  .is_enabled = clk_gate2_is_enabled,
84 };
85 
86 struct clk *clk_register_gate2(struct device *dev, const char *name,
87  const char *parent_name, unsigned long flags,
88  void __iomem *reg, u8 bit_idx,
89  u8 clk_gate2_flags, spinlock_t *lock)
90 {
91  struct clk_gate *gate;
92  struct clk *clk;
93  struct clk_init_data init;
94 
95  gate = kzalloc(sizeof(struct clk_gate), GFP_KERNEL);
96  if (!gate)
97  return ERR_PTR(-ENOMEM);
98 
99  /* struct clk_gate assignments */
100  gate->reg = reg;
101  gate->bit_idx = bit_idx;
102  gate->flags = clk_gate2_flags;
103  gate->lock = lock;
104 
105  init.name = name;
106  init.ops = &clk_gate2_ops;
107  init.flags = flags;
108  init.parent_names = parent_name ? &parent_name : NULL;
109  init.num_parents = parent_name ? 1 : 0;
110 
111  gate->hw.init = &init;
112 
113  clk = clk_register(dev, &gate->hw);
114  if (IS_ERR(clk))
115  kfree(gate);
116 
117  return clk;
118 }