「Linuxコマンド - chroot」の版間の差分

提供:MochiuWiki : SUSE, EC, PCB
ナビゲーションに移動 検索に移動
編集の要約なし
3行目: 3行目:
<br><br>
<br><br>


== QEMUのインストール ==
== QEMU-User-Staticのインストール ==
QEMU-User-Staticは、クロスアーキテクチャの開発者にとって重要なツールである。<br>
QEMU-User-Staticは、クロスアーキテクチャの開発者にとって重要なツールである。<br>
これにより、ユーザはchroot環境を作成して、クロスコンパイルされたプログラムを実行することができる。<br>
これにより、ユーザはchroot環境を作成して、クロスコンパイルされたプログラムを実行することができる。<br>
68行目: 68行目:
  make -j $(nproc) または ninja -C .
  make -j $(nproc) または ninja -C .
  make install    または ninja -C . install
  make install    または ninja -C . install
<br>
QEMU-User-Staticの設定スクリプトをコピーする。<br>
mkdir /<QEMU-User-Staticのインストールディレクトリ>/sbin
cp /<QEMUのソースコードがあるディレクトリ>/scripts/qemu-binfmt-conf.sh  /<QEMU-User-Staticのインストールディレクトリ>/sbin
<br>
~/.profileファイル等に環境変数<code>PATH</code>を追記する。<br>
vi ~/.profile
<br>
# ~/.profileファイル等
export PATH="/<QEMU-User-Staticのインストールディレクトリ>/bin:/<QEMU-User-Staticのインストールディレクトリ>/sbin:$PATH"
<br>
<br>
<u>以下に示す設定は、任意である。</u><br>
<u>以下に示す設定は、任意である。</u><br>
78行目: 89行目:


== 例 : openSUSE Tumbleweed (PinePhone) ==
== 例 : openSUSE Tumbleweed (PinePhone) ==
AArch64命令セットを動作させるために必要なライブラリをインストールする。<br>
sudo zypper install qemu-arm qemu-linux-user qemu-uefi-aarch64
<br>
x86またはx64のPCを使用している場合、ARMバイナリのQEMU変換を設定する。<br>
x86またはx64のPCを使用している場合、ARMバイナリのQEMU変換を設定する。<br>
もし、ARM PCを使用している場合は、この操作は行わない。<br>
もし、ARM PCを使用している場合は、この操作は行わない。<br>
# パッケージ管理システムからインストールしている場合
  sudo /usr/sbin/qemu-binfmt-conf.sh
  sudo /usr/sbin/qemu-binfmt-conf.sh
# ソースコードからインストールしている場合
sudo /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh /<QEMU-User-Staticのインストールディレクトリ>/bin
<br>
<br>
イメージファイルのルートファイルシステムにおいて、オフセットを確認する。<br>
イメージファイルのルートファイルシステムにおいて、オフセットを確認する。<br>
112行目: 124行目:


== 例 : Raspbian OS (AArch64) ==
== 例 : Raspbian OS (AArch64) ==
AArch64命令セットを動作させるために必要なライブラリをインストールする。<br>
x86またはx64のPCを使用している場合、ARMバイナリのQEMU変換を設定する。<br>
  sudo zypper install qemu-arm qemu-linux-user qemu-uefi-aarch64
もし、ARM PCを使用している場合は、この操作は行わない。<br>
<br>
# パッケージ管理システムからインストールしている場合
以下のコマンドを実行する。<br>
  sudo /usr/sbin/qemu-binfmt-conf.sh
  sudo qemu-binfmt-conf.sh
# ソースコードからインストールしている場合
  sudo /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh /<QEMU-User-Staticのインストールディレクトリ>/bin
<br>
<br>
イメージファイルのルートファイルシステムにおいて、オフセットを確認する。<br>
イメージファイルのルートファイルシステムにおいて、オフセットを確認する。<br>

2022年4月28日 (木) 14:07時点における版

概要



QEMU-User-Staticのインストール

QEMU-User-Staticは、クロスアーキテクチャの開発者にとって重要なツールである。
これにより、ユーザはchroot環境を作成して、クロスコンパイルされたプログラムを実行することができる。

例えば、ユーザはシステムレベルのエミュレーションのオーバーヘッド無しに、AArch64の実行ファイルを実行することができる。

パッケージ管理システムからインストール

sudo zypper install qemu-arm qemu-linux-user qemu-uefi-aarch64


ソースコードからインストール

QEMUのビルドに必要なライブラリをインストールする。

