mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-11-28 20:44:00 +08:00
media: subdev: add v4l2_subdev_has_pad_interdep()
Add a v4l2_subdev_has_pad_interdep() helper function which can be used for media_entity_operations.has_pad_interdep op. It considers two pads interdependent if there is an active route between pad0 and pad1. Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
This commit is contained in:
parent
8a54644571
commit
33c0ddbe56
@ -1073,6 +1073,37 @@ int v4l2_subdev_link_validate(struct media_link *link)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(v4l2_subdev_link_validate);
|
EXPORT_SYMBOL_GPL(v4l2_subdev_link_validate);
|
||||||
|
|
||||||
|
bool v4l2_subdev_has_pad_interdep(struct media_entity *entity,
|
||||||
|
unsigned int pad0, unsigned int pad1)
|
||||||
|
{
|
||||||
|
struct v4l2_subdev *sd = media_entity_to_v4l2_subdev(entity);
|
||||||
|
struct v4l2_subdev_krouting *routing;
|
||||||
|
struct v4l2_subdev_state *state;
|
||||||
|
unsigned int i;
|
||||||
|
|
||||||
|
state = v4l2_subdev_lock_and_get_active_state(sd);
|
||||||
|
|
||||||
|
routing = &state->routing;
|
||||||
|
|
||||||
|
for (i = 0; i < routing->num_routes; ++i) {
|
||||||
|
struct v4l2_subdev_route *route = &routing->routes[i];
|
||||||
|
|
||||||
|
if (!(route->flags & V4L2_SUBDEV_ROUTE_FL_ACTIVE))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if ((route->sink_pad == pad0 && route->source_pad == pad1) ||
|
||||||
|
(route->source_pad == pad0 && route->sink_pad == pad1)) {
|
||||||
|
v4l2_subdev_unlock_state(state);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
v4l2_subdev_unlock_state(state);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(v4l2_subdev_has_pad_interdep);
|
||||||
|
|
||||||
struct v4l2_subdev_state *
|
struct v4l2_subdev_state *
|
||||||
__v4l2_subdev_state_alloc(struct v4l2_subdev *sd, const char *lock_name,
|
__v4l2_subdev_state_alloc(struct v4l2_subdev *sd, const char *lock_name,
|
||||||
struct lock_class_key *lock_key)
|
struct lock_class_key *lock_key)
|
||||||
|
@ -1246,6 +1246,24 @@ int v4l2_subdev_link_validate_default(struct v4l2_subdev *sd,
|
|||||||
*/
|
*/
|
||||||
int v4l2_subdev_link_validate(struct media_link *link);
|
int v4l2_subdev_link_validate(struct media_link *link);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* v4l2_subdev_has_pad_interdep - MC has_pad_interdep implementation for subdevs
|
||||||
|
*
|
||||||
|
* @entity: pointer to &struct media_entity
|
||||||
|
* @pad0: pad number for the first pad
|
||||||
|
* @pad1: pad number for the second pad
|
||||||
|
*
|
||||||
|
* This function is an implementation of the
|
||||||
|
* media_entity_operations.has_pad_interdep operation for subdevs that
|
||||||
|
* implement the multiplexed streams API (as indicated by the
|
||||||
|
* V4L2_SUBDEV_FL_STREAMS subdev flag).
|
||||||
|
*
|
||||||
|
* It considers two pads interdependent if there is an active route between pad0
|
||||||
|
* and pad1.
|
||||||
|
*/
|
||||||
|
bool v4l2_subdev_has_pad_interdep(struct media_entity *entity,
|
||||||
|
unsigned int pad0, unsigned int pad1);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* __v4l2_subdev_state_alloc - allocate v4l2_subdev_state
|
* __v4l2_subdev_state_alloc - allocate v4l2_subdev_state
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user