提交 59d0b2bf 编写于 作者: L Laurent Pinchart 提交者: Mauro Carvalho Chehab

[media] v4l: vsp1: Don't setup control handler when starting streaming

The control handler set operations don't program the hardware anymore,
there's thus no need to call them when starting the stream.
Signed-off-by: NLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@osg.samsung.com>
上级 d884a8b2
...@@ -66,11 +66,8 @@ static int bru_s_stream(struct v4l2_subdev *subdev, int enable) ...@@ -66,11 +66,8 @@ static int bru_s_stream(struct v4l2_subdev *subdev, int enable)
struct v4l2_mbus_framefmt *format; struct v4l2_mbus_framefmt *format;
unsigned int flags; unsigned int flags;
unsigned int i; unsigned int i;
int ret;
ret = vsp1_entity_set_streaming(&bru->entity, enable); vsp1_entity_set_streaming(&bru->entity, enable);
if (ret < 0)
return ret;
if (!enable) if (!enable)
return 0; return 0;
......
...@@ -45,29 +45,13 @@ bool vsp1_entity_is_streaming(struct vsp1_entity *entity) ...@@ -45,29 +45,13 @@ bool vsp1_entity_is_streaming(struct vsp1_entity *entity)
return streaming; return streaming;
} }
int vsp1_entity_set_streaming(struct vsp1_entity *entity, bool streaming) void vsp1_entity_set_streaming(struct vsp1_entity *entity, bool streaming)
{ {
unsigned long flags; unsigned long flags;
int ret;
spin_lock_irqsave(&entity->lock, flags); spin_lock_irqsave(&entity->lock, flags);
entity->streaming = streaming; entity->streaming = streaming;
spin_unlock_irqrestore(&entity->lock, flags); spin_unlock_irqrestore(&entity->lock, flags);
if (!streaming)
return 0;
if (!entity->vsp1->info->uapi || !entity->subdev.ctrl_handler)
return 0;
ret = v4l2_ctrl_handler_setup(entity->subdev.ctrl_handler);
if (ret < 0) {
spin_lock_irqsave(&entity->lock, flags);
entity->streaming = false;
spin_unlock_irqrestore(&entity->lock, flags);
}
return ret;
} }
void vsp1_entity_route_setup(struct vsp1_entity *source) void vsp1_entity_route_setup(struct vsp1_entity *source)
......
...@@ -101,7 +101,7 @@ void vsp1_entity_init_formats(struct v4l2_subdev *subdev, ...@@ -101,7 +101,7 @@ void vsp1_entity_init_formats(struct v4l2_subdev *subdev,
struct v4l2_subdev_pad_config *cfg); struct v4l2_subdev_pad_config *cfg);
bool vsp1_entity_is_streaming(struct vsp1_entity *entity); bool vsp1_entity_is_streaming(struct vsp1_entity *entity);
int vsp1_entity_set_streaming(struct vsp1_entity *entity, bool streaming); void vsp1_entity_set_streaming(struct vsp1_entity *entity, bool streaming);
void vsp1_entity_route_setup(struct vsp1_entity *source); void vsp1_entity_route_setup(struct vsp1_entity *source);
......
...@@ -45,11 +45,8 @@ static int rpf_s_stream(struct v4l2_subdev *subdev, int enable) ...@@ -45,11 +45,8 @@ static int rpf_s_stream(struct v4l2_subdev *subdev, int enable)
const struct v4l2_rect *crop = &rpf->crop; const struct v4l2_rect *crop = &rpf->crop;
u32 pstride; u32 pstride;
u32 infmt; u32 infmt;
int ret;
ret = vsp1_entity_set_streaming(&rpf->entity, enable); vsp1_entity_set_streaming(&rpf->entity, enable);
if (ret < 0)
return ret;
if (!enable) if (!enable)
return 0; return 0;
......
...@@ -113,11 +113,8 @@ static int sru_s_stream(struct v4l2_subdev *subdev, int enable) ...@@ -113,11 +113,8 @@ static int sru_s_stream(struct v4l2_subdev *subdev, int enable)
struct v4l2_mbus_framefmt *input; struct v4l2_mbus_framefmt *input;
struct v4l2_mbus_framefmt *output; struct v4l2_mbus_framefmt *output;
u32 ctrl0; u32 ctrl0;
int ret;
ret = vsp1_entity_set_streaming(&sru->entity, enable); vsp1_entity_set_streaming(&sru->entity, enable);
if (ret < 0)
return ret;
if (!enable) if (!enable)
return 0; return 0;
......
...@@ -46,11 +46,8 @@ static int wpf_s_stream(struct v4l2_subdev *subdev, int enable) ...@@ -46,11 +46,8 @@ static int wpf_s_stream(struct v4l2_subdev *subdev, int enable)
unsigned int i; unsigned int i;
u32 srcrpf = 0; u32 srcrpf = 0;
u32 outfmt = 0; u32 outfmt = 0;
int ret;
ret = vsp1_entity_set_streaming(&wpf->entity, enable); vsp1_entity_set_streaming(&wpf->entity, enable);
if (ret < 0)
return ret;
if (!enable) { if (!enable) {
vsp1_write(vsp1, VI6_WPF_IRQ_ENB(wpf->entity.index), 0); vsp1_write(vsp1, VI6_WPF_IRQ_ENB(wpf->entity.index), 0);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册