diff options
author | Simon Glass <sjg@chromium.org> | 2021-08-01 12:05:23 -0600 |
---|---|---|
committer | Simon Glass <sjg@chromium.org> | 2021-08-08 11:27:27 -0600 |
commit | 1e9ced28f18ed75bef96df08e47baad27dd51829 (patch) | |
tree | 68281ced12e3fb983c8e8acff3e0a73b9424c1af /include/dm | |
parent | b18b38f2ae3f54b906e0f2ab86789d9dd0110ed2 (diff) | |
download | u-boot-1e9ced28f18ed75bef96df08e47baad27dd51829.tar.gz u-boot-1e9ced28f18ed75bef96df08e47baad27dd51829.tar.bz2 u-boot-1e9ced28f18ed75bef96df08e47baad27dd51829.zip |
dm: core: Don't allow uclass use before ready
At present it is possible to call uclass_get() before driver model is
inited. In fact this happens on x86 boards which use Intel FSPv1, since
mrccache_get_region() tries to get the SPI flash device very early
during init.
This has always been undefined behaviour. Previously it generally worked,
i.e. returned an error code without crashing, because gd->uclass_root_s
is zeroed and the uclass can be added despite driver model not being
ready, due to the way lists are implemented. With the change to use a
gd->uclass_root pointer, this no-longer works. For example, it causes a
hang on minnowmax.
Fix this by adding a check that driver model is ready when uclass_get() is
called. This function is called in the process of locating any device, so
it is a good place to add the check.
This fixes booting on minnowmax.
Signed-off-by: Simon Glass <sjg@chromium.org>
Fixes: 8a715530bb1 ("dm: core: Allow the uclass list to move")
Diffstat (limited to 'include/dm')
-rw-r--r-- | include/dm/uclass.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/include/dm/uclass.h b/include/dm/uclass.h index 2778818b52..da0c1bfadb 100644 --- a/include/dm/uclass.h +++ b/include/dm/uclass.h @@ -159,7 +159,8 @@ void *uclass_get_priv(const struct uclass *uc); * * @key: ID to look up * @ucp: Returns pointer to uclass (there is only one per ID) - * @return 0 if OK, -ve on error + * @return 0 if OK, -EDEADLK if driver model is not yet inited, other -ve on + * other error */ int uclass_get(enum uclass_id key, struct uclass **ucp); |