Commit e80cdf0a authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Mauro Carvalho Chehab

media: v4l2-async: Log message in case of heterogeneous fwnode match

When a notifier supplies a device fwnode and a subdev supplies an
endpoint fwnode, incorrect matches may occur if multiple subdevs
correspond to the same device fwnode. This can't be handled
transparently in the framework, and requires the notifier to switch to
endpoint fwnodes. Log a message to notify of this problem. A second
message is added to help accelerating the transition to endpoint
matching.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Tested-by: default avatarLad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>
Reviewed-by: default avatarKieran Bingham <kieran.bingham+renesas@ideasonboard.com>
Reviewed-by: default avatarJacopo Mondi <jacopo+renesas@jmondi.org>
Tested-by: default avatarNiklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent 3e33392a
...@@ -77,6 +77,7 @@ static bool match_fwnode(struct v4l2_async_notifier *notifier, ...@@ -77,6 +77,7 @@ static bool match_fwnode(struct v4l2_async_notifier *notifier,
struct fwnode_handle *dev_fwnode; struct fwnode_handle *dev_fwnode;
bool asd_fwnode_is_ep; bool asd_fwnode_is_ep;
bool sd_fwnode_is_ep; bool sd_fwnode_is_ep;
struct device *dev;
/* /*
* Both the subdev and the async subdev can provide either an endpoint * Both the subdev and the async subdev can provide either an endpoint
...@@ -114,7 +115,28 @@ static bool match_fwnode(struct v4l2_async_notifier *notifier, ...@@ -114,7 +115,28 @@ static bool match_fwnode(struct v4l2_async_notifier *notifier,
fwnode_handle_put(dev_fwnode); fwnode_handle_put(dev_fwnode);
return dev_fwnode == other_fwnode; if (dev_fwnode != other_fwnode)
return false;
/*
* We have a heterogeneous match. Retrieve the struct device of the side
* that matched on a device fwnode to print its driver name.
*/
if (sd_fwnode_is_ep)
dev = notifier->v4l2_dev ? notifier->v4l2_dev->dev
: notifier->sd->dev;
else
dev = sd->dev;
if (dev && dev->driver) {
if (sd_fwnode_is_ep)
dev_warn(dev, "Driver %s uses device fwnode, incorrect match may occur\n",
dev->driver->name);
dev_notice(dev, "Consider updating driver %s to match on endpoints\n",
dev->driver->name);
}
return true;
} }
static bool match_custom(struct v4l2_async_notifier *notifier, static bool match_custom(struct v4l2_async_notifier *notifier,
......
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