Pregunta

Soy consciente de que es posible utilizar readelf -d <elf> | grep RPATH inspeccionar un binario determinado de la cáscara, pero ¿es posible hacer esto dentro de un proceso?

Algo así como (mi completo compuesto por llamada al sistema):

  /* get a copy of current rpath into buffer */
  sys_get_current_rpath(&buffer);

Estoy tratando de diagnosticar algunas tan sospechoso vincular los temas en nuestra base de código, y que le gustaría inspeccionar la rPath esta manera, si es posible (que preferiría no tener que generar un script externo).

¿Fue útil?

Solución

#include <stdio.h>
#include <elf.h>
#include <link.h>

int main()
{
  const ElfW(Dyn) *dyn = _DYNAMIC;
  const ElfW(Dyn) *rpath = NULL;
  const char *strtab = NULL;
  for (; dyn->d_tag != DT_NULL; ++dyn) {
    if (dyn->d_tag == DT_RPATH) {
      rpath = dyn;
    } else if (dyn->d_tag == DT_STRTAB) {
      strtab = (const char *)dyn->d_un.d_val;
    }
  }

  if (strtab != NULL && rpath != NULL) {
    printf("RPATH: %s\n", strtab + rpath->d_un.d_val);
  }
  return 0;
}

Otros consejos

Para el registro, aquí hay un par de comandos que mostrará la cabecera rpath.

objdump -x binary-or-library |grep RPATH

Tal vez una mejor manera de hacerlo es la siguiente:

readelf -d binary-or-library |head -20

El segundo comando enumera también las dependencias directas sobre otras bibliotecas seguidos por rpath.

También puede usar:

chrpath -l binary-or-library
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top