sudo zypper install flex bison automake gcc gcc-c++ make glibc glibc-utils glibc-devel-static glib2-devel glibc-utils ncurses-devel libxml2-devel \
                    glibc-devel-static glibc-devel-static-32bit glib2-devel glib2-devel-static glib2-devel-32bit \
                    zlib-devel zlib-devel-32bit zlib-devel-static zlib-devel-static-32bit libpcap-devel-static readline-devel-static xfsprogs-devel \
                    pcre-devel-static pcre2-devel pcre2-devel-static gmp-devel \
                    gtk3-devel libgnutls-devel libnettle-devel libseccomp-devel liburing-devel libgbm-devel glusterfs-devel \
                    libjpeg8-devel libpng16-devel libpulse-devel alsa-devel libjack-devel spice-protocol-devel libspice-server-devel \
                    libxkbcommon-devel libxkbcommon-x11-devel libcap-devel libcap-ng-devel libpcap-devel libcurl-devel libudev-devel virglrenderer-devel \
                    libiscsi-devel libzstd-devel libnfs-devel libvdeplug-devel brlapi-devel libSDL2-devel libSDL2_image-devel librados-devel \
                    lzfse-devel libmpath0 libcacard-devel lzo-devel snappy-devel libgcrypt-devel libu2f-server-devel libu2f-host-devel \
                    usbredir-devel libusb-1_0-devel libpmem-devel libkeyutils1 keyutils-devel libselinux-devel fuse-devel fuse3-devel libbpf-devel \
                    libbd_swap-devel libcapstone-devel libslirp-devel libfdt-devel sphinx libsphinxclient-devel  numad libnuma1 numactl libnuma-devel \
                    librbd-devel rdma-core-devel libnet-devel libfvde-devel libdmmp-devel multipath-tools-devel libssh-devel libssh2-devel \
                    rpcbind rpcgen readline-devel libyajl-devel libpciaccess-devel device-mapper-devel libtirpc-devel libnl3-devel libpixman-1-0-devel \
                    libxslt-devel python3-docutils capstone libcapstone4 libcapstone-devel python3-capstone 


QEMUのソースコードをダウンロードする。

  • QEMUの公式Webサイトから、ソースコードをダウンロードする場合
    QEMUの公式Webサイトにアクセスして、ソースコードをダウンロードする。
    ダウンロードしたファイルを解凍する。
    tar xf qemu-<バージョン>.tar.xz
    cd qemu-<バージョン>

  • Gitからソースコードをダウンロードする場合
    git clone git://git.qemu.org/qemu.git
    cd qemu
    git submodule update --init --recursive


QEMUをQEMU-User-Staticとして、ビルドおよびインストールする。

mkdir build && cd build


--disable-systemオプションを指定する時、softmmuターゲットが無効になる。
ただし、softmmuターゲットがいくつかの共有ライブラリに依存していることは知られている。
--staticオプションを指定した場合、これらのsoftmmuターゲットはリンクエラーを引き起こす。

../configure --prefix=<QEMU-User-Staticのインストールディレクトリ> \
             --enable-linux-user --static \
             --disable-system --disable-blobs --disable-brlapi --disable-cap-ng --disable-capstone  \
             --disable-curl --disable-curses --disable-docs --disable-gcrypt --disable-gnutls \
             --disable-gtk --disable-guest-agent --disable-guest-agent-msi --disable-libiscsi \
             --disable-libnfs --disable-mpath --disable-nettle --disable-opengl --disable-pie \
             --disable-sdl --disable-spice --disable-tools --disable-vte --disable-werror \
             --disable-debug-info --disable-glusterfs \
             --extra-ldflags=-latomic \
             --target-list=aarch64-linux-user,arm-linux-user \
             # 以下のオプションは任意である
             --cross-prefix=$(info)-                        \
             --host-cc=clang \
             --host=$(clang --print-target-triple)          \
             --build=$(TARGETPLATFORM= TARGETPAIR= clang --print-target-triple) \
             --cc=clang                 \
             --disable-system           \  # ArmおよびAArch64のみをインストールする場合は、--target-list=arm-linux-user,armeb-linux-user,aarch64-linux-userオプションを指定する
             --enable-capstone=internal \  # その他の値として、enabled, disabled, auto等がある (このオプションは不要の可能性あり)

make -j $(nproc) または ninja -C .
make install     または ninja -C . install


QEMU-User-Staticの設定スクリプトをコピーする。

mkdir /<QEMU-User-Staticのインストールディレクトリ>/sbin
cp /<QEMUのソースコードがあるディレクトリ>/scripts/qemu-binfmt-conf.sh  /<QEMU-User-Staticのインストールディレクトリ>/sbin


