From: Alistair Francis Date: Wed, 12 Aug 2020 19:13:38 +0000 (-0700) Subject: target/riscv: Only support a single VSXL length X-Git-Tag: qemu-xen-4.16.0-rc4~678^2~4 X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=f8dc878efc45691be7e6c2019a19c271fb9aebbb;p=qemu-xen.git target/riscv: Only support a single VSXL length Signed-off-by: Alistair Francis Message-id: f3f4fd2ec22a07cc1d750e96895d6813f131de4d.1597259519.git.alistair.francis@wdc.com Message-Id: --- diff --git a/target/riscv/csr.c b/target/riscv/csr.c index f9ac21d687..390ef781e4 100644 --- a/target/riscv/csr.c +++ b/target/riscv/csr.c @@ -836,12 +836,21 @@ static int write_satp(CPURISCVState *env, int csrno, target_ulong val) static int read_hstatus(CPURISCVState *env, int csrno, target_ulong *val) { *val = env->hstatus; +#ifdef TARGET_RISCV64 + /* We only support 64-bit VSXL */ + *val = set_field(*val, HSTATUS_VSXL, 2); +#endif return 0; } static int write_hstatus(CPURISCVState *env, int csrno, target_ulong val) { env->hstatus = val; +#ifdef TARGET_RISCV64 + if (get_field(val, HSTATUS_VSXL) != 2) { + qemu_log_mask(LOG_UNIMP, "QEMU does not support mixed HSXLEN options."); + } +#endif return 0; }