1
0
Fork 0
qemu/target/loongarch
Daniel Baumann ea34ddeea6
Adding upstream version 1:10.0.2+ds.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
2025-06-22 14:27:05 +02:00
..
kvm Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
tcg Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
arch_dump.c Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
cpu-csr.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
cpu-param.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
cpu-qom.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
cpu.c Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
cpu.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
cpu_helper.c Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
csr.c Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
csr.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
disas.c Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
gdbstub.c Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
helper.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
insns.decode Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
internals.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
Kconfig Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
loongarch-qmp-cmds.c Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
machine.c Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
meson.build Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
README Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
trace-events Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
trace.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
translate.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00
vec.h Adding upstream version 1:10.0.2+ds. 2025-06-22 14:27:05 +02:00

- Introduction

  LoongArch is the general processor architecture of Loongson.

  The following versions of the LoongArch core are supported
    core: 3A5000
    https://github.com/loongson/LoongArch-Documentation/releases/download/2021.08.17/LoongArch-Vol1-v1.00-EN.pdf

  We can get the latest loongarch documents at https://github.com/loongson/LoongArch-Documentation/tags.


- System emulation

  You can reference docs/system/loongarch/loongson3.rst to get the information about system emulation of LoongArch.

- Linux-user emulation

  We already support Linux user emulation. We can use LoongArch cross-tools to build LoongArch executables on X86 machines,
  and We can also use qemu-loongarch64 to run LoongArch executables.

  1. Config cross-tools env.

     see System emulation.

  2. Test tests/tcg/multiarch.

     ./configure  --static  --prefix=/usr  --disable-werror --target-list="loongarch64-linux-user" --enable-debug

     cd build

     make && make check-tcg

  3. Run LoongArch system basic command with loongarch-clfs-system.

     - Config clfs env.

       wget https://github.com/loongson/build-tools/releases/download/2022.05.29/loongarch64-clfs-system-5.0.tar.bz2

       tar -vxf loongarch64-clfs-system-5.0.tar.bz2 -C /opt/clfs

       cp /opt/clfs/lib64/ld-linux-loongarch-lp64d.so.1  /lib64

       export LD_LIBRARY_PATH="/opt/clfs/lib64"

     - Run LoongArch system basic command.

       ./qemu-loongarch64  /opt/clfs/usr/bin/bash
       ./qemu-loongarch64  /opt/clfs/usr/bin/ls
       ./qemu-loongarch64  /opt/clfs/usr/bin/pwd

- Note.
  We can get the latest LoongArch documents or LoongArch tools at https://github.com/loongson/