dm: core: Fix iteration over driver_info records
authorPaul Barker <paul.barker@sancloud.com>
Mon, 14 Nov 2022 12:42:35 +0000 (12:42 +0000)
committerTom Rini <trini@konsulko.com>
Fri, 2 Dec 2022 13:39:00 +0000 (08:39 -0500)
commitdec64d55afca17bfc48366a48a0d5894b8a3bdd2
tree3ecc7b5b7dc2980df370d6ec2b6473dc1bf3fe7c
parent9f52e765dcf4e5b940db98136ad0382aecb2b932
dm: core: Fix iteration over driver_info records

We should only perform additional iteration steps when needed to
initialize the parent of a device. Other binding errors (such as a
missing driver) should not lead to additional iteration steps.

Unnecessary iteration steps can cause issues when memory is tightly
constrained (such as in the TPL/SPL) since device_bind_by_name()
unconditionally allocates memory for a struct udevice. On the SanCloud
BBE this led to boot failure caused by memory exhaustion in the SPL
when booting from SPI flash.

Signed-off-by: Paul Barker <paul.barker@sancloud.com>
drivers/core/lists.c