.. | .. |
---|
71 | 71 | * @freq_tbl: frequency table |
---|
72 | 72 | * @clkr: regmap clock handle |
---|
73 | 73 | * @lock: register lock |
---|
74 | | - * |
---|
75 | 74 | */ |
---|
76 | 75 | struct clk_rcg { |
---|
77 | 76 | u32 ns_reg; |
---|
.. | .. |
---|
107 | 106 | * @freq_tbl: frequency table |
---|
108 | 107 | * @clkr: regmap clock handle |
---|
109 | 108 | * @lock: register lock |
---|
110 | | - * |
---|
111 | 109 | */ |
---|
112 | 110 | struct clk_dyn_rcg { |
---|
113 | 111 | u32 ns_reg[2]; |
---|
.. | .. |
---|
140 | 138 | * @parent_map: map from software's parent index to hardware's src_sel field |
---|
141 | 139 | * @freq_tbl: frequency table |
---|
142 | 140 | * @clkr: regmap clock handle |
---|
143 | | - * |
---|
| 141 | + * @cfg_off: defines the cfg register offset from the CMD_RCGR + CFG_REG |
---|
144 | 142 | */ |
---|
145 | 143 | struct clk_rcg2 { |
---|
146 | 144 | u32 cmd_rcgr; |
---|
.. | .. |
---|
150 | 148 | const struct parent_map *parent_map; |
---|
151 | 149 | const struct freq_tbl *freq_tbl; |
---|
152 | 150 | struct clk_regmap clkr; |
---|
| 151 | + u8 cfg_off; |
---|
153 | 152 | }; |
---|
154 | 153 | |
---|
155 | 154 | #define to_clk_rcg2(_hw) container_of(to_clk_regmap(_hw), struct clk_rcg2, clkr) |
---|
.. | .. |
---|
162 | 161 | extern const struct clk_ops clk_pixel_ops; |
---|
163 | 162 | extern const struct clk_ops clk_gfx3d_ops; |
---|
164 | 163 | extern const struct clk_ops clk_rcg2_shared_ops; |
---|
| 164 | +extern const struct clk_ops clk_dp_ops; |
---|
165 | 165 | |
---|
| 166 | +struct clk_rcg_dfs_data { |
---|
| 167 | + struct clk_rcg2 *rcg; |
---|
| 168 | + struct clk_init_data *init; |
---|
| 169 | +}; |
---|
| 170 | + |
---|
| 171 | +#define DEFINE_RCG_DFS(r) \ |
---|
| 172 | + { .rcg = &r, .init = &r##_init } |
---|
| 173 | + |
---|
| 174 | +extern int qcom_cc_register_rcg_dfs(struct regmap *regmap, |
---|
| 175 | + const struct clk_rcg_dfs_data *rcgs, |
---|
| 176 | + size_t len); |
---|
166 | 177 | #endif |
---|