~/.profileファイル等に環境変数PATHを追記する。

vi ~/.profile


# ~/.profileファイル等

export PATH="/<QEMU-User-Staticのインストールディレクトリ>/bin:/<QEMU-User-Staticのインストールディレクトリ>/sbin:$PATH"


以下に示す設定は、任意である。
ファイル名がコンフリクト(衝突)を起こさないように、ファイル名を変更する。
以下の例では、ファイル名に-staticサフィックスを追加している。

cd /<QEMU-User-Staticのインストールディレクトリ>/bin

bash -c 'for i in *; do cp ${i} ${i}-static; done'



例 : openSUSE Tumbleweed (PinePhone)

x86またはx64のPCを使用している場合、ARMバイナリのQEMU変換を設定する。
もし、ARM PCを使用している場合は、この操作は行わない。

# パッケージ管理システムからインストールしている場合
sudo /usr/sbin/qemu-binfmt-conf.sh

# ソースコードからインストールしている場合
sudo /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh /<QEMU-User-Staticのインストールディレクトリ>/bin


イメージファイルのルートファイルシステムにおいて、オフセットを確認する。
この時、raw2拡張子の開始位置と1セクタのサイズを乗算して、ルートファイルシステムのオフセットを求める。

sudo fdisk -l <openSUSE Tumbleweedのイメージファイル名>.raw


openSUSE Tumbleweedのイメージファイルをマウントする。
以下の例では、/mntディレクトリにマウントしている。

sudo mount -t btrfs -o loop,offset=<ルートファイルシステムのオフセット  例: raw2拡張子の開始位置と1セクタのサイズを乗算した値> <openSUSE Tumbleweedのイメージファイル名>.raw /mnt

sudo mount --rbind /sys  /mnt/sys  && sudo mount --make-rslave /mnt/sys  && \
sudo mount --rbind /dev  /mnt/dev  && sudo mount --make-rslave /mnt/dev  && \
sudo mount --rbind /proc /mnt/proc && sudo mount --make-rslave /mnt/proc && \
sudo mount --rbind /dev/pts /mnt/dev/pts

sudo cp /run/netconfig/resolv.conf /mnt/etc/


AArch64命令セットをエミュレートするために必要なファイルを、openSUSE Tumbleweed (PinePhone)のマウント先ディレクトリにコピーする。

sudo cp /usr/bin/qemu-aarch64-binfmt /usr/bin/qemu-aarch64 /mnt/usr/bin/


openSUSE Tumbleweed (PinePhone)の環境にchrootする。

sudo chroot /mnt qemu-aarch64 /bin/bash


openSUSE Tumbleweed (PinePhone)の環境を終了する場合は、ターミナルからexitコマンドを実行した後、
openSUSE Tumbleweed (PinePhone)のイメージファイルをアンマウントする。

sudo umount -fl /mnt



例 : Raspbian OS (AArch64)

x86またはx64のPCを使用している場合、ARMバイナリのQEMU変換を設定する。
もし、ARM PCを使用している場合は、この操作は行わない。

# パッケージ管理システムからインストールしている場合
sudo /usr/sbin/qemu-binfmt-conf.sh

# ソースコードからインストールしている場合
sudo /<QEMU-User-Staticのインストールディレクトリ>/sbin/qemu-binfmt-conf.sh /<QEMU-User-Staticのインストールディレクトリ>/bin


イメージファイルのルートファイルシステムにおいて、オフセットを確認する。
この時、img3拡張子の開始位置と1セクタのサイズを乗算して、ルートファイルシステムのオフセットを求める。

sudo fdisk -l <Raspbian OS (AArch64)のイメージファイル名>.img


Raspbian OS (AArch64)のイメージファイルをマウントする。
以下の例では、/mntディレクトリにマウントしている。

sudo mount -t ext4 -o loop,offset=<ルートファイルシステムのオフセット  例: img3拡張子の開始位置と1セクタのサイズを乗算した値> <Raspbian OS (AArch64)のイメージファイル名>.raw /mnt


AArch64命令セットを動作させるために必要なライブラリを、Raspbian OS (AArch64)のマウント先ディレクトリにコピーする。

sudo cp /usr/bin/qemu-aarch64-binfmt /usr/bin/qemu-aarch64 /mnt/bin/


chrootコマンドを実行して、Raspbian OS (AArch64)を起動する。

sudo chroot /mnt qemu-aarch64 /bin/bash


終了する場合は、Raspbian OS (AArch64)のイメージファイルをアンマウントする。

sudo umount -fl /mnt