On Mon, 09 Dec 2019 10:11:30 PST (-0800), Alistair Francis wrote:
> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
> ---
> target/riscv/csr.c | 13 ++++++++++++-
> 1 file changed, 12 insertions(+), 1 deletion(-)
>
> diff --git a/target/riscv/csr.c b/target/riscv/csr.c
> index 54edfb280e..d028dfb60b 100644
> --- a/target/riscv/csr.c
> +++ b/target/riscv/csr.c
> @@ -744,8 +744,19 @@ static int write_sbadaddr(CPURISCVState *env, int csrno, target_ulong val)
> static int rmw_sip(CPURISCVState *env, int csrno, target_ulong *ret_value,
> target_ulong new_value, target_ulong write_mask)
> {
> - int ret = rmw_mip(env, CSR_MSTATUS, ret_value, new_value,
> + int ret;
> +
> + if (riscv_cpu_virt_enabled(env)) {
> + /* Shift the new values to line up with the VS bits */
> + ret = rmw_mip(env, CSR_MSTATUS, ret_value, new_value << 1,
> + (write_mask & sip_writable_mask) << 1 & env->mideleg);
> + ret &= vsip_writable_mask;
> + ret >>= 1;
> + } else {
> + ret = rmw_mip(env, CSR_MSTATUS, ret_value, new_value,
> write_mask & env->mideleg & sip_writable_mask);
> + }
> +
> *ret_value &= env->mideleg;
> return ret;
> }
Reviewed-by: Palmer Dabbelt <palmerdabbelt@google.com>