qemu-e2k/target/loongarch
Thomas Huth c34ad45992 target/loongarch: Fix the CSRRD CPUID instruction on big endian hosts
The test in tests/avocado/machine_loongarch.py is currently failing
on big endian hosts like s390x. By comparing the traces between running
the QEMU_EFI.fd bios on a s390x and on a x86 host, it's quickly obvious
that the CSRRD instruction for the CPUID is behaving differently. And
indeed: The code currently does a long read (i.e. 64 bit) from the
address that points to the CPUState->cpu_index field (with tcg_gen_ld_tl()
in the trans_csrrd() function). But this cpu_index field is only an "int"
(i.e. 32 bit). While this dirty pointer magic works on little endian hosts,
it of course fails on big endian hosts. Fix it by using a proper helper
function instead.

Message-Id: <20230720175307.854460-1-thuth@redhat.com>
Reviewed-by: Song Gao <gaosong@loongson.cn>
Signed-off-by: Thomas Huth <thuth@redhat.com>
2023-07-24 18:44:48 +02:00
..
insn_trans target/loongarch: Fix the CSRRD CPUID instruction on big endian hosts 2023-07-24 18:44:48 +02:00
constant_timer.c target/loongarch: Add constant timer support 2022-06-06 18:09:03 +00:00
cpu-csr.h target/loongarch: Add CSRs definition 2022-06-06 18:09:03 +00:00
cpu-param.h target/loongarch: Remove NB_MMU_MODES define 2023-03-13 06:44:37 -07:00
cpu.c target/loongarch: Fix LD/ST{LE/GT} instructions get wrong CSR_ERA and CSR_BADV 2023-05-26 17:21:12 +08:00
cpu.h target/loongarch: Fix the CSRRD CPUID instruction on big endian hosts 2023-07-24 18:44:48 +02:00
csr_helper.c target/loongarch: Fix the CSRRD CPUID instruction on big endian hosts 2023-07-24 18:44:48 +02:00
disas.c target/loongarch: Implement vldi 2023-05-06 11:19:49 +08:00
fpu_helper.c target/loongarch: Implement LSX fpu arith instructions 2023-05-06 11:19:48 +08:00
gdbstub.c target/loongarch: Add LSX data type VReg 2023-05-06 11:19:42 +08:00
helper.h target/loongarch: Fix the CSRRD CPUID instruction on big endian hosts 2023-07-24 18:44:48 +02:00
insns.decode target/loongarch: Implement vldi 2023-05-06 11:19:49 +08:00
internals.h target/loongarch: Implement LSX fpu arith instructions 2023-05-06 11:19:48 +08:00
iocsr_helper.c target/loongarch: Do not include tcg-ldst.h 2023-05-11 09:53:41 +01:00
Kconfig hw/loongarch: Add support loongson3 virt machine type. 2022-06-06 18:09:03 +00:00
loongarch-qmp-cmds.c target/loongarch: Restrict 'qapi-commands-machine.h' to system emulation 2023-03-02 07:51:33 +01:00
lsx_helper.c target/loongarch: Implement vilvl vilvh vextrins vshuf 2023-05-06 11:19:49 +08:00
machine.c target/loongarch: Terminate vmstate subsections list 2023-05-10 09:52:36 +01:00
meson.build meson: Replace softmmu_ss -> system_ss 2023-06-20 10:01:30 +02:00
op_helper.c target/loongarch: Fix LD/ST{LE/GT} instructions get wrong CSR_ERA and CSR_BADV 2023-05-26 17:21:12 +08:00
README docs/system/loongarch: Update the LoongArch document 2022-08-13 04:45:03 -07:00
tlb_helper.c target/loongarch: Fix CSR.DMW0-3.VSEG check 2023-06-16 17:58:46 +08:00
translate.c target/*: Add missing includes of exec/translation-block.h 2023-06-05 12:04:29 -07:00
translate.h target/loongarch: Implement vadd/vsub 2023-05-06 11:19:45 +08: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/