提交 1499be67 编写于 作者: L Laurent Pinchart 提交者: Mauro Carvalho Chehab

[media] v4l: vsp1: Cleanup video nodes at removal time

Video nodes created and initialized in the RPF and WPF init code paths
are never unregistered, and the related resources (videobuf alloc
context and media entity) never released.

Fix this by storing a pointer to the vsp1_video object in vsp1_entity
and calling vsp1_video_cleanup() from vsp1_entity_destroy(). This also
allows simplifying the init error code paths.
Signed-off-by: NLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Signed-off-by: NMauro Carvalho Chehab <m.chehab@samsung.com>
上级 7005a817
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include "vsp1.h" #include "vsp1.h"
#include "vsp1_entity.h" #include "vsp1_entity.h"
#include "vsp1_video.h"
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
* V4L2 Subdevice Operations * V4L2 Subdevice Operations
...@@ -185,6 +186,8 @@ int vsp1_entity_init(struct vsp1_device *vsp1, struct vsp1_entity *entity, ...@@ -185,6 +186,8 @@ int vsp1_entity_init(struct vsp1_device *vsp1, struct vsp1_entity *entity,
void vsp1_entity_destroy(struct vsp1_entity *entity) void vsp1_entity_destroy(struct vsp1_entity *entity)
{ {
if (entity->video)
vsp1_video_cleanup(entity->video);
if (entity->subdev.ctrl_handler) if (entity->subdev.ctrl_handler)
v4l2_ctrl_handler_free(entity->subdev.ctrl_handler); v4l2_ctrl_handler_free(entity->subdev.ctrl_handler);
media_entity_cleanup(&entity->subdev.entity); media_entity_cleanup(&entity->subdev.entity);
......
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
#include <media/v4l2-subdev.h> #include <media/v4l2-subdev.h>
struct vsp1_device; struct vsp1_device;
struct vsp1_video;
enum vsp1_entity_type { enum vsp1_entity_type {
VSP1_ENTITY_BRU, VSP1_ENTITY_BRU,
...@@ -68,6 +69,8 @@ struct vsp1_entity { ...@@ -68,6 +69,8 @@ struct vsp1_entity {
struct v4l2_subdev subdev; struct v4l2_subdev subdev;
struct v4l2_mbus_framefmt *formats; struct v4l2_mbus_framefmt *formats;
struct vsp1_video *video;
}; };
static inline struct vsp1_entity *to_vsp1_entity(struct v4l2_subdev *subdev) static inline struct vsp1_entity *to_vsp1_entity(struct v4l2_subdev *subdev)
......
...@@ -205,7 +205,9 @@ struct vsp1_rwpf *vsp1_rpf_create(struct vsp1_device *vsp1, unsigned int index) ...@@ -205,7 +205,9 @@ struct vsp1_rwpf *vsp1_rpf_create(struct vsp1_device *vsp1, unsigned int index)
ret = vsp1_video_init(video, &rpf->entity); ret = vsp1_video_init(video, &rpf->entity);
if (ret < 0) if (ret < 0)
goto error_video; goto error;
rpf->entity.video = video;
/* Connect the video device to the RPF. */ /* Connect the video device to the RPF. */
ret = media_entity_create_link(&rpf->video.video.entity, 0, ret = media_entity_create_link(&rpf->video.video.entity, 0,
...@@ -214,13 +216,11 @@ struct vsp1_rwpf *vsp1_rpf_create(struct vsp1_device *vsp1, unsigned int index) ...@@ -214,13 +216,11 @@ struct vsp1_rwpf *vsp1_rpf_create(struct vsp1_device *vsp1, unsigned int index)
MEDIA_LNK_FL_ENABLED | MEDIA_LNK_FL_ENABLED |
MEDIA_LNK_FL_IMMUTABLE); MEDIA_LNK_FL_IMMUTABLE);
if (ret < 0) if (ret < 0)
goto error_link; goto error;
return rpf; return rpf;
error_link: error:
vsp1_video_cleanup(video); vsp1_entity_destroy(&rpf->entity);
error_video:
media_entity_cleanup(&rpf->entity.subdev.entity);
return ERR_PTR(ret); return ERR_PTR(ret);
} }
...@@ -216,7 +216,9 @@ struct vsp1_rwpf *vsp1_wpf_create(struct vsp1_device *vsp1, unsigned int index) ...@@ -216,7 +216,9 @@ struct vsp1_rwpf *vsp1_wpf_create(struct vsp1_device *vsp1, unsigned int index)
ret = vsp1_video_init(video, &wpf->entity); ret = vsp1_video_init(video, &wpf->entity);
if (ret < 0) if (ret < 0)
goto error_video; goto error;
wpf->entity.video = video;
/* Connect the video device to the WPF. All connections are immutable /* Connect the video device to the WPF. All connections are immutable
* except for the WPF0 source link if a LIF is present. * except for the WPF0 source link if a LIF is present.
...@@ -229,15 +231,13 @@ struct vsp1_rwpf *vsp1_wpf_create(struct vsp1_device *vsp1, unsigned int index) ...@@ -229,15 +231,13 @@ struct vsp1_rwpf *vsp1_wpf_create(struct vsp1_device *vsp1, unsigned int index)
RWPF_PAD_SOURCE, RWPF_PAD_SOURCE,
&wpf->video.video.entity, 0, flags); &wpf->video.video.entity, 0, flags);
if (ret < 0) if (ret < 0)
goto error_link; goto error;
wpf->entity.sink = &wpf->video.video.entity; wpf->entity.sink = &wpf->video.video.entity;
return wpf; return wpf;
error_link: error:
vsp1_video_cleanup(video); vsp1_entity_destroy(&wpf->entity);
error_video:
media_entity_cleanup(&wpf->entity.subdev.entity);
return ERR_PTR(ret); return ERR_PTR(ret);
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册