====== run x86_64 auf ARM ====== Auf einer ARM CPU basierenden Computer wie z.B. den Raspberry Pi möchte ich x86_64Bit Anwendungen ausführen. Dafür benötigt man zunächst einen Raspberry Pi ab der Version 3, denn hier ist sicher ein 64 Bit CPU verbaut. Ausserdem wird ein 64 Bit OS benötigt. Suse hatte schon recht früh 64Bit für ARM angeboten nun gibt es das auch vom Raspberry Pi OS. ===== box64 ===== Mit ''box64'' x86_64 Anwendungen auf ARM ausführen. Hier am Bespiel der x86_64 Bit Anwendung guarda: box64 guarda Man kann vorher noch Umgebungsvariablen setzen um das Verhalten von ''box64'' zu beeinflussen. export BOX64_NOBANNER=0 export BOX64_NOPULSE=1 ===== schroot ===== Mit ''schroot'' wird einem ein Teil der Arbeit abgenommen, es übernimmt das Mounten der benötigten Verzeichnisse aus dem Hauptsystem. Die gemounteten Pfade können, falls benötigt, unter ''/etc/schroot/desktop/fstab'' bearbeitet werden. Die neuen Pakete ''schroot'', ''qemu'' und ''debootstrap'' installieren + weitere: sudo apt install schroot qemu qemu-user qemu-user-static binfmt-support debootstrap binutils Eine Datei für eine neue ''chroot'' Umgebung anlegen: sudo nano /etc/schroot/chroot.d/bullseye-amd64 Mit dem Inhalt: [bullseye-amd64] description=chroot-bullseye-amd64 aliases=kryptowallets directory=/home/pi/chroot-bullseye-amd64 users=root,pi type=directory profile=desktop personality=linux preserve-environment=false Zunächst einmal den Ordner anlegen wo die schroot-Umgebung innewohnt: mkdir ~/chroot-bullseye-amd64 Den schroot Dienst neu-starten: systemctl restart schroot Dann probieren einzuloggen, musste sein bei meinen Tests, da wohl dann erst weitere Ordner unter ~/chroot-bullseye-amd64 angelegt werden: schroot -c kryptowallets Mit ''debootstrap'' die **x86_64** Umgebung anlegen: sudo debootstrap --foreign --arch amd64 bullseye ./chroot-bullseye-amd64/ http://ftp.us.debian.org/debian Separating the two stages is only needed if you are bootstrapping a distribution for a foreign architecture (CrossDebootstrap). See the description of the ''--foreign'' option on the man page. For example, using a x86 machine to create a Debian/Ubuntu installation for an embedded ARM or PowerPC system. The first stage downloads the needed .deb files and unpacks them into the directory you specify. The second stage runs all of the package configuration scripts, which must be done using the target architecture (or by using qemu-user-static to emulate the target architecture). If you're not building an install for a foreign architecture, the stages are combined and you can ignore the ''--second-stage'' option. Den Kommando zunächst **nicht** ausführen: sudo chroot ./chroot-bullseye-amd64/ /debootstrap/debootstrap --second-stage Dann evtl. noch den Dienst ''binfmt-support.service'' neustarten: systemctl restart binfmt-support.service Ab nun kann man den ''chroot'' Container betreten, als root: sudo schroot -c kryptowallets oder als normaler Nutzer: schroot -c kryptowallets ==== Bei Fehlern ==== Hinweis: Es kann vorkommen, dass die ''chroot'' hängen bleibt. Um die gemounteten Ressourcen wieder frei zu bekommen, könnten folgende Befehle hilfreich sein... Zeigt alle Sessions an die noch laufen. sudo schroot -l --all-sessions Beendet normalerweise alle Sessions sudo schroot -e --all-sessions ==== Alternativ ==== sudo raspi-config # enable OpenGL driver sudo apt install -y debootstrap schroot cat << EOF | sudo tee /etc/schroot/chroot.d/pi64 [pi64] description=VC4 arm64 testing type=directory directory=/srv/chroot/pi64 users=pi root-groups=root profile=desktop personality=linux preserve-environment=true EOF sudo debootstrap --arch arm64 stable /srv/chroot/pi64 sudo schroot -c pi64 -- apt install -y mesa-utils minetest sudo schroot -c pi64 First you need to run the command below: sudo apt install -y raspbian-nspawn-64 You'll be prompted to enable 64-bit. Select Yes, hit Enter and reboot the system. Then you should be good to go and run: