FEX/unittests/ASM/VEX/vpabsd.asm
2022-12-12 18:47:10 +00:00

75 lines
2.6 KiB
NASM

%ifdef CONFIG
{
"HostFeatures": ["AVX"],
"RegData": {
"XMM0": ["0x0000000000000000", "0x0000000000000000", "0x0000000000000000", "0x0000000000000000"],
"XMM1": ["0xFFFFFFFFFFFFFFFF", "0xFFFFFFFFFFFFFFFF", "0xFFFFFFFFFFFFFFFF", "0xFFFFFFFFFFFFFFFF"],
"XMM2": ["0x0000000100000001", "0x0000000100000001", "0x0000000100000001", "0x0000000100000001"],
"XMM3": ["0xFFFFFFFF00000000", "0x00000001FFFFFFFF", "0xFFFFFFFF00000000", "0x00000001FFFFFFFF"],
"XMM4": ["0x0000000000000000", "0x0000000000000000", "0x0000000000000000", "0x0000000000000000"],
"XMM5": ["0x0000000100000001", "0x0000000100000001", "0x0000000100000001", "0x0000000100000001"],
"XMM6": ["0x0000000100000001", "0x0000000100000001", "0x0000000100000001", "0x0000000100000001"],
"XMM7": ["0x0000000100000000", "0x0000000100000001", "0x0000000100000000", "0x0000000100000001"],
"XMM8": ["0x0000000000000000", "0x0000000000000000", "0x0000000000000000", "0x0000000000000000"],
"XMM9": ["0x0000000100000001", "0x0000000100000001", "0x0000000000000000", "0x0000000000000000"],
"XMM10": ["0x0000000100000001", "0x0000000100000001", "0x0000000000000000", "0x0000000000000000"],
"XMM11": ["0x0000000100000000", "0x0000000100000001", "0x0000000000000000", "0x0000000000000000"],
"XMM12": ["0x0000000100000001", "0x0000000100000001", "0x0000000100000001", "0x0000000100000001"],
"XMM13": ["0x0000000100000001", "0x0000000100000001", "0x0000000000000000", "0x0000000000000000"],
"XMM14": ["0x0000000100000001", "0x0000000100000001", "0x0000000100000001", "0x0000000100000001"],
"XMM15": ["0x0000000100000001", "0x0000000100000001", "0x0000000000000000", "0x0000000000000000"]
}
}
%endif
lea rdx, [rel .data]
vmovapd ymm0, [rdx + 32 * 0]
vmovaps ymm1, [rdx + 32 * 1]
vmovaps ymm2, [rdx + 32 * 2]
vmovaps ymm3, [rdx + 32 * 3]
; Test with full zero
vpabsd ymm4, [rdx + 32 * 0]
vpabsd xmm8, [rdx + 32 * 0]
; Test with full negative
vpabsd ymm5, [rdx + 32 * 1]
vpabsd xmm9, [rdx + 32 * 1]
vpabsd ymm12, ymm1
vpabsd xmm13, xmm1
; Test with full positive
vpabsd ymm6, [rdx + 32 * 2]
vpabsd xmm10, [rdx + 32 * 2]
vpabsd ymm14, ymm2
vpabsd xmm15, xmm2
; Test a mix
vpabsd ymm7, [rdx + 32 * 3]
vpabsd xmm11, [rdx + 32 * 3]
hlt
align 32
.data:
dq 0x0000000000000000
dq 0x0000000000000000
dq 0x0000000000000000
dq 0x0000000000000000
dq 0xFFFFFFFFFFFFFFFF
dq 0xFFFFFFFFFFFFFFFF
dq 0xFFFFFFFFFFFFFFFF
dq 0xFFFFFFFFFFFFFFFF
dq 0x0000000100000001
dq 0x0000000100000001
dq 0x0000000100000001
dq 0x0000000100000001
dq 0xFFFFFFFF00000000
dq 0x00000001FFFFFFFF
dq 0xFFFFFFFF00000000
dq 0x00000001FFFFFFFF