mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-08 02:03:56 -06:00
target/riscv: Add Zvksh ISA extension support
This commit adds support for the Zvksh vector-crypto extension, which consists of the following instructions: * vsm3me.vv * vsm3c.vi Translation functions are defined in `target/riscv/insn_trans/trans_rvvk.c.inc` and helpers are defined in `target/riscv/vcrypto_helper.c`. Co-authored-by: Kiran Ostrolenk <kiran.ostrolenk@codethink.co.uk> [max.chou@sifive.com: Replaced vstart checking by TCG op] Signed-off-by: Kiran Ostrolenk <kiran.ostrolenk@codethink.co.uk> Signed-off-by: Lawrence Hunter <lawrence.hunter@codethink.co.uk> Signed-off-by: Max Chou <max.chou@sifive.com> Reviewed-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com> [max.chou@sifive.com: Exposed x-zvksh property] Message-ID: <20230711165917.2629866-12-max.chou@sifive.com> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
This commit is contained in:
parent
fcf1943376
commit
2350881c44
6 changed files with 177 additions and 2 deletions
|
@ -500,3 +500,34 @@ static bool trans_vsha2ch_vv(DisasContext *s, arg_rmrr *a)
|
|||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/*
|
||||
* Zvksh
|
||||
*/
|
||||
|
||||
#define ZVKSH_EGS 8
|
||||
|
||||
static inline bool vsm3_check(DisasContext *s, arg_rmrr *a)
|
||||
{
|
||||
int egw_bytes = ZVKSH_EGS << s->sew;
|
||||
int mult = 1 << MAX(s->lmul, 0);
|
||||
return s->cfg_ptr->ext_zvksh == true &&
|
||||
require_rvv(s) &&
|
||||
vext_check_isa_ill(s) &&
|
||||
!is_overlapped(a->rd, mult, a->rs2, mult) &&
|
||||
MAXSZ(s) >= egw_bytes &&
|
||||
s->sew == MO_32;
|
||||
}
|
||||
|
||||
static inline bool vsm3me_check(DisasContext *s, arg_rmrr *a)
|
||||
{
|
||||
return vsm3_check(s, a) && vext_check_sss(s, a->rd, a->rs1, a->rs2, a->vm);
|
||||
}
|
||||
|
||||
static inline bool vsm3c_check(DisasContext *s, arg_rmrr *a)
|
||||
{
|
||||
return vsm3_check(s, a) && vext_check_ss(s, a->rd, a->rs2, a->vm);
|
||||
}
|
||||
|
||||
GEN_VV_UNMASKED_TRANS(vsm3me_vv, vsm3me_check, ZVKSH_EGS)
|
||||
GEN_VI_UNMASKED_TRANS(vsm3c_vi, vsm3c_check, ZVKSH_EGS)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue