mirror of
https://gitee.com/openharmony/third_party_ffmpeg
synced 2024-12-18 00:46:51 +00:00
x86inc: FMA3/4 Support
Signed-off-by: Derek Buitenhuis <derek.buitenhuis@gmail.com>
This commit is contained in:
parent
206895708e
commit
c6908d6b4b
@ -1417,3 +1417,45 @@ FMA_INSTR pmadcswd, pmaddwd, paddd
|
||||
; tzcnt is equivalent to "rep bsf" and is backwards-compatible with bsf.
|
||||
; This lets us use tzcnt without bumping the yasm version requirement yet.
|
||||
%define tzcnt rep bsf
|
||||
|
||||
; convert FMA4 to FMA3 if possible
|
||||
%macro FMA4_INSTR 4
|
||||
%macro %1 4-8 %1, %2, %3, %4
|
||||
%if cpuflag(fma4)
|
||||
v%5 %1, %2, %3, %4
|
||||
%elifidn %1, %2
|
||||
v%6 %1, %4, %3 ; %1 = %1 * %3 + %4
|
||||
%elifidn %1, %3
|
||||
v%7 %1, %2, %4 ; %1 = %2 * %1 + %4
|
||||
%elifidn %1, %4
|
||||
v%8 %1, %2, %3 ; %1 = %2 * %3 + %1
|
||||
%else
|
||||
%error fma3 emulation of ``%5 %1, %2, %3, %4'' is not supported
|
||||
%endif
|
||||
%endmacro
|
||||
%endmacro
|
||||
|
||||
FMA4_INSTR fmaddpd, fmadd132pd, fmadd213pd, fmadd231pd
|
||||
FMA4_INSTR fmaddps, fmadd132ps, fmadd213ps, fmadd231ps
|
||||
FMA4_INSTR fmaddsd, fmadd132sd, fmadd213sd, fmadd231sd
|
||||
FMA4_INSTR fmaddss, fmadd132ss, fmadd213ss, fmadd231ss
|
||||
|
||||
FMA4_INSTR fmaddsubpd, fmaddsub132pd, fmaddsub213pd, fmaddsub231pd
|
||||
FMA4_INSTR fmaddsubps, fmaddsub132ps, fmaddsub213ps, fmaddsub231ps
|
||||
FMA4_INSTR fmsubaddpd, fmsubadd132pd, fmsubadd213pd, fmsubadd231pd
|
||||
FMA4_INSTR fmsubaddps, fmsubadd132ps, fmsubadd213ps, fmsubadd231ps
|
||||
|
||||
FMA4_INSTR fmsubpd, fmsub132pd, fmsub213pd, fmsub231pd
|
||||
FMA4_INSTR fmsubps, fmsub132ps, fmsub213ps, fmsub231ps
|
||||
FMA4_INSTR fmsubsd, fmsub132sd, fmsub213sd, fmsub231sd
|
||||
FMA4_INSTR fmsubss, fmsub132ss, fmsub213ss, fmsub231ss
|
||||
|
||||
FMA4_INSTR fnmaddpd, fnmadd132pd, fnmadd213pd, fnmadd231pd
|
||||
FMA4_INSTR fnmaddps, fnmadd132ps, fnmadd213ps, fnmadd231ps
|
||||
FMA4_INSTR fnmaddsd, fnmadd132sd, fnmadd213sd, fnmadd231sd
|
||||
FMA4_INSTR fnmaddss, fnmadd132ss, fnmadd213ss, fnmadd231ss
|
||||
|
||||
FMA4_INSTR fnmsubpd, fnmsub132pd, fnmsub213pd, fnmsub231pd
|
||||
FMA4_INSTR fnmsubps, fnmsub132ps, fnmsub213ps, fnmsub231ps
|
||||
FMA4_INSTR fnmsubsd, fnmsub132sd, fnmsub213sd, fnmsub231sd
|
||||
FMA4_INSTR fnmsubss, fnmsub132ss, fnmsub213ss, fnmsub231ss
|
||||
|
@ -668,7 +668,9 @@
|
||||
|
||||
; Wrapper for non-FMA version of fmaddps
|
||||
%macro FMULADD_PS 5
|
||||
%ifidn %1, %4
|
||||
%if cpuflag(fma3) || cpuflag(fma4)
|
||||
fmaddps %1, %2, %3, %4
|
||||
%elifidn %1, %4
|
||||
mulps %5, %2, %3
|
||||
addps %1, %4, %5
|
||||
%else
|
||||
|
Loading…
Reference in New Issue
Block a user