====== 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: