i2c: i2c-mux-gpio: use deferred probing
If the i2c-parent bus driver is not loaded, returning -ENODEV will force people to unload and then reload the module again to get it working. Signed-off-by: Ionut Nicu <ioan.nicu.ext@nsn.com> Acked-by: Peter Korsgaard <peter.korsgaard@barco.com> Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
This commit is contained in:
Родитель
492ed77bfa
Коммит
9937b8d89e
|
@ -79,7 +79,7 @@ static int i2c_mux_gpio_probe_dt(struct gpiomux *mux,
|
||||||
adapter = of_find_i2c_adapter_by_node(adapter_np);
|
adapter = of_find_i2c_adapter_by_node(adapter_np);
|
||||||
if (!adapter) {
|
if (!adapter) {
|
||||||
dev_err(&pdev->dev, "Cannot find parent bus\n");
|
dev_err(&pdev->dev, "Cannot find parent bus\n");
|
||||||
return -ENODEV;
|
return -EPROBE_DEFER;
|
||||||
}
|
}
|
||||||
mux->data.parent = i2c_adapter_id(adapter);
|
mux->data.parent = i2c_adapter_id(adapter);
|
||||||
put_device(&adapter->dev);
|
put_device(&adapter->dev);
|
||||||
|
@ -181,7 +181,7 @@ static int i2c_mux_gpio_probe(struct platform_device *pdev)
|
||||||
if (!parent) {
|
if (!parent) {
|
||||||
dev_err(&pdev->dev, "Parent adapter (%d) not found\n",
|
dev_err(&pdev->dev, "Parent adapter (%d) not found\n",
|
||||||
mux->data.parent);
|
mux->data.parent);
|
||||||
return -ENODEV;
|
return -EPROBE_DEFER;
|
||||||
}
|
}
|
||||||
|
|
||||||
mux->parent = parent;
|
mux->parent = parent;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче