Series |
target/ppc: PowerISA Vector/VSX instruction batch
|
expand
-
[v2,00/38] target/ppc: PowerISA Vector/VSX instruction batch
-
[v2,01/38] target/ppc: Introduce TRANS*FLAGS macros
-
[v2,02/38] target/ppc: moved vector even and odd multiplication to decodetree
-
[v2,03/38] target/ppc: Moved vector multiply high and low to decodetree
-
[v2,04/38] target/ppc: vmulh* instructions use gvec
-
[v2,05/38] target/ppc: Implement vmsumcud instruction
-
[v2,06/38] target/ppc: Implement vmsumudm instruction
-
[v2,07/38] target/ppc: Move vexts[bhw]2[wd] to decodetree
-
[v2,08/38] target/ppc: Implement vextsd2q
-
[v2,09/38] target/ppc: Move Vector Compare Equal/Not Equal/Greater Than to decodetree
-
[v2,10/38] target/ppc: Move Vector Compare Not Equal or Zero to decodetree
-
[v2,11/38] target/ppc: Implement Vector Compare Equal Quadword
-
[v2,12/38] target/ppc: Implement Vector Compare Greater Than Quadword
-
[v2,13/38] target/ppc: Implement Vector Compare Quadword
-
[v2,14/38] target/ppc: implement vstri[bh][lr]
-
[v2,15/38] target/ppc: implement vclrlb
-
[v2,16/38] target/ppc: implement vclrrb
-
[v2,17/38] target/ppc: implement vcntmb[bhwd]
-
[v2,18/38] target/ppc: implement vgnb
-
[v2,19/38] target/ppc: Move vsel and vperm/vpermr to decodetree
-
[v2,20/38] target/ppc: Move xxsel to decodetree
-
[v2,21/38] target/ppc: move xxperm/xxpermr to decodetree
-
[v2,22/38] target/ppc: Move xxpermdi to decodetree
-
[v2,23/38] target/ppc: Implement xxpermx instruction
-
[v2,24/38] tcg/tcg-op-gvec.c: Introduce tcg_gen_gvec_4i
-
[v2,25/38] target/ppc: Implement xxeval
-
[v2,26/38] target/ppc: Implement xxgenpcv[bhwd]m instruction
-
[v2,27/38] target/ppc: move xs[n]madd[am][ds]p/xs[n]msub[am][ds]p to decodetree
-
[v2,28/38] target/ppc: implement xs[n]maddqp[o]/xs[n]msubqp[o]
-
[v2,29/38] target/ppc: Implement xvtlsbb instruction
-
[v2,30/38] target/ppc: Remove xscmpnedp instruction
-
[v2,31/38] target/ppc: Refactor VSX_SCALAR_CMP_DP
-
[v2,32/38] target/ppc: Implement xscmp{eq,ge,gt}qp
-
[v2,33/38] target/ppc: Implement do_helper_XX3 and move xxperm* to use it
-
[v2,34/38] target/ppc: Move xscmp{eq,ge,gt}dp to decodetree
-
[v2,35/38] target/ppc: Move xs{max, min}[cj]dp to use do_helper_XX3
-
[v2,36/38] target/ppc: Refactor VSX_MAX_MINC helper
-
[v2,37/38] target/ppc: Implement xs{max,min}cqp
-
[v2,38/38] target/ppc: Implement xvcvbf16spn and xvcvspbf16 instructions
|
From: Matheus Ferst <matheus.ferst@eldorado.org.br> This patch series implements 5 missing instructions from PowerISA v3.0 and 40 new instructions from PowerISA v3.1, moving 62 other instructions to decodetree along the way. v2: - New patch (30) to remove xscmpnedp Lucas Coutinho (2): target/ppc: Move vexts[bhw]2[wd] to decodetree target/ppc: Implement vextsd2q Lucas Mateus Castro (alqotel) (3): target/ppc: moved vector even and odd multiplication to decodetree target/ppc: Moved vector multiply high and low to decodetree target/ppc: vmulh* instructions use gvec Luis Pires (1): target/ppc: Introduce TRANS*FLAGS macros Matheus Ferst (20): target/ppc: Move Vector Compare Equal/Not Equal/Greater Than to decodetree target/ppc: Move Vector Compare Not Equal or Zero to decodetree target/ppc: Implement Vector Compare Equal Quadword target/ppc: Implement Vector Compare Greater Than Quadword target/ppc: Implement Vector Compare Quadword target/ppc: implement vstri[bh][lr] target/ppc: implement vclrlb target/ppc: implement vclrrb target/ppc: implement vcntmb[bhwd] target/ppc: implement vgnb target/ppc: Move vsel and vperm/vpermr to decodetree target/ppc: Move xxsel to decodetree target/ppc: move xxperm/xxpermr to decodetree target/ppc: Move xxpermdi to decodetree target/ppc: Implement xxpermx instruction tcg/tcg-op-gvec.c: Introduce tcg_gen_gvec_4i target/ppc: Implement xxeval target/ppc: Implement xxgenpcv[bhwd]m instruction target/ppc: move xs[n]madd[am][ds]p/xs[n]msub[am][ds]p to decodetree target/ppc: implement xs[n]maddqp[o]/xs[n]msubqp[o] VĂctor Colombo (12): target/ppc: Implement vmsumcud instruction target/ppc: Implement vmsumudm instruction target/ppc: Implement xvtlsbb instruction target/ppc: Remove xscmpnedp instruction target/ppc: Refactor VSX_SCALAR_CMP_DP target/ppc: Implement xscmp{eq,ge,gt}qp target/ppc: Implement do_helper_XX3 and move xxperm* to use it target/ppc: Move xscmp{eq,ge,gt}dp to decodetree target/ppc: Move xs{max,min}[cj]dp to use do_helper_XX3 target/ppc: Refactor VSX_MAX_MINC helper target/ppc: Implement xs{max,min}cqp target/ppc: Implement xvcvbf16spn and xvcvspbf16 instructions include/tcg/tcg-op-gvec.h | 22 + target/ppc/fpu_helper.c | 171 ++++-- target/ppc/helper.h | 143 ++--- target/ppc/insn32.decode | 188 +++++- target/ppc/insn64.decode | 40 +- target/ppc/int_helper.c | 354 ++++++----- target/ppc/translate.c | 19 + target/ppc/translate/vmx-impl.c.inc | 894 +++++++++++++++++++++++++--- target/ppc/translate/vmx-ops.c.inc | 41 +- target/ppc/translate/vsx-impl.c.inc | 515 ++++++++++++---- target/ppc/translate/vsx-ops.c.inc | 67 --- tcg/ppc/tcg-target.c.inc | 6 + tcg/tcg-op-gvec.c | 146 +++++ 13 files changed, 2033 insertions(+), 573 deletions(-)