mirror of
https://github.com/FEX-Emu/FEX.git
synced 2025-01-07 14:10:23 +00:00
unittests: Adds tests for vector shifts with zero immediate
To ensure FEX doesn't encounter the encoding bug again.
This commit is contained in:
parent
5f0efda8fe
commit
e8fb322025
75
unittests/ASM/FEX_bugs/VectorShift_zero.asm
Normal file
75
unittests/ASM/FEX_bugs/VectorShift_zero.asm
Normal file
@ -0,0 +1,75 @@
|
||||
%ifdef CONFIG
|
||||
{
|
||||
"RegData": {
|
||||
"MM0": "0x4054c664c2f837b5",
|
||||
"MM1": "0x40516053e2d6238e",
|
||||
"MM2": "0x4044836d86ec17ec",
|
||||
"MM3": "0x402a1e1c58255b03",
|
||||
"MM4": "0x401568e0c9d9d346",
|
||||
"MM5": "0x4035fe425aee6320",
|
||||
"MM6": "0x402359003eea209b",
|
||||
"MM7": "0x40154b7d41743e96",
|
||||
"XMM0": ["0x4054c664c2f837b5", "0x40516053e2d6238e"],
|
||||
"XMM1": ["0x4044836d86ec17ec", "0x402a1e1c58255b03"],
|
||||
"XMM2": ["0x401568e0c9d9d346", "0x4035fe425aee6320"],
|
||||
"XMM3": ["0x402359003eea209b", "0x40154b7d41743e96"],
|
||||
"XMM4": ["0x403d075a31a4bdba", "0x4050a018bd66277c"],
|
||||
"XMM5": ["0x40334ec17ebaf102", "0x4056d7404ea4a8c1"],
|
||||
"XMM6": ["0x404439b5c7cd898b", "0x40497b136a400fbb"],
|
||||
"XMM7": ["0x4040528bc169c23b", "0x4037f9ca18bd6627"],
|
||||
"XMM8": ["0x4056a929888f861a", "0x403839b866e43aa8"],
|
||||
"XMM9": ["0x4058bc1f212d7732", "0x4056cde5c91d14e4"]
|
||||
}
|
||||
}
|
||||
%endif
|
||||
|
||||
; FEX had a bug where immediate encoded shifts by zero would generate bad code on AArch64.
|
||||
|
||||
lea rdx, [rel .data]
|
||||
movq mm0, [rdx + 8 * 0]
|
||||
movq mm1, [rdx + 8 * 1]
|
||||
movq mm2, [rdx + 8 * 2]
|
||||
movq mm3, [rdx + 8 * 3]
|
||||
movq mm4, [rdx + 8 * 4]
|
||||
movq mm5, [rdx + 8 * 5]
|
||||
movq mm6, [rdx + 8 * 6]
|
||||
movq mm7, [rdx + 8 * 7]
|
||||
|
||||
movapd xmm0, [rdx + 16 * 0]
|
||||
movapd xmm1, [rdx + 16 * 1]
|
||||
movapd xmm2, [rdx + 16 * 2]
|
||||
movapd xmm3, [rdx + 16 * 3]
|
||||
movapd xmm4, [rdx + 16 * 4]
|
||||
movapd xmm5, [rdx + 16 * 5]
|
||||
movapd xmm6, [rdx + 16 * 6]
|
||||
movapd xmm7, [rdx + 16 * 7]
|
||||
movapd xmm8, [rdx + 16 * 8]
|
||||
movapd xmm9, [rdx + 16 * 9]
|
||||
|
||||
; Test MMX first
|
||||
psllw mm0, 0
|
||||
pslld mm1, 0
|
||||
psllq mm2, 0
|
||||
psraw mm3, 0
|
||||
psrad mm4, 0
|
||||
psrlw mm5, 0
|
||||
psrld mm6, 0
|
||||
psrlq mm7, 0
|
||||
|
||||
; Now test XMM
|
||||
psllw xmm0, 0
|
||||
pslld xmm1, 0
|
||||
psllq xmm2, 0
|
||||
pslldq xmm3, 0
|
||||
psraw xmm4, 0
|
||||
psrad xmm5, 0
|
||||
psrlw xmm6, 0
|
||||
psrld xmm7, 0
|
||||
psrlq xmm8, 0
|
||||
pslldq xmm9, 0
|
||||
|
||||
hlt
|
||||
align 16
|
||||
; 512bytes of random data
|
||||
.data:
|
||||
dq 83.0999,69.50512,41.02678,13.05881,5.35242,21.9932,9.67383,5.32372,29.02872,66.50151,19.30764,91.3633,40.45086,50.96153,32.64489,23.97574,90.64316,24.22547,98.9394,91.21715,90.80143,99.48407,64.97245,74.39838,35.22761,25.35321,5.8732,90.19956,33.03133,52.02952,58.38554,10.17531,47.84703,84.04831,90.02965,65.81329,96.27991,6.64479,25.58971,95.00694,88.1929,37.16964,49.52602,10.27223,77.70605,20.21439,9.8056,41.29389,15.4071,57.54286,9.61117,55.54302,52.90745,4.88086,72.52882,3.0201,56.55091,71.22749,61.84736,88.74295,47.72641,24.17404,33.70564,96.71303
|
58
unittests/ASM/FEX_bugs/VectorShift_zero_256.asm
Normal file
58
unittests/ASM/FEX_bugs/VectorShift_zero_256.asm
Normal file
@ -0,0 +1,58 @@
|
||||
%ifdef CONFIG
|
||||
{
|
||||
"HostFeatures": ["AVX"],
|
||||
"RegData": {
|
||||
"XMM0": ["0x4047dcfb00bcbe62", "0x40382c8de2ac3223", "0x4040da5269595fee", "0x40582da24894c448"],
|
||||
"XMM1": ["0x404c46843808850a", "0x4051ce8f32378ab1", "0x404eec764adff823", "0x40562f8c7e28240b"],
|
||||
"XMM2": ["0x404a7427525460aa", "0x4013860029f16b12", "0x405221d82fd75e20", "0x4008292a30553261"],
|
||||
"XMM3": ["0x402ed06f69446738", "0x404cc57c6fbd273d", "0x402338eb463497b7", "0x404bc581adea8976"],
|
||||
"XMM4": ["0x40536d2fec56d5d0", "0x403436e2435696e6", "0x40239c779a6b50b1", "0x4044a59e30014f8b"],
|
||||
"XMM5": ["0x40560c58793dd97f", "0x404295b6c3760bf6", "0x4048c3549f94855e", "0x40248b61bb05faec"],
|
||||
"XMM6": ["0x405811ea0ba1f4b2", "0x401a9443d46b26c0", "0x403996f73c0c1fc9", "0x4057c071b4784231"],
|
||||
"XMM7": ["0x4047ec6b7aa25d8d", "0x4055031782d38477", "0x405681e5c91d14e4", "0x4050740cf1800a7c"],
|
||||
"XMM10": ["0x40560c58793dd97f", "0x404295b6c3760bf6", "0x4048c3549f94855e", "0x40248b61bb05faec"],
|
||||
"XMM11": ["0x40536d2fec56d5d0", "0x403436e2435696e6", "0x40239c779a6b50b1", "0x4044a59e30014f8b"],
|
||||
"XMM12": ["0x402ed06f69446738", "0x404cc57c6fbd273d", "0x402338eb463497b7", "0x404bc581adea8976"],
|
||||
"XMM13": ["0x404a7427525460aa", "0x4013860029f16b12", "0x405221d82fd75e20", "0x4008292a30553261"],
|
||||
"XMM14": ["0x404c46843808850a", "0x4051ce8f32378ab1", "0x404eec764adff823", "0x40562f8c7e28240b"],
|
||||
"XMM15": ["0x4047dcfb00bcbe62", "0x40382c8de2ac3223", "0x4040da5269595fee", "0x40582da24894c448"]
|
||||
}
|
||||
}
|
||||
%endif
|
||||
|
||||
; FEX had a bug where immediate encoded shifts by zero would generate bad code on AArch64.
|
||||
|
||||
lea rdx, [rel .data]
|
||||
vmovapd ymm0, [rdx + 32 * 0]
|
||||
vmovapd ymm1, [rdx + 32 * 1]
|
||||
vmovapd ymm2, [rdx + 32 * 2]
|
||||
vmovapd ymm3, [rdx + 32 * 3]
|
||||
vmovapd ymm4, [rdx + 32 * 4]
|
||||
vmovapd ymm5, [rdx + 32 * 5]
|
||||
vmovapd ymm6, [rdx + 32 * 6]
|
||||
vmovapd ymm7, [rdx + 32 * 7]
|
||||
vmovapd ymm8, [rdx + 32 * 8]
|
||||
vmovapd ymm9, [rdx + 32 * 9]
|
||||
vmovapd ymm10, [rdx + 32 * 10]
|
||||
vmovapd ymm11, [rdx + 32 * 11]
|
||||
vmovapd ymm12, [rdx + 32 * 12]
|
||||
vmovapd ymm13, [rdx + 32 * 13]
|
||||
vmovapd ymm14, [rdx + 32 * 14]
|
||||
vmovapd ymm15, [rdx + 32 * 15]
|
||||
|
||||
vpsllw ymm0, ymm15, 0
|
||||
vpslld ymm1, ymm14, 0
|
||||
vpsllq ymm2, ymm13, 0
|
||||
vpslldq ymm3, ymm12, 0
|
||||
vpsraw ymm4, ymm11, 0
|
||||
vpsrad ymm5, ymm10, 0
|
||||
vpsrlw ymm6, ymm9, 0
|
||||
vpsrld ymm7, ymm8, 0
|
||||
vpsrlq ymm8, ymm7, 0
|
||||
vpslldq ymm9, ymm6, 0
|
||||
|
||||
hlt
|
||||
align 16
|
||||
; 512bytes of random data
|
||||
.data:
|
||||
dq 83.0999,69.50512,41.02678,13.05881,5.35242,21.9932,9.67383,5.32372,29.02872,66.50151,19.30764,91.3633,40.45086,50.96153,32.64489,23.97574,90.64316,24.22547,98.9394,91.21715,90.80143,99.48407,64.97245,74.39838,35.22761,25.35321,5.8732,90.19956,33.03133,52.02952,58.38554,10.17531,47.84703,84.04831,90.02965,65.81329,96.27991,6.64479,25.58971,95.00694,88.1929,37.16964,49.52602,10.27223,77.70605,20.21439,9.8056,41.29389,15.4071,57.54286,9.61117,55.54302,52.90745,4.88086,72.52882,3.0201,56.55091,71.22749,61.84736,88.74295,47.72641,24.17404,33.70564,96.71303
|
58
unittests/ASM/FEX_bugs/VectorShift_zero_avx_128.asm
Normal file
58
unittests/ASM/FEX_bugs/VectorShift_zero_avx_128.asm
Normal file
@ -0,0 +1,58 @@
|
||||
%ifdef CONFIG
|
||||
{
|
||||
"HostFeatures": ["AVX"],
|
||||
"RegData": {
|
||||
"XMM0": ["0x4047dcfb00bcbe62", "0x40382c8de2ac3223", "0", "0"],
|
||||
"XMM1": ["0x404c46843808850a", "0x4051ce8f32378ab1", "0", "0"],
|
||||
"XMM2": ["0x404a7427525460aa", "0x4013860029f16b12", "0", "0"],
|
||||
"XMM3": ["0x402ed06f69446738", "0x404cc57c6fbd273d", "0", "0"],
|
||||
"XMM4": ["0x40536d2fec56d5d0", "0x403436e2435696e6", "0", "0"],
|
||||
"XMM5": ["0x40560c58793dd97f", "0x404295b6c3760bf6", "0", "0"],
|
||||
"XMM6": ["0x405811ea0ba1f4b2", "0x401a9443d46b26c0", "0", "0"],
|
||||
"XMM7": ["0x4047ec6b7aa25d8d", "0x4055031782d38477", "0", "0"],
|
||||
"XMM10": ["0x40560c58793dd97f", "0x404295b6c3760bf6", "0x4048c3549f94855e", "0x40248b61bb05faec"],
|
||||
"XMM11": ["0x40536d2fec56d5d0", "0x403436e2435696e6", "0x40239c779a6b50b1", "0x4044a59e30014f8b"],
|
||||
"XMM12": ["0x402ed06f69446738", "0x404cc57c6fbd273d", "0x402338eb463497b7", "0x404bc581adea8976"],
|
||||
"XMM13": ["0x404a7427525460aa", "0x4013860029f16b12", "0x405221d82fd75e20", "0x4008292a30553261"],
|
||||
"XMM14": ["0x404c46843808850a", "0x4051ce8f32378ab1", "0x404eec764adff823", "0x40562f8c7e28240b"],
|
||||
"XMM15": ["0x4047dcfb00bcbe62", "0x40382c8de2ac3223", "0x4040da5269595fee", "0x40582da24894c448"]
|
||||
}
|
||||
}
|
||||
%endif
|
||||
|
||||
; FEX had a bug where immediate encoded shifts by zero would generate bad code on AArch64.
|
||||
|
||||
lea rdx, [rel .data]
|
||||
vmovapd ymm0, [rdx + 32 * 0]
|
||||
vmovapd ymm1, [rdx + 32 * 1]
|
||||
vmovapd ymm2, [rdx + 32 * 2]
|
||||
vmovapd ymm3, [rdx + 32 * 3]
|
||||
vmovapd ymm4, [rdx + 32 * 4]
|
||||
vmovapd ymm5, [rdx + 32 * 5]
|
||||
vmovapd ymm6, [rdx + 32 * 6]
|
||||
vmovapd ymm7, [rdx + 32 * 7]
|
||||
vmovapd ymm8, [rdx + 32 * 8]
|
||||
vmovapd ymm9, [rdx + 32 * 9]
|
||||
vmovapd ymm10, [rdx + 32 * 10]
|
||||
vmovapd ymm11, [rdx + 32 * 11]
|
||||
vmovapd ymm12, [rdx + 32 * 12]
|
||||
vmovapd ymm13, [rdx + 32 * 13]
|
||||
vmovapd ymm14, [rdx + 32 * 14]
|
||||
vmovapd ymm15, [rdx + 32 * 15]
|
||||
|
||||
vpsllw xmm0, xmm15, 0
|
||||
vpslld xmm1, xmm14, 0
|
||||
vpsllq xmm2, xmm13, 0
|
||||
vpslldq xmm3, xmm12, 0
|
||||
vpsraw xmm4, xmm11, 0
|
||||
vpsrad xmm5, xmm10, 0
|
||||
vpsrlw xmm6, xmm9, 0
|
||||
vpsrld xmm7, xmm8, 0
|
||||
vpsrlq xmm8, xmm7, 0
|
||||
vpslldq xmm9, xmm6, 0
|
||||
|
||||
hlt
|
||||
align 16
|
||||
; 512bytes of random data
|
||||
.data:
|
||||
dq 83.0999,69.50512,41.02678,13.05881,5.35242,21.9932,9.67383,5.32372,29.02872,66.50151,19.30764,91.3633,40.45086,50.96153,32.64489,23.97574,90.64316,24.22547,98.9394,91.21715,90.80143,99.48407,64.97245,74.39838,35.22761,25.35321,5.8732,90.19956,33.03133,52.02952,58.38554,10.17531,47.84703,84.04831,90.02965,65.81329,96.27991,6.64479,25.58971,95.00694,88.1929,37.16964,49.52602,10.27223,77.70605,20.21439,9.8056,41.29389,15.4071,57.54286,9.61117,55.54302,52.90745,4.88086,72.52882,3.0201,56.55091,71.22749,61.84736,88.74295,47.72641,24.17404,33.70564,96.71303
|
Loading…
Reference in New Issue
Block a user