Инструменты компилятора, execv и "ошибка формата exec" в chroot s390x
У меня машина Debian 8 x86_64 с двумя средами chroot. Первый armel
а второй s390x
, armel
был установлен на прошлой неделе, и s390x
был установлен недавно. armel
хорошо как до, так и после s390x
установить. Но я ловлю ошибки при компиляции под недавно установленный s390x
,
# chroot debian-s390x
# g++ -dumpmachine
s390x-linux-gnu
# cd /home/cryptopp-5.6.3/
# make
g++ -DNDEBUG -g2 -O2 -pipe -c osrng.cpp
g++: error trying to exec '/usr/lib/gcc/s390x-linux-gnu/5/cc1plus': execv: Exec format error
GNUmakefile:382: recipe for target 'osrng.o' failed
make: *** [osrng.o] Error 1
Я не могу найти информацию при поиске /usr/lib/gcc/s390x-linux-gnu/5/cc1plus': execv: Exec format error
,
Я нашел некоторые чтения, связанные с cc1plus
, но я не вижу, где есть проблемы с установкой:
# file /usr/lib/gcc/s390x-linux-gnu/5/cc1plus
/usr/lib/gcc/s390x-linux-gnu/5/cc1plus: ELF 64-bit MSB executable, IBM S/390, version 1
(GNU/Linux), dynamically linked, interpreter /lib/ld64.so.1, for GNU/Linux 2.6.32,
BuildID[sha1]=aaa1e442e47e5e41c36b70d5e6a8f538da4ca3e7, not stripped
Я также выполнил переустановку g++
с apt-get install --reinstall g++
, но это не помогло.
В чем проблема, и каково ее решение?
РЕДАКТИРОВАТЬ: это может быть проблема, или может быть связана проблема: Ошибка Debian 684909: qemu-system-s390x не работает, нет загрузчика 's390-zipl.rom'.
Я не верю, что это связано с проектом, который я пытаюсь скомпилировать:
# cat test.cxx
#include <iostream>
int main(int argc, char* argv[])
{
return argc;
}
# g++ test.cxx
g++: error trying to exec '/usr/lib/gcc/s390x-linux-gnu/5/cc1plus': execv: Exec format error
Вот 5-секундный обзор процедуры установки среды debian-s390x:
# apt-get install qemu-user-static debootstrap
# qemu-debootstrap --arch=s390x --keyring /usr/share/keyrings/debian-archive-keyring.gpg
--variant=buildd --exclude=debfoster unstable debian-s390x http://ftp.debian.org/debian
# chroot debian-s390x
# apt-get install locales build-essentials emacs-nox
1 ответ
Это оказалось проблемой с регистрацией binfmt. Взяв сообщение Михаила Токарева в выпуске Debian 799120: cc1/cc1plus завершается с ошибкой "execv: exec format error" в QEMU s390x, не может скомпилировать программу C++:
Это было исправлено в версии, против которой вы сообщили об этой проблеме, 1:2.4+dfsg-3, где я обновил маски binfmt, добавив в них также OSABI_GNU. Это был #784605.
Однако, похоже, у нас проблема с обновлением регистраций binfmt. Если у вас ранее был установлен пакет qemu-user-static (который регистрирует только вариант OSABI_SYSV) и обновите его до текущей версии (которая должна регистрировать как варианты SYSV, так и GNU), регистрация в ядре не обновляется. Он будет обновлен при перезагрузке, или вы можете удалить и переустановить пакет qemu-user-static, после чего он заработает.