for executing init array functions, use function type with prototype
authorRich Felker <dalias@aerifal.cx>
Fri, 13 Oct 2017 14:39:51 +0000 (10:39 -0400)
committerRich Felker <dalias@aerifal.cx>
Fri, 13 Oct 2017 14:39:51 +0000 (10:39 -0400)
this is for consistency with the way it's done in in the dynamic
linker, avoiding a deprecated C feature (non-prototype function
types), and improving code generation. GCC unnecessarily uses the
variadic calling convention (e.g. clearing rax on x86_64) when making
a call where the argument types are not known for compatibility with
wrong code which calls variadic functions this way. (C on the other
hand is clear that such calls have undefined behavior.)

src/env/__libc_start_main.c

index 18afdc1..2d758af 100644 (file)
@@ -58,7 +58,7 @@ static void libc_start_init(void)
        _init();
        uintptr_t a = (uintptr_t)&__init_array_start;
        for (; a<(uintptr_t)&__init_array_end; a+=sizeof(void(*)()))
-               (*(void (**)())a)();
+               (*(void (**)(void))a)();
 }
 
 weak_alias(libc_start_init, __libc_start_init);