Forma correcta de agregar /lib/ld-linux.so.3 en Debian

Forma correcta de agregar /lib/ld-linux.so.3 en Debian

Mi configuración actual es bastante exótica y me vendría bien alguna aclaración.

estoy corriendo en unPinebook Pro, impulsado por una CPU Quad Cortex-A53 de 64 bits. El sistema operativo es una versión de 64 bits de Debian:

$ uname -a
Linux pinebook 4.4.196 #1 SMP Tue Oct 15 16:54:21 EDT 2019 aarch64 GNU/Linux

Sin embargo, de forma predeterminada solo estaba habilitada la arquitectura armhf:

$ dpkg --print-architecture
armhf

Como quería ejecutar los binarios de aarch64, agregué la arquitectura correspondiente:

$ dpkg --add-architecture arm64
$ apt update && apt upgrade
$ apt install gcc-6-base:arm64 libc6:arm64 libgcc1:arm64

Esto funcionó sin problemas. Sin embargo, después de esto descubrí que ya no podía ejecutar otro binario de 32 bits porque de repente /lib/ld-linux.so.3había desaparecido. Inspeccionarlo me dio el siguiente resultado.

$ file openocd 
openocd: ELF 32-bit LSB shared object, ARM, EABI5 version 1 (SYSV), dynamically linked, interpreter /lib/ld-linux.so.3, for GNU/Linux 3.2.0, BuildID[sha1]=363651b03c33118c80584e99b6f876c7a8663325, stripped

De hecho, ld-linux.so.3faltaba. En su lugar encontré enlaces simbólicos específicos de la arquitectura:

$ ls /lib
aarch64-linux-gnu    firmware               ld-linux-armhf.so.3  systemd
arm-linux-gnueabihf  ifupdown               lsb                  terminfo
cpp                  init                   modprobe.d           udev
dhcpcd               ld-linux-aarch64.so.1  modules           

Como necesitaba ld-linux.so.3de armhf Architecture, lo busqué debajo /lib/arm-linux-gnueabihf/y, efectivamente, allí estaba. Para resolver mi problema, lo vinculé /liby el binario volvió a funcionar.

$ ln -s /lib/arm-linux-gnueabihf/ld-linux.so.3 /lib/ld-linux.so.3

Ahora, la pregunta: para solucionar este problema tuve que meterme directamente con /lib, lo cual no es lo ideal. ¿Cuál sería la solución preferida?

Respuesta1

Compile la aplicación en dicho sistema de múltiples arcos, parchee la interfaz ( patchelf --set-interpreter /lib/ld-linux-armhf.so.3 /usr/local/bin/openocd) si no puede. O llame explícitamente al binario vinculado dinámicamente a través del vinculador dinámico correspondiente ( /lib/ld-linux-armhf.so.3 /usr/local/bin/openocd). Puede hacer lo último envolviendo el nombre del comando en un script o alias y apartando el binario real.

información relacionada