* [PATCH master 1/3] fs: add only successful filesystem probes to fs_device_list
@ 2025-04-04 15:55 Ahmad Fatoum
2025-04-04 15:55 ` [PATCH master 2/3] common: pe: fix crash when pe_load was not called Ahmad Fatoum
2025-04-04 15:55 ` [PATCH master 3/3] barebox.h: annotate __hang as __noreturn Ahmad Fatoum
0 siblings, 2 replies; 3+ messages in thread
From: Ahmad Fatoum @ 2025-04-04 15:55 UTC (permalink / raw)
To: barebox; +Cc: Ahmad Fatoum
fs_init_legacy can't fail currently, but if it does in future, we can
end up with a file system added to fs_device_list that wasn't
successfully probed.
Move the list_add_tail to the end to avoid this.
Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
---
fs/fs.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/fs/fs.c b/fs/fs.c
index 48a6e960e812..4d201d1b0db8 100644
--- a/fs/fs.c
+++ b/fs/fs.c
@@ -782,14 +782,14 @@ static int fs_probe(struct device *dev)
fsdev->driver = fsdrv;
- list_add_tail(&fsdev->list, &fs_device_list);
-
if (IS_ENABLED(CONFIG_FS_LEGACY) && !fsdev->sb.s_root) {
ret = fs_init_legacy(fsdev);
if (ret)
return ret;
}
+ list_add_tail(&fsdev->list, &fs_device_list);
+
return 0;
}
--
2.39.5
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH master 2/3] common: pe: fix crash when pe_load was not called
2025-04-04 15:55 [PATCH master 1/3] fs: add only successful filesystem probes to fs_device_list Ahmad Fatoum
@ 2025-04-04 15:55 ` Ahmad Fatoum
2025-04-04 15:55 ` [PATCH master 3/3] barebox.h: annotate __hang as __noreturn Ahmad Fatoum
1 sibling, 0 replies; 3+ messages in thread
From: Ahmad Fatoum @ 2025-04-04 15:55 UTC (permalink / raw)
To: barebox; +Cc: Ahmad Fatoum
pe_close is the counterpart to pe_open. pe->code is set to non-NULL
outside pe_open by pe_load, so we should check for NULL before
attempting to free the SDRAM region.
Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
---
common/pe.c | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/common/pe.c b/common/pe.c
index 65d456a2c332..fd99761bddfd 100644
--- a/common/pe.c
+++ b/common/pe.c
@@ -373,7 +373,8 @@ int pe_load(struct pe_image *pe)
void pe_close(struct pe_image *pe)
{
- release_sdram_region(pe->code);
+ if (pe->code)
+ release_sdram_region(pe->code);
free(pe->bin);
free(pe);
}
--
2.39.5
^ permalink raw reply [flat|nested] 3+ messages in thread
* [PATCH master 3/3] barebox.h: annotate __hang as __noreturn
2025-04-04 15:55 [PATCH master 1/3] fs: add only successful filesystem probes to fs_device_list Ahmad Fatoum
2025-04-04 15:55 ` [PATCH master 2/3] common: pe: fix crash when pe_load was not called Ahmad Fatoum
@ 2025-04-04 15:55 ` Ahmad Fatoum
1 sibling, 0 replies; 3+ messages in thread
From: Ahmad Fatoum @ 2025-04-04 15:55 UTC (permalink / raw)
To: barebox; +Cc: Ahmad Fatoum
Otherwise, GCC may complain that other __noreturn functions calling
__hang can in fact return.
Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
---
include/barebox.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/include/barebox.h b/include/barebox.h
index 334dcfceffcf..02228451c26e 100644
--- a/include/barebox.h
+++ b/include/barebox.h
@@ -6,7 +6,7 @@
#include <linux/compiler.h>
/* For use when unrelocated */
-static inline void __hang(void)
+static inline __noreturn void __hang(void)
{
while (1);
}
--
2.39.5
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2025-04-04 15:55 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-04-04 15:55 [PATCH master 1/3] fs: add only successful filesystem probes to fs_device_list Ahmad Fatoum
2025-04-04 15:55 ` [PATCH master 2/3] common: pe: fix crash when pe_load was not called Ahmad Fatoum
2025-04-04 15:55 ` [PATCH master 3/3] barebox.h: annotate __hang as __noreturn Ahmad Fatoum
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox