私の現在のセットアップは非常にエキゾチックであり、いくつかの説明を使用できます。
Quad Cortex-A53、64ビットCPUを搭載した Pinebook Pro で実行しています。 OSは64ビットバージョンのDebianです。
$ uname -a
Linux pinebook 4.4.196 #1 SMP Tue Oct 15 16:54:21 EDT 2019 aarch64 GNU/Linux
ただし、デフォルトではarmhfアーキテクチャのみが有効でした。
$ dpkg --print-architecture
armhf
Aarch64バイナリを実行したかったので、対応するアーキテクチャを追加しました。
$ dpkg --add-architecture arm64
$ apt update && apt upgrade
$ apt install gcc-6-base:arm64 libc6:arm64 libgcc1:arm64
これは問題なく動作しました。しかし、その後、突然/lib/ld-linux.so.3
が消えたため、別の32ビットバイナリを実行できなくなりました。検査すると、次の出力が得られました。
$ 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
実際、ld-linux.so.3
がありませんでした。その場所で、アーキテクチャ固有のシンボリックリンクを見つけました。
$ 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
Armhfアーキテクチャのld-linux.so.3
が必要だったので、/lib/arm-linux-gnueabihf/
の下で探しました。私の問題を解決するために、それを/lib
にリンクし、バイナリが再び機能しました。
$ ln -s /lib/arm-linux-gnueabihf/ld-linux.so.3 /lib/ld-linux.so.3
さて、質問:この問題を解決するには、/lib
を直接いじる必要がありましたが、これは理想的ではありません。望ましい解決策は何でしょうか?
このようなマルチアーチシステムでアプリケーションをコンパイルし、interpにパッチを適用します(patchelf --set-interpreter /lib/ld-linux-armhf.so.3 /usr/local/bin/openocd
) 出来なければ。または、対応する動的リンカー(/lib/ld-linux-armhf.so.3 /usr/local/bin/openocd
)。コマンド名をスクリプトまたはエイリアスでラップし、実際のバイナリを邪魔にならないように移動することで、最後の操作を行うことができます。