提交 68223eee 编写于 作者: S Saravana Kannan 提交者: Greg Kroah-Hartman

driver core: Set deferred probe reason when deferred by driver core

When the driver core defers the probe of a device, set the deferred
probe reason so that it's easier to debug. The deferred probe reason is
available in debugfs under devices_deferred.
Reviewed-by: NGeert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: NSaravana Kannan <saravanak@google.com>
Link: https://lore.kernel.org/r/20210915172808.620546-2-saravanak@google.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 04f41c68
...@@ -975,6 +975,7 @@ int device_links_check_suppliers(struct device *dev) ...@@ -975,6 +975,7 @@ int device_links_check_suppliers(struct device *dev)
{ {
struct device_link *link; struct device_link *link;
int ret = 0; int ret = 0;
struct fwnode_handle *sup_fw;
/* /*
* Device waiting for supplier to become available is not allowed to * Device waiting for supplier to become available is not allowed to
...@@ -983,10 +984,11 @@ int device_links_check_suppliers(struct device *dev) ...@@ -983,10 +984,11 @@ int device_links_check_suppliers(struct device *dev)
mutex_lock(&fwnode_link_lock); mutex_lock(&fwnode_link_lock);
if (dev->fwnode && !list_empty(&dev->fwnode->suppliers) && if (dev->fwnode && !list_empty(&dev->fwnode->suppliers) &&
!fw_devlink_is_permissive()) { !fw_devlink_is_permissive()) {
dev_dbg(dev, "probe deferral - wait for supplier %pfwP\n", sup_fw = list_first_entry(&dev->fwnode->suppliers,
list_first_entry(&dev->fwnode->suppliers, struct fwnode_link,
struct fwnode_link, c_hook)->supplier;
c_hook)->supplier); dev_err_probe(dev, -EPROBE_DEFER, "wait for supplier %pfwP\n",
sup_fw);
mutex_unlock(&fwnode_link_lock); mutex_unlock(&fwnode_link_lock);
return -EPROBE_DEFER; return -EPROBE_DEFER;
} }
...@@ -1001,8 +1003,9 @@ int device_links_check_suppliers(struct device *dev) ...@@ -1001,8 +1003,9 @@ int device_links_check_suppliers(struct device *dev)
if (link->status != DL_STATE_AVAILABLE && if (link->status != DL_STATE_AVAILABLE &&
!(link->flags & DL_FLAG_SYNC_STATE_ONLY)) { !(link->flags & DL_FLAG_SYNC_STATE_ONLY)) {
device_links_missing_supplier(dev); device_links_missing_supplier(dev);
dev_dbg(dev, "probe deferral - supplier %s not ready\n", dev_err_probe(dev, -EPROBE_DEFER,
dev_name(link->supplier)); "supplier %s not ready\n",
dev_name(link->supplier));
ret = -EPROBE_DEFER; ret = -EPROBE_DEFER;
break; break;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册