mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-11 23:23:52 +08:00
media: Split v4l2_pipeline_pm_use into v4l2_pipeline_pm_{get, put}
Currently, v4l2_pipeline_pm_use() prototype is: int v4l2_pipeline_pm_use(struct media_entity *entity, int use) Where the 'use' argument shall only be set to '1' for enable/power-on, or to '0' for disable/power-off. The integer return is specified as only meaningful when 'use' is set to '1'. Let's enforce this semantic by splitting the function in two: v4l2_pipeline_pm_get and v4l2_pipeline_pm_put. This is done for several reasons. It makes the API easier to use (or harder to misuse). It removes the constraint on the values the 'use' argument shall take. Also, it removes the need to constraint the return value, by making v4l2_pipeline_pm_put void return. And last, it's more consistent with other kernel APIs, such as the runtime pm APIs, which makes the code more symmetric. Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com> Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
This commit is contained in:
parent
8fb12ce2ec
commit
8fd390b89c
@ -74,7 +74,7 @@ Before the receiver driver may enable the CSI-2 transmitter by using
|
|||||||
the :c:type:`v4l2_subdev_video_ops`->s_stream(), it must have powered
|
the :c:type:`v4l2_subdev_video_ops`->s_stream(), it must have powered
|
||||||
the transmitter up by using the
|
the transmitter up by using the
|
||||||
:c:type:`v4l2_subdev_core_ops`->s_power() callback. This may take
|
:c:type:`v4l2_subdev_core_ops`->s_power() callback. This may take
|
||||||
place either indirectly by using :c:func:`v4l2_pipeline_pm_use` or
|
place either indirectly by using :c:func:`v4l2_pipeline_pm_get` or
|
||||||
directly.
|
directly.
|
||||||
|
|
||||||
Formats
|
Formats
|
||||||
|
@ -1311,7 +1311,7 @@ static int isp_video_open(struct file *file)
|
|||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = v4l2_pipeline_pm_use(&video->video.entity, 1);
|
ret = v4l2_pipeline_pm_get(&video->video.entity);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
omap3isp_put(video->isp);
|
omap3isp_put(video->isp);
|
||||||
goto done;
|
goto done;
|
||||||
@ -1363,7 +1363,7 @@ static int isp_video_release(struct file *file)
|
|||||||
vb2_queue_release(&handle->queue);
|
vb2_queue_release(&handle->queue);
|
||||||
mutex_unlock(&video->queue_lock);
|
mutex_unlock(&video->queue_lock);
|
||||||
|
|
||||||
v4l2_pipeline_pm_use(&video->video.entity, 0);
|
v4l2_pipeline_pm_put(&video->video.entity);
|
||||||
|
|
||||||
/* Release the file handle. */
|
/* Release the file handle. */
|
||||||
v4l2_fh_del(vfh);
|
v4l2_fh_del(vfh);
|
||||||
|
@ -745,7 +745,7 @@ static int video_open(struct file *file)
|
|||||||
|
|
||||||
file->private_data = vfh;
|
file->private_data = vfh;
|
||||||
|
|
||||||
ret = v4l2_pipeline_pm_use(&vdev->entity, 1);
|
ret = v4l2_pipeline_pm_get(&vdev->entity);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
dev_err(video->camss->dev, "Failed to power up pipeline: %d\n",
|
dev_err(video->camss->dev, "Failed to power up pipeline: %d\n",
|
||||||
ret);
|
ret);
|
||||||
@ -771,7 +771,7 @@ static int video_release(struct file *file)
|
|||||||
|
|
||||||
vb2_fop_release(file);
|
vb2_fop_release(file);
|
||||||
|
|
||||||
v4l2_pipeline_pm_use(&vdev->entity, 0);
|
v4l2_pipeline_pm_put(&vdev->entity);
|
||||||
|
|
||||||
file->private_data = NULL;
|
file->private_data = NULL;
|
||||||
|
|
||||||
|
@ -842,7 +842,7 @@ static int rvin_open(struct file *file)
|
|||||||
goto err_unlock;
|
goto err_unlock;
|
||||||
|
|
||||||
if (vin->info->use_mc)
|
if (vin->info->use_mc)
|
||||||
ret = v4l2_pipeline_pm_use(&vin->vdev.entity, 1);
|
ret = v4l2_pipeline_pm_get(&vin->vdev.entity);
|
||||||
else if (v4l2_fh_is_singular_file(file))
|
else if (v4l2_fh_is_singular_file(file))
|
||||||
ret = rvin_power_parallel(vin, true);
|
ret = rvin_power_parallel(vin, true);
|
||||||
|
|
||||||
@ -858,7 +858,7 @@ static int rvin_open(struct file *file)
|
|||||||
return 0;
|
return 0;
|
||||||
err_power:
|
err_power:
|
||||||
if (vin->info->use_mc)
|
if (vin->info->use_mc)
|
||||||
v4l2_pipeline_pm_use(&vin->vdev.entity, 0);
|
v4l2_pipeline_pm_put(&vin->vdev.entity);
|
||||||
else if (v4l2_fh_is_singular_file(file))
|
else if (v4l2_fh_is_singular_file(file))
|
||||||
rvin_power_parallel(vin, false);
|
rvin_power_parallel(vin, false);
|
||||||
err_open:
|
err_open:
|
||||||
@ -886,7 +886,7 @@ static int rvin_release(struct file *file)
|
|||||||
ret = _vb2_fop_release(file, NULL);
|
ret = _vb2_fop_release(file, NULL);
|
||||||
|
|
||||||
if (vin->info->use_mc) {
|
if (vin->info->use_mc) {
|
||||||
v4l2_pipeline_pm_use(&vin->vdev.entity, 0);
|
v4l2_pipeline_pm_put(&vin->vdev.entity);
|
||||||
} else {
|
} else {
|
||||||
if (fh_singular)
|
if (fh_singular)
|
||||||
rvin_power_parallel(vin, false);
|
rvin_power_parallel(vin, false);
|
||||||
|
@ -214,7 +214,7 @@ static int sun4i_csi_open(struct file *file)
|
|||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto err_pm_put;
|
goto err_pm_put;
|
||||||
|
|
||||||
ret = v4l2_pipeline_pm_use(&csi->vdev.entity, 1);
|
ret = v4l2_pipeline_pm_get(&csi->vdev.entity);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err_pm_put;
|
goto err_pm_put;
|
||||||
|
|
||||||
@ -227,7 +227,7 @@ static int sun4i_csi_open(struct file *file)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_pipeline_pm_put:
|
err_pipeline_pm_put:
|
||||||
v4l2_pipeline_pm_use(&csi->vdev.entity, 0);
|
v4l2_pipeline_pm_put(&csi->vdev.entity);
|
||||||
|
|
||||||
err_pm_put:
|
err_pm_put:
|
||||||
pm_runtime_put(csi->dev);
|
pm_runtime_put(csi->dev);
|
||||||
@ -243,7 +243,7 @@ static int sun4i_csi_release(struct file *file)
|
|||||||
mutex_lock(&csi->lock);
|
mutex_lock(&csi->lock);
|
||||||
|
|
||||||
v4l2_fh_release(file);
|
v4l2_fh_release(file);
|
||||||
v4l2_pipeline_pm_use(&csi->vdev.entity, 0);
|
v4l2_pipeline_pm_put(&csi->vdev.entity);
|
||||||
pm_runtime_put(csi->dev);
|
pm_runtime_put(csi->dev);
|
||||||
|
|
||||||
mutex_unlock(&csi->lock);
|
mutex_unlock(&csi->lock);
|
||||||
|
@ -474,7 +474,7 @@ static int sun6i_video_open(struct file *file)
|
|||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto unlock;
|
goto unlock;
|
||||||
|
|
||||||
ret = v4l2_pipeline_pm_use(&video->vdev.entity, 1);
|
ret = v4l2_pipeline_pm_get(&video->vdev.entity);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto fh_release;
|
goto fh_release;
|
||||||
|
|
||||||
@ -507,7 +507,7 @@ static int sun6i_video_close(struct file *file)
|
|||||||
|
|
||||||
_vb2_fop_release(file, NULL);
|
_vb2_fop_release(file, NULL);
|
||||||
|
|
||||||
v4l2_pipeline_pm_use(&video->vdev.entity, 0);
|
v4l2_pipeline_pm_put(&video->vdev.entity);
|
||||||
|
|
||||||
if (last_fh)
|
if (last_fh)
|
||||||
sun6i_csi_set_power(video->csi, false);
|
sun6i_csi_set_power(video->csi, false);
|
||||||
|
@ -321,7 +321,7 @@ EXPORT_SYMBOL_GPL(v4l_vb2q_enable_media_source);
|
|||||||
* use_count field stores the total number of users of all video device nodes
|
* use_count field stores the total number of users of all video device nodes
|
||||||
* in the pipeline.
|
* in the pipeline.
|
||||||
*
|
*
|
||||||
* The v4l2_pipeline_pm_use() function must be called in the open() and
|
* The v4l2_pipeline_pm_{get, put}() functions must be called in the open() and
|
||||||
* close() handlers of video device nodes. It increments or decrements the use
|
* close() handlers of video device nodes. It increments or decrements the use
|
||||||
* count of all subdev entities in the pipeline.
|
* count of all subdev entities in the pipeline.
|
||||||
*
|
*
|
||||||
@ -423,7 +423,7 @@ static int pipeline_pm_power(struct media_entity *entity, int change,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int v4l2_pipeline_pm_use(struct media_entity *entity, int use)
|
static int v4l2_pipeline_pm_use(struct media_entity *entity, unsigned int use)
|
||||||
{
|
{
|
||||||
struct media_device *mdev = entity->graph_obj.mdev;
|
struct media_device *mdev = entity->graph_obj.mdev;
|
||||||
int change = use ? 1 : -1;
|
int change = use ? 1 : -1;
|
||||||
@ -444,7 +444,19 @@ int v4l2_pipeline_pm_use(struct media_entity *entity, int use)
|
|||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(v4l2_pipeline_pm_use);
|
|
||||||
|
int v4l2_pipeline_pm_get(struct media_entity *entity)
|
||||||
|
{
|
||||||
|
return v4l2_pipeline_pm_use(entity, 1);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(v4l2_pipeline_pm_get);
|
||||||
|
|
||||||
|
void v4l2_pipeline_pm_put(struct media_entity *entity)
|
||||||
|
{
|
||||||
|
/* Powering off entities shouldn't fail. */
|
||||||
|
WARN_ON(v4l2_pipeline_pm_use(entity, 0));
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(v4l2_pipeline_pm_put);
|
||||||
|
|
||||||
int v4l2_pipeline_link_notify(struct media_link *link, u32 flags,
|
int v4l2_pipeline_link_notify(struct media_link *link, u32 flags,
|
||||||
unsigned int notification)
|
unsigned int notification)
|
||||||
|
@ -643,7 +643,7 @@ static int capture_open(struct file *file)
|
|||||||
if (ret)
|
if (ret)
|
||||||
v4l2_err(priv->src_sd, "v4l2_fh_open failed\n");
|
v4l2_err(priv->src_sd, "v4l2_fh_open failed\n");
|
||||||
|
|
||||||
ret = v4l2_pipeline_pm_use(&vfd->entity, 1);
|
ret = v4l2_pipeline_pm_get(&vfd->entity);
|
||||||
if (ret)
|
if (ret)
|
||||||
v4l2_fh_release(file);
|
v4l2_fh_release(file);
|
||||||
|
|
||||||
@ -664,7 +664,7 @@ static int capture_release(struct file *file)
|
|||||||
vq->owner = NULL;
|
vq->owner = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
v4l2_pipeline_pm_use(&vfd->entity, 0);
|
v4l2_pipeline_pm_put(&vfd->entity);
|
||||||
|
|
||||||
v4l2_fh_release(file);
|
v4l2_fh_release(file);
|
||||||
mutex_unlock(&priv->mutex);
|
mutex_unlock(&priv->mutex);
|
||||||
|
@ -1111,7 +1111,7 @@ static int iss_video_open(struct file *file)
|
|||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = v4l2_pipeline_pm_use(&video->video.entity, 1);
|
ret = v4l2_pipeline_pm_get(&video->video.entity);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
omap4iss_put(video->iss);
|
omap4iss_put(video->iss);
|
||||||
goto done;
|
goto done;
|
||||||
@ -1160,7 +1160,7 @@ static int iss_video_release(struct file *file)
|
|||||||
/* Disable streaming and free the buffers queue resources. */
|
/* Disable streaming and free the buffers queue resources. */
|
||||||
iss_video_streamoff(file, vfh, video->type);
|
iss_video_streamoff(file, vfh, video->type);
|
||||||
|
|
||||||
v4l2_pipeline_pm_use(&video->video.entity, 0);
|
v4l2_pipeline_pm_put(&video->video.entity);
|
||||||
|
|
||||||
/* Release the videobuf2 queue */
|
/* Release the videobuf2 queue */
|
||||||
vb2_queue_release(&handle->queue);
|
vb2_queue_release(&handle->queue);
|
||||||
|
@ -937,10 +937,7 @@ static void rkisp1_vb2_stop_streaming(struct vb2_queue *queue)
|
|||||||
|
|
||||||
rkisp1_return_all_buffers(cap, VB2_BUF_STATE_ERROR);
|
rkisp1_return_all_buffers(cap, VB2_BUF_STATE_ERROR);
|
||||||
|
|
||||||
ret = v4l2_pipeline_pm_use(&node->vdev.entity, 0);
|
v4l2_pipeline_pm_put(&node->vdev.entity);
|
||||||
if (ret)
|
|
||||||
dev_err(rkisp1->dev, "pipeline close failed error:%d\n", ret);
|
|
||||||
|
|
||||||
ret = pm_runtime_put(rkisp1->dev);
|
ret = pm_runtime_put(rkisp1->dev);
|
||||||
if (ret)
|
if (ret)
|
||||||
dev_err(rkisp1->dev, "power down failed error:%d\n", ret);
|
dev_err(rkisp1->dev, "power down failed error:%d\n", ret);
|
||||||
@ -999,7 +996,7 @@ rkisp1_vb2_start_streaming(struct vb2_queue *queue, unsigned int count)
|
|||||||
dev_err(cap->rkisp1->dev, "power up failed %d\n", ret);
|
dev_err(cap->rkisp1->dev, "power up failed %d\n", ret);
|
||||||
goto err_destroy_dummy;
|
goto err_destroy_dummy;
|
||||||
}
|
}
|
||||||
ret = v4l2_pipeline_pm_use(entity, 1);
|
ret = v4l2_pipeline_pm_get(entity);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
dev_err(cap->rkisp1->dev, "open cif pipeline failed %d\n", ret);
|
dev_err(cap->rkisp1->dev, "open cif pipeline failed %d\n", ret);
|
||||||
goto err_pipe_pm_put;
|
goto err_pipe_pm_put;
|
||||||
@ -1025,7 +1022,7 @@ err_pipe_disable:
|
|||||||
rkisp1_pipeline_sink_walk(entity, NULL, rkisp1_pipeline_disable_cb);
|
rkisp1_pipeline_sink_walk(entity, NULL, rkisp1_pipeline_disable_cb);
|
||||||
err_stop_stream:
|
err_stop_stream:
|
||||||
rkisp1_stream_stop(cap);
|
rkisp1_stream_stop(cap);
|
||||||
v4l2_pipeline_pm_use(entity, 0);
|
v4l2_pipeline_pm_put(entity);
|
||||||
err_pipe_pm_put:
|
err_pipe_pm_put:
|
||||||
pm_runtime_put(cap->rkisp1->dev);
|
pm_runtime_put(cap->rkisp1->dev);
|
||||||
err_destroy_dummy:
|
err_destroy_dummy:
|
||||||
|
@ -86,23 +86,30 @@ int v4l_vb2q_enable_media_source(struct vb2_queue *q);
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* v4l2_pipeline_pm_use - Update the use count of an entity
|
* v4l2_pipeline_pm_get - Increase the use count of a pipeline
|
||||||
* @entity: The entity
|
* @entity: The root entity of a pipeline
|
||||||
* @use: Use (1) or stop using (0) the entity
|
|
||||||
*
|
*
|
||||||
* Update the use count of all entities in the pipeline and power entities on or
|
* Update the use count of all entities in the pipeline and power entities on.
|
||||||
* off accordingly.
|
|
||||||
*
|
*
|
||||||
* This function is intended to be called in video node open (use ==
|
* This function is intended to be called in video node open. It uses
|
||||||
* 1) and release (use == 0). It uses struct media_entity.use_count to
|
* struct media_entity.use_count to track the power status. The use
|
||||||
* track the power status. The use of this function should be paired
|
* of this function should be paired with v4l2_pipeline_link_notify().
|
||||||
* with v4l2_pipeline_link_notify().
|
|
||||||
*
|
*
|
||||||
* Return 0 on success or a negative error code on failure. Powering entities
|
* Return 0 on success or a negative error code on failure.
|
||||||
* off is assumed to never fail. No failure can occur when the use parameter is
|
|
||||||
* set to 0.
|
|
||||||
*/
|
*/
|
||||||
int v4l2_pipeline_pm_use(struct media_entity *entity, int use);
|
int v4l2_pipeline_pm_get(struct media_entity *entity);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* v4l2_pipeline_pm_put - Decrease the use count of a pipeline
|
||||||
|
* @entity: The root entity of a pipeline
|
||||||
|
*
|
||||||
|
* Update the use count of all entities in the pipeline and power entities off.
|
||||||
|
*
|
||||||
|
* This function is intended to be called in video node release. It uses
|
||||||
|
* struct media_entity.use_count to track the power status. The use
|
||||||
|
* of this function should be paired with v4l2_pipeline_link_notify().
|
||||||
|
*/
|
||||||
|
void v4l2_pipeline_pm_put(struct media_entity *entity);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -114,7 +121,7 @@ int v4l2_pipeline_pm_use(struct media_entity *entity, int use);
|
|||||||
* React to link management on powered pipelines by updating the use count of
|
* React to link management on powered pipelines by updating the use count of
|
||||||
* all entities in the source and sink sides of the link. Entities are powered
|
* all entities in the source and sink sides of the link. Entities are powered
|
||||||
* on or off accordingly. The use of this function should be paired
|
* on or off accordingly. The use of this function should be paired
|
||||||
* with v4l2_pipeline_pm_use().
|
* with v4l2_pipeline_pm_{get,put}().
|
||||||
*
|
*
|
||||||
* Return 0 on success or a negative error code on failure. Powering entities
|
* Return 0 on success or a negative error code on failure. Powering entities
|
||||||
* off is assumed to never fail. This function will not fail for disconnection
|
* off is assumed to never fail. This function will not fail for disconnection
|
||||||
@ -144,11 +151,14 @@ static inline int v4l_vb2q_enable_media_source(struct vb2_queue *q)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int v4l2_pipeline_pm_use(struct media_entity *entity, int use)
|
static inline int v4l2_pipeline_pm_get(struct media_entity *entity)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void v4l2_pipeline_pm_put(struct media_entity *entity)
|
||||||
|
{}
|
||||||
|
|
||||||
static inline int v4l2_pipeline_link_notify(struct media_link *link, u32 flags,
|
static inline int v4l2_pipeline_link_notify(struct media_link *link, u32 flags,
|
||||||
unsigned int notification)
|
unsigned int notification)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user