Commit 40012cd5 authored by Lubomir Rintel's avatar Lubomir Rintel Committed by Mauro Carvalho Chehab

media: ov7670: split register setting from set_framerate() logic

This will allow us to restore the last set frame rate after the device
returns from a power off.

[sakari.ailus@linux.intel.com>: Wrap a line over 80 characters]
Signed-off-by: default avatarLubomir Rintel <lkundrak@v3.sk>
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
parent 5556ab2a
...@@ -811,13 +811,25 @@ static void ov7675_get_framerate(struct v4l2_subdev *sd, ...@@ -811,13 +811,25 @@ static void ov7675_get_framerate(struct v4l2_subdev *sd,
(4 * clkrc); (4 * clkrc);
} }
static int ov7675_apply_framerate(struct v4l2_subdev *sd)
{
struct ov7670_info *info = to_state(sd);
int ret;
ret = ov7670_write(sd, REG_CLKRC, info->clkrc);
if (ret < 0)
return ret;
return ov7670_write(sd, REG_DBLV,
info->pll_bypass ? DBLV_BYPASS : DBLV_X4);
}
static int ov7675_set_framerate(struct v4l2_subdev *sd, static int ov7675_set_framerate(struct v4l2_subdev *sd,
struct v4l2_fract *tpf) struct v4l2_fract *tpf)
{ {
struct ov7670_info *info = to_state(sd); struct ov7670_info *info = to_state(sd);
u32 clkrc; u32 clkrc;
int pll_factor; int pll_factor;
int ret;
/* /*
* The formula is fps = 5/4*pixclk for YUV/RGB and * The formula is fps = 5/4*pixclk for YUV/RGB and
...@@ -826,19 +838,10 @@ static int ov7675_set_framerate(struct v4l2_subdev *sd, ...@@ -826,19 +838,10 @@ static int ov7675_set_framerate(struct v4l2_subdev *sd,
* pixclk = clock_speed / (clkrc + 1) * PLLfactor * pixclk = clock_speed / (clkrc + 1) * PLLfactor
* *
*/ */
if (info->pll_bypass) {
pll_factor = 1;
ret = ov7670_write(sd, REG_DBLV, DBLV_BYPASS);
} else {
pll_factor = PLL_FACTOR;
ret = ov7670_write(sd, REG_DBLV, DBLV_X4);
}
if (ret < 0)
return ret;
if (tpf->numerator == 0 || tpf->denominator == 0) { if (tpf->numerator == 0 || tpf->denominator == 0) {
clkrc = 0; clkrc = 0;
} else { } else {
pll_factor = info->pll_bypass ? 1 : PLL_FACTOR;
clkrc = (5 * pll_factor * info->clock_speed * tpf->numerator) / clkrc = (5 * pll_factor * info->clock_speed * tpf->numerator) /
(4 * tpf->denominator); (4 * tpf->denominator);
if (info->fmt->mbus_code == MEDIA_BUS_FMT_SBGGR8_1X8) if (info->fmt->mbus_code == MEDIA_BUS_FMT_SBGGR8_1X8)
...@@ -860,7 +863,7 @@ static int ov7675_set_framerate(struct v4l2_subdev *sd, ...@@ -860,7 +863,7 @@ static int ov7675_set_framerate(struct v4l2_subdev *sd,
/* Recalculate frame rate */ /* Recalculate frame rate */
ov7675_get_framerate(sd, tpf); ov7675_get_framerate(sd, tpf);
return ov7670_write(sd, REG_CLKRC, info->clkrc); return ov7675_apply_framerate(sd);
} }
static void ov7670_get_framerate_legacy(struct v4l2_subdev *sd, static void ov7670_get_framerate_legacy(struct v4l2_subdev *sd,
......
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