You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
qemu/target/loongarch
Peter Maydell 1bb5257def target/loongarch: Explicitly set 2-NaN propagation rule
Set the 2-NaN propagation rule explicitly in the float_status word we
use.

(There are a couple of places in fpu_helper.c where we create a
dummy float_status word with "float_status *s = { };", but these
are only used for calling float*_is_quiet_nan() so it doesn't
matter that we don't set a 2-NaN propagation rule there.)

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20241025141254.2141506-6-peter.maydell@linaro.org
4 weeks ago
..
kvm target/loongarch: Add steal time support on migration 1 month ago
tcg target/loongarch: Explicitly set 2-NaN propagation rule 4 weeks ago
Kconfig hw/loongarch: Add support loongson3 virt machine type. 3 years ago
README docs/system/loongarch: Update the LoongArch document 2 years ago
arch_dump.c target/loongarch: Avoid bits shift exceeding width of bool type 2 months ago
cpu-csr.h target/loongarch: Fix tlb huge page loading issue 9 months ago
cpu-param.h target: Define TCG_GUEST_DEFAULT_MO in 'cpu-param.h' 7 months ago
cpu-qom.h target: Move ArchCPUClass definition to 'cpu.h' 1 year ago
cpu.c target/loongarch/kvm: Implement LoongArch PMU extension 1 month ago
cpu.h target/loongarch: Add steal time support on migration 1 month ago
cpu_helper.c target/loongarch: Add TCG macro in structure CPUArchState 7 months ago
disas.c target/loongarch: honour show_opcodes when disassembling 9 months ago
gdbstub.c target/loongarch: Use explicit little-endian LD/ST API 2 months ago
helper.h target/loongarch: Implement xvshuf xvperm{i} xvshuf4i 1 year ago
insns.decode target/loongarch: Add preldx instruction 1 year ago
internals.h target/loongarch: Support QMP dump-guest-memory 3 months ago
loongarch-qmp-cmds.c target/loongarch/kvm: Implement LoongArch PMU extension 1 month ago
machine.c target/loongarch: Add steal time support on migration 1 month ago
meson.build target/loongarch: Support QMP dump-guest-memory 3 months ago
trace-events target/loongarch: Implement set vcpu intr for kvm 11 months ago
trace.h target/loongarch: Implement kvm get/set registers 11 months ago
translate.h target/loongarch: Add avail_LASX to check LASX instructions 1 year ago
vec.h target/loongarch: Move simply DO_XX marcos togther 1 year ago

README

- 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/