X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=lib%2Finitcall.c;h=714274415c9f2e3ab21783f3e0806c466908d84d;hb=0d3f732fd2ba679b4498541f075d1b1bdbea3935;hp=7597bad555404a276a72afd4bda981e0f4187ce7;hpb=61e76f53708cf082ef9061a140b57df3513b8ba1;p=platform%2Fkernel%2Fu-boot.git diff --git a/lib/initcall.c b/lib/initcall.c index 7597bad..7142744 100644 --- a/lib/initcall.c +++ b/lib/initcall.c @@ -15,14 +15,20 @@ int initcall_run_list(const init_fnc_t init_sequence[]) for (init_fnc_ptr = init_sequence; *init_fnc_ptr; ++init_fnc_ptr) { unsigned long reloc_ofs = 0; + int ret; if (gd->flags & GD_FLG_RELOC) reloc_ofs = gd->reloc_off; - debug("initcall: %p\n", (char *)*init_fnc_ptr - reloc_ofs); - if ((*init_fnc_ptr)()) { - printf("initcall sequence %p failed at call %p\n", + debug("initcall: %p", (char *)*init_fnc_ptr - reloc_ofs); + if (gd->flags & GD_FLG_RELOC) + debug(" (relocated to %p)\n", (char *)*init_fnc_ptr); + else + debug("\n"); + ret = (*init_fnc_ptr)(); + if (ret) { + printf("initcall sequence %p failed at call %p (err=%d)\n", init_sequence, - (char *)*init_fnc_ptr - reloc_ofs); + (char *)*init_fnc_ptr - reloc_ofs, ret); return -1; } }