@@ -2339,6 +2339,15 @@ static int sa_dma_init(struct sa_crypto_data *dd)
return ret;
}
+static int sa_link_child(struct device *dev, void *data)
+{
+ struct device *parent = data;
+
+ device_link_add(dev, parent, DL_FLAG_AUTOPROBE_CONSUMER);
+
+ return 0;
+}
+
static int sa_ul_probe(struct platform_device *pdev)
{
struct device *dev = &pdev->dev;
@@ -2389,6 +2398,8 @@ static int sa_ul_probe(struct platform_device *pdev)
if (ret)
goto release_dma;
+ device_for_each_child(&pdev->dev, &pdev->dev, sa_link_child);
+
return 0;
release_dma:
The child devices for sa2ul (like the RNG) have hard dependency towards the parent, they can't function without the parent enabled. Add device link for this purpose so that the dependencies are taken care of properly. Signed-off-by: Tero Kristo <t-kristo@ti.com> --- drivers/crypto/sa2ul.c | 11 +++++++++++ 1 file changed, 11 insertions(+)