diff options
author | Laurent Pinchart <laurent.pinchart@ideasonboard.com> | 2012-10-22 10:40:56 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2012-10-29 07:51:00 -0400 |
commit | 6ec84a28f5f40e3ebef5d8186c4b11b10aa295d7 (patch) | |
tree | 298d63522cd5b4db692f1b1e48691ed74d6f76d2 | |
parent | f5984bbdf402b586581bc292a5449f17ce4b8209 (diff) |
[media] smiapp-pll: Create a structure for OP and VT limits
OP and VT limits have identical fields, create a shared structure for
both.
Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: Sakari Ailus <sakari.ailus@iki.fi>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r-- | drivers/media/i2c/smiapp-pll.c | 54 | ||||
-rw-r--r-- | drivers/media/i2c/smiapp-pll.h | 30 | ||||
-rw-r--r-- | drivers/media/i2c/smiapp/smiapp-core.c | 43 |
3 files changed, 58 insertions, 69 deletions
diff --git a/drivers/media/i2c/smiapp-pll.c b/drivers/media/i2c/smiapp-pll.c index d3243602c77a..cbef446180f8 100644 --- a/drivers/media/i2c/smiapp-pll.c +++ b/drivers/media/i2c/smiapp-pll.c | |||
@@ -122,7 +122,7 @@ static int __smiapp_pll_calculate(struct device *dev, | |||
122 | more_mul_max); | 122 | more_mul_max); |
123 | /* Don't go above the division capability of op sys clock divider. */ | 123 | /* Don't go above the division capability of op sys clock divider. */ |
124 | more_mul_max = min(more_mul_max, | 124 | more_mul_max = min(more_mul_max, |
125 | limits->max_op_sys_clk_div * pll->pre_pll_clk_div | 125 | limits->op.max_sys_clk_div * pll->pre_pll_clk_div |
126 | / div); | 126 | / div); |
127 | dev_dbg(dev, "more_mul_max: max_op_sys_clk_div check: %d\n", | 127 | dev_dbg(dev, "more_mul_max: max_op_sys_clk_div check: %d\n", |
128 | more_mul_max); | 128 | more_mul_max); |
@@ -152,7 +152,7 @@ static int __smiapp_pll_calculate(struct device *dev, | |||
152 | 152 | ||
153 | more_mul_factor = lcm(div, pll->pre_pll_clk_div) / div; | 153 | more_mul_factor = lcm(div, pll->pre_pll_clk_div) / div; |
154 | dev_dbg(dev, "more_mul_factor: %d\n", more_mul_factor); | 154 | dev_dbg(dev, "more_mul_factor: %d\n", more_mul_factor); |
155 | more_mul_factor = lcm(more_mul_factor, limits->min_op_sys_clk_div); | 155 | more_mul_factor = lcm(more_mul_factor, limits->op.min_sys_clk_div); |
156 | dev_dbg(dev, "more_mul_factor: min_op_sys_clk_div: %d\n", | 156 | dev_dbg(dev, "more_mul_factor: min_op_sys_clk_div: %d\n", |
157 | more_mul_factor); | 157 | more_mul_factor); |
158 | i = roundup(more_mul_min, more_mul_factor); | 158 | i = roundup(more_mul_min, more_mul_factor); |
@@ -220,19 +220,19 @@ static int __smiapp_pll_calculate(struct device *dev, | |||
220 | dev_dbg(dev, "min_vt_div: %d\n", min_vt_div); | 220 | dev_dbg(dev, "min_vt_div: %d\n", min_vt_div); |
221 | min_vt_div = max(min_vt_div, | 221 | min_vt_div = max(min_vt_div, |
222 | DIV_ROUND_UP(pll->pll_op_clk_freq_hz, | 222 | DIV_ROUND_UP(pll->pll_op_clk_freq_hz, |
223 | limits->max_vt_pix_clk_freq_hz)); | 223 | limits->vt.max_pix_clk_freq_hz)); |
224 | dev_dbg(dev, "min_vt_div: max_vt_pix_clk_freq_hz: %d\n", | 224 | dev_dbg(dev, "min_vt_div: max_vt_pix_clk_freq_hz: %d\n", |
225 | min_vt_div); | 225 | min_vt_div); |
226 | min_vt_div = max_t(uint32_t, min_vt_div, | 226 | min_vt_div = max_t(uint32_t, min_vt_div, |
227 | limits->min_vt_pix_clk_div | 227 | limits->vt.min_pix_clk_div |
228 | * limits->min_vt_sys_clk_div); | 228 | * limits->vt.min_sys_clk_div); |
229 | dev_dbg(dev, "min_vt_div: min_vt_clk_div: %d\n", min_vt_div); | 229 | dev_dbg(dev, "min_vt_div: min_vt_clk_div: %d\n", min_vt_div); |
230 | 230 | ||
231 | max_vt_div = limits->max_vt_sys_clk_div * limits->max_vt_pix_clk_div; | 231 | max_vt_div = limits->vt.max_sys_clk_div * limits->vt.max_pix_clk_div; |
232 | dev_dbg(dev, "max_vt_div: %d\n", max_vt_div); | 232 | dev_dbg(dev, "max_vt_div: %d\n", max_vt_div); |
233 | max_vt_div = min(max_vt_div, | 233 | max_vt_div = min(max_vt_div, |
234 | DIV_ROUND_UP(pll->pll_op_clk_freq_hz, | 234 | DIV_ROUND_UP(pll->pll_op_clk_freq_hz, |
235 | limits->min_vt_pix_clk_freq_hz)); | 235 | limits->vt.min_pix_clk_freq_hz)); |
236 | dev_dbg(dev, "max_vt_div: min_vt_pix_clk_freq_hz: %d\n", | 236 | dev_dbg(dev, "max_vt_div: min_vt_pix_clk_freq_hz: %d\n", |
237 | max_vt_div); | 237 | max_vt_div); |
238 | 238 | ||
@@ -240,28 +240,28 @@ static int __smiapp_pll_calculate(struct device *dev, | |||
240 | * Find limitsits for sys_clk_div. Not all values are possible | 240 | * Find limitsits for sys_clk_div. Not all values are possible |
241 | * with all values of pix_clk_div. | 241 | * with all values of pix_clk_div. |
242 | */ | 242 | */ |
243 | min_sys_div = limits->min_vt_sys_clk_div; | 243 | min_sys_div = limits->vt.min_sys_clk_div; |
244 | dev_dbg(dev, "min_sys_div: %d\n", min_sys_div); | 244 | dev_dbg(dev, "min_sys_div: %d\n", min_sys_div); |
245 | min_sys_div = max(min_sys_div, | 245 | min_sys_div = max(min_sys_div, |
246 | DIV_ROUND_UP(min_vt_div, | 246 | DIV_ROUND_UP(min_vt_div, |
247 | limits->max_vt_pix_clk_div)); | 247 | limits->vt.max_pix_clk_div)); |
248 | dev_dbg(dev, "min_sys_div: max_vt_pix_clk_div: %d\n", min_sys_div); | 248 | dev_dbg(dev, "min_sys_div: max_vt_pix_clk_div: %d\n", min_sys_div); |
249 | min_sys_div = max(min_sys_div, | 249 | min_sys_div = max(min_sys_div, |
250 | pll->pll_op_clk_freq_hz | 250 | pll->pll_op_clk_freq_hz |
251 | / limits->max_vt_sys_clk_freq_hz); | 251 | / limits->vt.max_sys_clk_freq_hz); |
252 | dev_dbg(dev, "min_sys_div: max_pll_op_clk_freq_hz: %d\n", min_sys_div); | 252 | dev_dbg(dev, "min_sys_div: max_pll_op_clk_freq_hz: %d\n", min_sys_div); |
253 | min_sys_div = clk_div_even_up(min_sys_div); | 253 | min_sys_div = clk_div_even_up(min_sys_div); |
254 | dev_dbg(dev, "min_sys_div: one or even: %d\n", min_sys_div); | 254 | dev_dbg(dev, "min_sys_div: one or even: %d\n", min_sys_div); |
255 | 255 | ||
256 | max_sys_div = limits->max_vt_sys_clk_div; | 256 | max_sys_div = limits->vt.max_sys_clk_div; |
257 | dev_dbg(dev, "max_sys_div: %d\n", max_sys_div); | 257 | dev_dbg(dev, "max_sys_div: %d\n", max_sys_div); |
258 | max_sys_div = min(max_sys_div, | 258 | max_sys_div = min(max_sys_div, |
259 | DIV_ROUND_UP(max_vt_div, | 259 | DIV_ROUND_UP(max_vt_div, |
260 | limits->min_vt_pix_clk_div)); | 260 | limits->vt.min_pix_clk_div)); |
261 | dev_dbg(dev, "max_sys_div: min_vt_pix_clk_div: %d\n", max_sys_div); | 261 | dev_dbg(dev, "max_sys_div: min_vt_pix_clk_div: %d\n", max_sys_div); |
262 | max_sys_div = min(max_sys_div, | 262 | max_sys_div = min(max_sys_div, |
263 | DIV_ROUND_UP(pll->pll_op_clk_freq_hz, | 263 | DIV_ROUND_UP(pll->pll_op_clk_freq_hz, |
264 | limits->min_vt_pix_clk_freq_hz)); | 264 | limits->vt.min_pix_clk_freq_hz)); |
265 | dev_dbg(dev, "max_sys_div: min_vt_pix_clk_freq_hz: %d\n", max_sys_div); | 265 | dev_dbg(dev, "max_sys_div: min_vt_pix_clk_freq_hz: %d\n", max_sys_div); |
266 | 266 | ||
267 | /* | 267 | /* |
@@ -276,13 +276,13 @@ static int __smiapp_pll_calculate(struct device *dev, | |||
276 | sys_div += 2 - (sys_div & 1)) { | 276 | sys_div += 2 - (sys_div & 1)) { |
277 | uint16_t pix_div = DIV_ROUND_UP(vt_div, sys_div); | 277 | uint16_t pix_div = DIV_ROUND_UP(vt_div, sys_div); |
278 | 278 | ||
279 | if (pix_div < limits->min_vt_pix_clk_div | 279 | if (pix_div < limits->vt.min_pix_clk_div |
280 | || pix_div > limits->max_vt_pix_clk_div) { | 280 | || pix_div > limits->vt.max_pix_clk_div) { |
281 | dev_dbg(dev, | 281 | dev_dbg(dev, |
282 | "pix_div %d too small or too big (%d--%d)\n", | 282 | "pix_div %d too small or too big (%d--%d)\n", |
283 | pix_div, | 283 | pix_div, |
284 | limits->min_vt_pix_clk_div, | 284 | limits->vt.min_pix_clk_div, |
285 | limits->max_vt_pix_clk_div); | 285 | limits->vt.max_pix_clk_div); |
286 | continue; | 286 | continue; |
287 | } | 287 | } |
288 | 288 | ||
@@ -327,36 +327,36 @@ static int __smiapp_pll_calculate(struct device *dev, | |||
327 | if (!rval) | 327 | if (!rval) |
328 | rval = bounds_check( | 328 | rval = bounds_check( |
329 | dev, pll->op_sys_clk_div, | 329 | dev, pll->op_sys_clk_div, |
330 | limits->min_op_sys_clk_div, limits->max_op_sys_clk_div, | 330 | limits->op.min_sys_clk_div, limits->op.max_sys_clk_div, |
331 | "op_sys_clk_div"); | 331 | "op_sys_clk_div"); |
332 | if (!rval) | 332 | if (!rval) |
333 | rval = bounds_check( | 333 | rval = bounds_check( |
334 | dev, pll->op_pix_clk_div, | 334 | dev, pll->op_pix_clk_div, |
335 | limits->min_op_pix_clk_div, limits->max_op_pix_clk_div, | 335 | limits->op.min_pix_clk_div, limits->op.max_pix_clk_div, |
336 | "op_pix_clk_div"); | 336 | "op_pix_clk_div"); |
337 | if (!rval) | 337 | if (!rval) |
338 | rval = bounds_check( | 338 | rval = bounds_check( |
339 | dev, pll->op_sys_clk_freq_hz, | 339 | dev, pll->op_sys_clk_freq_hz, |
340 | limits->min_op_sys_clk_freq_hz, | 340 | limits->op.min_sys_clk_freq_hz, |
341 | limits->max_op_sys_clk_freq_hz, | 341 | limits->op.max_sys_clk_freq_hz, |
342 | "op_sys_clk_freq_hz"); | 342 | "op_sys_clk_freq_hz"); |
343 | if (!rval) | 343 | if (!rval) |
344 | rval = bounds_check( | 344 | rval = bounds_check( |
345 | dev, pll->op_pix_clk_freq_hz, | 345 | dev, pll->op_pix_clk_freq_hz, |
346 | limits->min_op_pix_clk_freq_hz, | 346 | limits->op.min_pix_clk_freq_hz, |
347 | limits->max_op_pix_clk_freq_hz, | 347 | limits->op.max_pix_clk_freq_hz, |
348 | "op_pix_clk_freq_hz"); | 348 | "op_pix_clk_freq_hz"); |
349 | if (!rval) | 349 | if (!rval) |
350 | rval = bounds_check( | 350 | rval = bounds_check( |
351 | dev, pll->vt_sys_clk_freq_hz, | 351 | dev, pll->vt_sys_clk_freq_hz, |
352 | limits->min_vt_sys_clk_freq_hz, | 352 | limits->vt.min_sys_clk_freq_hz, |
353 | limits->max_vt_sys_clk_freq_hz, | 353 | limits->vt.max_sys_clk_freq_hz, |
354 | "vt_sys_clk_freq_hz"); | 354 | "vt_sys_clk_freq_hz"); |
355 | if (!rval) | 355 | if (!rval) |
356 | rval = bounds_check( | 356 | rval = bounds_check( |
357 | dev, pll->vt_pix_clk_freq_hz, | 357 | dev, pll->vt_pix_clk_freq_hz, |
358 | limits->min_vt_pix_clk_freq_hz, | 358 | limits->vt.min_pix_clk_freq_hz, |
359 | limits->max_vt_pix_clk_freq_hz, | 359 | limits->vt.max_pix_clk_freq_hz, |
360 | "vt_pix_clk_freq_hz"); | 360 | "vt_pix_clk_freq_hz"); |
361 | 361 | ||
362 | return rval; | 362 | return rval; |
diff --git a/drivers/media/i2c/smiapp-pll.h b/drivers/media/i2c/smiapp-pll.h index 439fe5d665b0..8500e6e562bb 100644 --- a/drivers/media/i2c/smiapp-pll.h +++ b/drivers/media/i2c/smiapp-pll.h | |||
@@ -73,6 +73,17 @@ struct smiapp_pll { | |||
73 | uint32_t pixel_rate_csi; | 73 | uint32_t pixel_rate_csi; |
74 | }; | 74 | }; |
75 | 75 | ||
76 | struct smiapp_pll_branch_limits { | ||
77 | uint16_t min_sys_clk_div; | ||
78 | uint16_t max_sys_clk_div; | ||
79 | uint32_t min_sys_clk_freq_hz; | ||
80 | uint32_t max_sys_clk_freq_hz; | ||
81 | uint16_t min_pix_clk_div; | ||
82 | uint16_t max_pix_clk_div; | ||
83 | uint32_t min_pix_clk_freq_hz; | ||
84 | uint32_t max_pix_clk_freq_hz; | ||
85 | }; | ||
86 | |||
76 | struct smiapp_pll_limits { | 87 | struct smiapp_pll_limits { |
77 | /* Strict PLL limits */ | 88 | /* Strict PLL limits */ |
78 | uint32_t min_ext_clk_freq_hz; | 89 | uint32_t min_ext_clk_freq_hz; |
@@ -86,23 +97,8 @@ struct smiapp_pll_limits { | |||
86 | uint32_t min_pll_op_freq_hz; | 97 | uint32_t min_pll_op_freq_hz; |
87 | uint32_t max_pll_op_freq_hz; | 98 | uint32_t max_pll_op_freq_hz; |
88 | 99 | ||
89 | uint16_t min_vt_sys_clk_div; | 100 | struct smiapp_pll_branch_limits vt; |
90 | uint16_t max_vt_sys_clk_div; | 101 | struct smiapp_pll_branch_limits op; |
91 | uint32_t min_vt_sys_clk_freq_hz; | ||
92 | uint32_t max_vt_sys_clk_freq_hz; | ||
93 | uint16_t min_vt_pix_clk_div; | ||
94 | uint16_t max_vt_pix_clk_div; | ||
95 | uint32_t min_vt_pix_clk_freq_hz; | ||
96 | uint32_t max_vt_pix_clk_freq_hz; | ||
97 | |||
98 | uint16_t min_op_sys_clk_div; | ||
99 | uint16_t max_op_sys_clk_div; | ||
100 | uint32_t min_op_sys_clk_freq_hz; | ||
101 | uint32_t max_op_sys_clk_freq_hz; | ||
102 | uint16_t min_op_pix_clk_div; | ||
103 | uint16_t max_op_pix_clk_div; | ||
104 | uint32_t min_op_pix_clk_freq_hz; | ||
105 | uint32_t max_op_pix_clk_freq_hz; | ||
106 | 102 | ||
107 | /* Other relevant limits */ | 103 | /* Other relevant limits */ |
108 | uint32_t min_line_length_pck_bin; | 104 | uint32_t min_line_length_pck_bin; |
diff --git a/drivers/media/i2c/smiapp/smiapp-core.c b/drivers/media/i2c/smiapp/smiapp-core.c index 42316cb57041..81ec4ac5bcdd 100644 --- a/drivers/media/i2c/smiapp/smiapp-core.c +++ b/drivers/media/i2c/smiapp/smiapp-core.c | |||
@@ -252,23 +252,23 @@ static int smiapp_pll_update(struct smiapp_sensor *sensor) | |||
252 | .min_pll_op_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_PLL_OP_FREQ_HZ], | 252 | .min_pll_op_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_PLL_OP_FREQ_HZ], |
253 | .max_pll_op_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_PLL_OP_FREQ_HZ], | 253 | .max_pll_op_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_PLL_OP_FREQ_HZ], |
254 | 254 | ||
255 | .min_op_sys_clk_div = sensor->limits[SMIAPP_LIMIT_MIN_OP_SYS_CLK_DIV], | 255 | .op.min_sys_clk_div = sensor->limits[SMIAPP_LIMIT_MIN_OP_SYS_CLK_DIV], |
256 | .max_op_sys_clk_div = sensor->limits[SMIAPP_LIMIT_MAX_OP_SYS_CLK_DIV], | 256 | .op.max_sys_clk_div = sensor->limits[SMIAPP_LIMIT_MAX_OP_SYS_CLK_DIV], |
257 | .min_op_pix_clk_div = sensor->limits[SMIAPP_LIMIT_MIN_OP_PIX_CLK_DIV], | 257 | .op.min_pix_clk_div = sensor->limits[SMIAPP_LIMIT_MIN_OP_PIX_CLK_DIV], |
258 | .max_op_pix_clk_div = sensor->limits[SMIAPP_LIMIT_MAX_OP_PIX_CLK_DIV], | 258 | .op.max_pix_clk_div = sensor->limits[SMIAPP_LIMIT_MAX_OP_PIX_CLK_DIV], |
259 | .min_op_sys_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_OP_SYS_CLK_FREQ_HZ], | 259 | .op.min_sys_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_OP_SYS_CLK_FREQ_HZ], |
260 | .max_op_sys_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_OP_SYS_CLK_FREQ_HZ], | 260 | .op.max_sys_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_OP_SYS_CLK_FREQ_HZ], |
261 | .min_op_pix_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_OP_PIX_CLK_FREQ_HZ], | 261 | .op.min_pix_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_OP_PIX_CLK_FREQ_HZ], |
262 | .max_op_pix_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_OP_PIX_CLK_FREQ_HZ], | 262 | .op.max_pix_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_OP_PIX_CLK_FREQ_HZ], |
263 | 263 | ||
264 | .min_vt_sys_clk_div = sensor->limits[SMIAPP_LIMIT_MIN_VT_SYS_CLK_DIV], | 264 | .vt.min_sys_clk_div = sensor->limits[SMIAPP_LIMIT_MIN_VT_SYS_CLK_DIV], |
265 | .max_vt_sys_clk_div = sensor->limits[SMIAPP_LIMIT_MAX_VT_SYS_CLK_DIV], | 265 | .vt.max_sys_clk_div = sensor->limits[SMIAPP_LIMIT_MAX_VT_SYS_CLK_DIV], |
266 | .min_vt_pix_clk_div = sensor->limits[SMIAPP_LIMIT_MIN_VT_PIX_CLK_DIV], | 266 | .vt.min_pix_clk_div = sensor->limits[SMIAPP_LIMIT_MIN_VT_PIX_CLK_DIV], |
267 | .max_vt_pix_clk_div = sensor->limits[SMIAPP_LIMIT_MAX_VT_PIX_CLK_DIV], | 267 | .vt.max_pix_clk_div = sensor->limits[SMIAPP_LIMIT_MAX_VT_PIX_CLK_DIV], |
268 | .min_vt_sys_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_VT_SYS_CLK_FREQ_HZ], | 268 | .vt.min_sys_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_VT_SYS_CLK_FREQ_HZ], |
269 | .max_vt_sys_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_VT_SYS_CLK_FREQ_HZ], | 269 | .vt.max_sys_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_VT_SYS_CLK_FREQ_HZ], |
270 | .min_vt_pix_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_VT_PIX_CLK_FREQ_HZ], | 270 | .vt.min_pix_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MIN_VT_PIX_CLK_FREQ_HZ], |
271 | .max_vt_pix_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_VT_PIX_CLK_FREQ_HZ], | 271 | .vt.max_pix_clk_freq_hz = sensor->limits[SMIAPP_LIMIT_MAX_VT_PIX_CLK_FREQ_HZ], |
272 | 272 | ||
273 | .min_line_length_pck_bin = sensor->limits[SMIAPP_LIMIT_MIN_LINE_LENGTH_PCK_BIN], | 273 | .min_line_length_pck_bin = sensor->limits[SMIAPP_LIMIT_MIN_LINE_LENGTH_PCK_BIN], |
274 | .min_line_length_pck = sensor->limits[SMIAPP_LIMIT_MIN_LINE_LENGTH_PCK], | 274 | .min_line_length_pck = sensor->limits[SMIAPP_LIMIT_MIN_LINE_LENGTH_PCK], |
@@ -283,14 +283,7 @@ static int smiapp_pll_update(struct smiapp_sensor *sensor) | |||
283 | * requirements regarding them are essentially the | 283 | * requirements regarding them are essentially the |
284 | * same as on VT ones. | 284 | * same as on VT ones. |
285 | */ | 285 | */ |
286 | lim.min_op_sys_clk_div = lim.min_vt_sys_clk_div; | 286 | lim.op = lim.vt; |
287 | lim.max_op_sys_clk_div = lim.max_vt_sys_clk_div; | ||
288 | lim.min_op_pix_clk_div = lim.min_vt_pix_clk_div; | ||
289 | lim.max_op_pix_clk_div = lim.max_vt_pix_clk_div; | ||
290 | lim.min_op_sys_clk_freq_hz = lim.min_vt_sys_clk_freq_hz; | ||
291 | lim.max_op_sys_clk_freq_hz = lim.max_vt_sys_clk_freq_hz; | ||
292 | lim.min_op_pix_clk_freq_hz = lim.min_vt_pix_clk_freq_hz; | ||
293 | lim.max_op_pix_clk_freq_hz = lim.max_vt_pix_clk_freq_hz; | ||
294 | } | 287 | } |
295 | 288 | ||
296 | pll->binning_horizontal = sensor->binning_horizontal; | 289 | pll->binning_horizontal = sensor->binning_horizontal; |