Entendendo o __libc_init_array

Eu vi o código-fonte de __libc_init_array dehttp://newlib.sourcearchive.com/documentation/1.18.0/init_8c-source.html .
Mas eu não entendo bem o que essa função faz.

Eu sei que esses símbolos

/* These magic symbols are provided by the linker.  */
extern void (*__preinit_array_start []) (void) __attribute__((weak));
extern void (*__preinit_array_end []) (void) __attribute__((weak));
extern void (*__init_array_start []) (void) __attribute__((weak));
extern void (*__init_array_end []) (void) __attribute__((weak));
extern void (*__fini_array_start []) (void) __attribute__((weak));
extern void (*__fini_array_end []) (void) __attribute__((weak));

é definido no script do vinculador.
Parte do script de vinculador pode se parecer com:

  .preinit_array     :
  {
    PROVIDE_HIDDEN (__preinit_array_start = .);
    KEEP (*(.preinit_array*))
    PROVIDE_HIDDEN (__preinit_array_end = .);
  } >FLASH
  .init_array :
  {
    PROVIDE_HIDDEN (__init_array_start = .);
    KEEP (*(SORT(.init_array.*)))
    KEEP (*(.init_array*))
    PROVIDE_HIDDEN (__init_array_end = .);
  } >FLASH
  ...

e, em seguida, procurei com a chave "init_array" nos documentos ELF-v1.1, gcc 4.7.2, ld e codesourcery (estou usando o codeourcery g ++ lite) apenas para não obter nada.

Onde posso encontrar a especificação desses símbolos?