mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 08:43:55 -06:00
target/sparc: Fix FEXPAND
This is a 2-operand instruction, not 3-operand. Worse, we took the source from the wrong operand. Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Message-Id: <20240502165528.244004-3-richard.henderson@linaro.org> Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
This commit is contained in:
parent
1cde1a2a89
commit
7b616f36de
4 changed files with 24 additions and 6 deletions
|
@ -4358,6 +4358,25 @@ TRANS(FSQRTd, ALL, do_env_dd, a, gen_helper_fsqrtd)
|
|||
TRANS(FxTOd, 64, do_env_dd, a, gen_helper_fxtod)
|
||||
TRANS(FdTOx, 64, do_env_dd, a, gen_helper_fdtox)
|
||||
|
||||
static bool do_df(DisasContext *dc, arg_r_r *a,
|
||||
void (*func)(TCGv_i64, TCGv_i32))
|
||||
{
|
||||
TCGv_i64 dst;
|
||||
TCGv_i32 src;
|
||||
|
||||
if (gen_trap_ifnofpu(dc)) {
|
||||
return true;
|
||||
}
|
||||
|
||||
dst = tcg_temp_new_i64();
|
||||
src = gen_load_fpr_F(dc, a->rs);
|
||||
func(dst, src);
|
||||
gen_store_fpr_D(dc, a->rd, dst);
|
||||
return advance_pc(dc);
|
||||
}
|
||||
|
||||
TRANS(FEXPAND, VIS1, do_df, a, gen_helper_fexpand)
|
||||
|
||||
static bool do_env_df(DisasContext *dc, arg_r_r *a,
|
||||
void (*func)(TCGv_i64, TCGv_env, TCGv_i32))
|
||||
{
|
||||
|
@ -4589,7 +4608,6 @@ TRANS(FMUL8ULx16, VIS1, do_ddd, a, gen_helper_fmul8ulx16)
|
|||
TRANS(FMULD8SUx16, VIS1, do_ddd, a, gen_helper_fmuld8sux16)
|
||||
TRANS(FMULD8ULx16, VIS1, do_ddd, a, gen_helper_fmuld8ulx16)
|
||||
TRANS(FPMERGE, VIS1, do_ddd, a, gen_helper_fpmerge)
|
||||
TRANS(FEXPAND, VIS1, do_ddd, a, gen_helper_fexpand)
|
||||
|
||||
TRANS(FPADD16, VIS1, do_ddd, a, tcg_gen_vec_add16_i64)
|
||||
TRANS(FPADD32, VIS1, do_ddd, a, tcg_gen_vec_add32_i64)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue