mirror of
https://github.com/torvalds/linux.git
synced 2024-11-24 13:11:40 +00:00
media: ov2680: Wait for endpoint fwnode before continuing with probe()
Defer probe() until the endpoint fwnode is available. This is necessary on ACPI platforms where the bridge code creating the fwnodes may also e.g. set the "clock-frequency" device property and add GPIO mappings. Acked-by: Rui Miguel Silva <rmfrfs@gmail.com> Reviewed-by: Daniel Scally <dan.scally@ideasonboard.com> Signed-off-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
This commit is contained in:
parent
8e50a1221f
commit
83634470b0
@ -717,10 +717,22 @@ static int ov2680_check_id(struct ov2680_dev *sensor)
|
|||||||
static int ov2680_parse_dt(struct ov2680_dev *sensor)
|
static int ov2680_parse_dt(struct ov2680_dev *sensor)
|
||||||
{
|
{
|
||||||
struct device *dev = sensor->dev;
|
struct device *dev = sensor->dev;
|
||||||
|
struct fwnode_handle *ep_fwnode;
|
||||||
struct gpio_desc *gpio;
|
struct gpio_desc *gpio;
|
||||||
unsigned int rate = 0;
|
unsigned int rate = 0;
|
||||||
int i, ret;
|
int i, ret;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Sometimes the fwnode graph is initialized by the bridge driver.
|
||||||
|
* Bridge drivers doing this may also add GPIO mappings, wait for this.
|
||||||
|
*/
|
||||||
|
ep_fwnode = fwnode_graph_get_next_endpoint(dev_fwnode(dev), NULL);
|
||||||
|
if (!ep_fwnode)
|
||||||
|
return dev_err_probe(dev, -EPROBE_DEFER,
|
||||||
|
"waiting for fwnode graph endpoint\n");
|
||||||
|
|
||||||
|
fwnode_handle_put(ep_fwnode);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The pin we want is named XSHUTDN in the datasheet. Linux sensor
|
* The pin we want is named XSHUTDN in the datasheet. Linux sensor
|
||||||
* drivers have standardized on using "powerdown" as con-id name
|
* drivers have standardized on using "powerdown" as con-id name
|
||||||
@ -801,7 +813,7 @@ static int ov2680_probe(struct i2c_client *client)
|
|||||||
|
|
||||||
ret = ov2680_parse_dt(sensor);
|
ret = ov2680_parse_dt(sensor);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return -EINVAL;
|
return ret;
|
||||||
|
|
||||||
ret = ov2680_mode_init(sensor);
|
ret = ov2680_mode_init(sensor);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
|
Loading…
Reference in New Issue
Block a user