Commit 2de3a654 authored by Bryan O'Donoghue's avatar Bryan O'Donoghue Committed by Hans Verkuil

media: qcom: camss: Untangle if/else spaghetti in camss

We have a very convoluted if/else legacy here which needs to be
rationalised to make it more sustainable.

Adding in another Soc or two will make some of these if statements into
increasingly large multi-clause behemoths.

Introduce switches in the obvious places to despaghetiify.
Signed-off-by: default avatarBryan O'Donoghue <bryan.odonoghue@linaro.org>
Acked-by: default avatarKonrad Dybcio <konrad.dybcio@linaro.org>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
parent b2c2715e
...@@ -558,19 +558,21 @@ int msm_csiphy_subdev_init(struct camss *camss, ...@@ -558,19 +558,21 @@ int msm_csiphy_subdev_init(struct camss *camss,
csiphy->cfg.combo_mode = 0; csiphy->cfg.combo_mode = 0;
csiphy->ops = res->ops; csiphy->ops = res->ops;
if (camss->res->version == CAMSS_8x16) { switch (camss->res->version) {
case CAMSS_8x16:
csiphy->formats = csiphy_formats_8x16; csiphy->formats = csiphy_formats_8x16;
csiphy->nformats = ARRAY_SIZE(csiphy_formats_8x16); csiphy->nformats = ARRAY_SIZE(csiphy_formats_8x16);
} else if (camss->res->version == CAMSS_8x96 || break;
camss->res->version == CAMSS_660) { case CAMSS_8x96:
case CAMSS_660:
csiphy->formats = csiphy_formats_8x96; csiphy->formats = csiphy_formats_8x96;
csiphy->nformats = ARRAY_SIZE(csiphy_formats_8x96); csiphy->nformats = ARRAY_SIZE(csiphy_formats_8x96);
} else if (camss->res->version == CAMSS_845 || break;
camss->res->version == CAMSS_8250) { case CAMSS_845:
case CAMSS_8250:
csiphy->formats = csiphy_formats_sdm845; csiphy->formats = csiphy_formats_sdm845;
csiphy->nformats = ARRAY_SIZE(csiphy_formats_sdm845); csiphy->nformats = ARRAY_SIZE(csiphy_formats_sdm845);
} else { break;
return -EINVAL;
} }
/* Memory */ /* Memory */
......
...@@ -170,7 +170,8 @@ static u32 vfe_src_pad_code(struct vfe_line *line, u32 sink_code, ...@@ -170,7 +170,8 @@ static u32 vfe_src_pad_code(struct vfe_line *line, u32 sink_code,
{ {
struct vfe_device *vfe = to_vfe(line); struct vfe_device *vfe = to_vfe(line);
if (vfe->camss->res->version == CAMSS_8x16) switch (vfe->camss->res->version) {
case CAMSS_8x16:
switch (sink_code) { switch (sink_code) {
case MEDIA_BUS_FMT_YUYV8_1X16: case MEDIA_BUS_FMT_YUYV8_1X16:
{ {
...@@ -218,10 +219,11 @@ static u32 vfe_src_pad_code(struct vfe_line *line, u32 sink_code, ...@@ -218,10 +219,11 @@ static u32 vfe_src_pad_code(struct vfe_line *line, u32 sink_code,
return sink_code; return sink_code;
} }
else if (vfe->camss->res->version == CAMSS_8x96 || break;
vfe->camss->res->version == CAMSS_660 || case CAMSS_8x96:
vfe->camss->res->version == CAMSS_845 || case CAMSS_660:
vfe->camss->res->version == CAMSS_8250) case CAMSS_845:
case CAMSS_8250:
switch (sink_code) { switch (sink_code) {
case MEDIA_BUS_FMT_YUYV8_1X16: case MEDIA_BUS_FMT_YUYV8_1X16:
{ {
...@@ -281,8 +283,9 @@ static u32 vfe_src_pad_code(struct vfe_line *line, u32 sink_code, ...@@ -281,8 +283,9 @@ static u32 vfe_src_pad_code(struct vfe_line *line, u32 sink_code,
return sink_code; return sink_code;
} }
else break;
return 0; }
return 0;
} }
int vfe_reset(struct vfe_device *vfe) int vfe_reset(struct vfe_device *vfe)
...@@ -1379,7 +1382,8 @@ int msm_vfe_subdev_init(struct camss *camss, struct vfe_device *vfe, ...@@ -1379,7 +1382,8 @@ int msm_vfe_subdev_init(struct camss *camss, struct vfe_device *vfe,
init_completion(&l->output.sof); init_completion(&l->output.sof);
init_completion(&l->output.reg_update); init_completion(&l->output.reg_update);
if (camss->res->version == CAMSS_8x16) { switch (camss->res->version) {
case CAMSS_8x16:
if (i == VFE_LINE_PIX) { if (i == VFE_LINE_PIX) {
l->formats = formats_pix_8x16; l->formats = formats_pix_8x16;
l->nformats = ARRAY_SIZE(formats_pix_8x16); l->nformats = ARRAY_SIZE(formats_pix_8x16);
...@@ -1387,8 +1391,9 @@ int msm_vfe_subdev_init(struct camss *camss, struct vfe_device *vfe, ...@@ -1387,8 +1391,9 @@ int msm_vfe_subdev_init(struct camss *camss, struct vfe_device *vfe,
l->formats = formats_rdi_8x16; l->formats = formats_rdi_8x16;
l->nformats = ARRAY_SIZE(formats_rdi_8x16); l->nformats = ARRAY_SIZE(formats_rdi_8x16);
} }
} else if (camss->res->version == CAMSS_8x96 || break;
camss->res->version == CAMSS_660) { case CAMSS_8x96:
case CAMSS_660:
if (i == VFE_LINE_PIX) { if (i == VFE_LINE_PIX) {
l->formats = formats_pix_8x96; l->formats = formats_pix_8x96;
l->nformats = ARRAY_SIZE(formats_pix_8x96); l->nformats = ARRAY_SIZE(formats_pix_8x96);
...@@ -1396,12 +1401,12 @@ int msm_vfe_subdev_init(struct camss *camss, struct vfe_device *vfe, ...@@ -1396,12 +1401,12 @@ int msm_vfe_subdev_init(struct camss *camss, struct vfe_device *vfe,
l->formats = formats_rdi_8x96; l->formats = formats_rdi_8x96;
l->nformats = ARRAY_SIZE(formats_rdi_8x96); l->nformats = ARRAY_SIZE(formats_rdi_8x96);
} }
} else if (camss->res->version == CAMSS_845 || break;
camss->res->version == CAMSS_8250) { case CAMSS_845:
case CAMSS_8250:
l->formats = formats_rdi_845; l->formats = formats_rdi_845;
l->nformats = ARRAY_SIZE(formats_rdi_845); l->nformats = ARRAY_SIZE(formats_rdi_845);
} else { break;
return -EINVAL;
} }
} }
......
...@@ -1006,7 +1006,8 @@ int msm_video_register(struct camss_video *video, struct v4l2_device *v4l2_dev, ...@@ -1006,7 +1006,8 @@ int msm_video_register(struct camss_video *video, struct v4l2_device *v4l2_dev,
mutex_init(&video->lock); mutex_init(&video->lock);
if (video->camss->res->version == CAMSS_8x16) { switch (video->camss->res->version) {
case CAMSS_8x16:
if (is_pix) { if (is_pix) {
video->formats = formats_pix_8x16; video->formats = formats_pix_8x16;
video->nformats = ARRAY_SIZE(formats_pix_8x16); video->nformats = ARRAY_SIZE(formats_pix_8x16);
...@@ -1014,8 +1015,9 @@ int msm_video_register(struct camss_video *video, struct v4l2_device *v4l2_dev, ...@@ -1014,8 +1015,9 @@ int msm_video_register(struct camss_video *video, struct v4l2_device *v4l2_dev,
video->formats = formats_rdi_8x16; video->formats = formats_rdi_8x16;
video->nformats = ARRAY_SIZE(formats_rdi_8x16); video->nformats = ARRAY_SIZE(formats_rdi_8x16);
} }
} else if (video->camss->res->version == CAMSS_8x96 || break;
video->camss->res->version == CAMSS_660) { case CAMSS_8x96:
case CAMSS_660:
if (is_pix) { if (is_pix) {
video->formats = formats_pix_8x96; video->formats = formats_pix_8x96;
video->nformats = ARRAY_SIZE(formats_pix_8x96); video->nformats = ARRAY_SIZE(formats_pix_8x96);
...@@ -1023,13 +1025,12 @@ int msm_video_register(struct camss_video *video, struct v4l2_device *v4l2_dev, ...@@ -1023,13 +1025,12 @@ int msm_video_register(struct camss_video *video, struct v4l2_device *v4l2_dev,
video->formats = formats_rdi_8x96; video->formats = formats_rdi_8x96;
video->nformats = ARRAY_SIZE(formats_rdi_8x96); video->nformats = ARRAY_SIZE(formats_rdi_8x96);
} }
} else if (video->camss->res->version == CAMSS_845 || break;
video->camss->res->version == CAMSS_8250) { case CAMSS_845:
case CAMSS_8250:
video->formats = formats_rdi_845; video->formats = formats_rdi_845;
video->nformats = ARRAY_SIZE(formats_rdi_845); video->nformats = ARRAY_SIZE(formats_rdi_845);
} else { break;
ret = -EINVAL;
goto error_video_register;
} }
ret = msm_video_init_format(video); ret = msm_video_init_format(video);
......
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