de https://github.com/lattera/glibc/blob/master/include/libc-symbols.h
/* Define ALIASNAME as a weak alias for NAME.
If weak aliases are not available, this defines a strong alias. */
# define weak_alias(name, aliasname) _weak_alias (name, aliasname)
# define _weak_alias(name, aliasname) \
extern __typeof (name) aliasname __attribute__ ((weak, alias (#name)));
Acerca del símbolo débil:
https://en.wikipedia.org/wiki/Weak_symbol
Es una macro que hace lo siguiente:
Declara una función débil, si no proporcionó un nombre de símbolo fuerte para esa función, llamará a la función a la que lo ha asignado. por ejemplo
int _foo(){ return 1;}
//And weak alias
int __attribute__((weak, alias("_foo"))) foo();
Entonces, si no ha proporcionado una implementación real para foo, básicamente usará _foo y devolverá 1.