| .. | .. |
|---|
| 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 |
|---|