VirtualBox

source: vbox/trunk/src/VBox/Disassembler/testcase/tstDisasm-1A.asm@ 95479

Last change on this file since 95479 was 95479, checked in by vboxsync, 2 years ago

DIS: Fixes for PMOVMSKB and VPMOVMSKB. bugref:9898 bugref:6251

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 12.0 KB
Line 
1; $Id: tstDisasm-1A.asm 95479 2022-07-01 21:07:44Z vboxsync $
2;; @file
3; VBox disassembler: Assembler test routines
4;
5
6;
7; Copyright (C) 2006-2022 Oracle Corporation
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.virtualbox.org. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License (GPL) as published by the Free Software
13; Foundation, in version 2 as it comes in the "COPYING" file of the
14; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16;
17
18;*******************************************************************************
19;* Header Files *
20;*******************************************************************************
21%include "iprt/asmdefs.mac"
22;%include "VBox/vmm/vm.mac"
23;%include "VBox/err.mac"
24;%include "VBox/vmm/stam.mac"
25;%include "iprt/x86.mac"
26
27BITS 32
28
29%if __YASM_VERSION_ID__ >= 001020001h ; v1.2.0.1 and greater, make sure to exclude v1.2.0.0.
30 %define pmulhrwa pmulhrw
31%endif
32
33
34BEGINCODE
35
36align 16
37BEGINPROC TestProc32
38 xor eax, eax
39 mov al, 4
40 lea edx, [4]
41 mov edx, 4
42 mov eax, 4
43 shl eax, 4
44 shl edx, 4
45 shr edx, 4
46 mov eax, edx
47 mov eax, ecx
48 mov edx, eax
49 mov ecx, eax
50 DB 0xF0, 0x0F, 0x22, 0xC0
51 DB 0xF0, 0x0F, 0x20, 0xC0
52 smsw word [edx+16]
53 ; invept eax, dqword [ecx]
54 DB 0x66, 0x0F, 0x38, 0x80, 0x1
55 ; invept eax, dqword [ecx]
56 DB 0x66, 0x0F, 0x38, 0x81, 0x1
57 mov eax, dword [ecx]
58 mov word [edi], 0123ah
59 movzx eax,byte [edx]
60 movzx eax,word [edx]
61 mov dword [es:ebx + 1234h], 0789h
62 mov word [fs:ebx + ecx], 0654h
63 mov byte [esi + eax*4], 054h
64 mov bl, byte [ds:ebp + 1234h]
65 mov al, [cs:1234h + ecx*8]
66 mov al, [cs:1234h]
67 mov ax, [cs:1234h]
68 mov eax, [cs:1234h]
69 lock cmpxchg [ecx], eax
70 lock cmpxchg [ecx], ax
71 lock cmpxchg [ecx], dl
72 movzx ESI,word [EAX]
73 in al, dx
74 in ax, dx
75 in eax, dx
76 mov ebx, [ecx + eax*4 + 17]
77 mov ebx, [ebp + eax*4 + 4]
78 mov ebx, [ebp + eax*4]
79 int 80h
80 in al, 60h
81 in ax, dx
82 out 64h, eax
83
84 movss xmm0, xmm1
85 movss xmm3, [eax]
86 movss [eax], xmm4
87 movsd xmm6, xmm1
88
89 pause
90 nop
91
92 ; 3Dnow!
93 pavgusb mm1, mm0
94 pf2id mm5, mm4
95 pf2iw mm6, mm3
96 pfacc mm7, mm2
97 pfadd mm5, mm4
98 pfcmpeq mm6, mm3
99 pfcmpge mm2, mm7
100 pfcmpgt mm4, mm5
101 pfmax mm3, mm6
102 pfmin mm1, mm0
103 pfmul mm5, mm4
104 pmulhrwa mm3, mm6
105 pfnacc mm4, mm5
106 pfpnacc mm3, mm6
107 pfrcp mm0, mm1
108 pfrcpit1 mm2, mm7
109 pfrcpit2 mm4, mm5
110 pfrsqrt mm7, mm2
111 pfrsqit1 mm1, mm0
112 pfsub mm6, mm3
113 pfsubr mm0, mm1
114 pi2fd mm7, mm2
115 pi2fw mm0, mm1
116 pswapd mm2, mm7
117
118 pavgusb mm1, qword [es:eax+000000010h]
119 pf2id mm5, qword [ds:esi+000101010h]
120 pf2iw mm6, qword [fs:esi+000101010h]
121 pfacc mm7, qword [gs:esi+000101010h]
122 pfadd mm5, qword [ esi+000101010h]
123 pfcmpeq mm6, qword [ edi*8+000101010h]
124 pfcmpge mm2, qword [es:esi+000100010h]
125 pfcmpgt mm4, qword [es:esi+000101010h]
126 pfmax mm3, qword [es:esi+000101010h]
127 pfmin mm1, qword [es:esi+000101010h]
128 pfmul mm5, qword [es:esi+000101000h]
129 pmulhrwa mm3, qword [es:eax+0ffffffffh]
130 pfnacc mm4, qword [es:ebx+000101010h]
131 pfpnacc mm3, qword [es:edx+000102900h]
132 pfrcp mm0, qword [es:ecx+000101020h]
133 pfrcpit1 mm2, qword [es:ebp+000101510h]
134 pfrcpit2 mm4, qword [es:esp+000101310h]
135 pfrsqrt mm7, qword [es:esi+0f0106010h]
136 pfrsqit1 mm1, qword [es:edi+0001f1010h]
137 pfsub mm6, qword [es:esi*2]
138 pfsubr mm0, qword [es:esi*3]
139 pi2fd mm7, qword [es:esi*4]
140 pi2fw mm0, qword [es:esi*5]
141 pswapd mm2, qword [es:esi*8]
142
143 pmulhrwa mm0, qword [ds:ebp+edi*8+00f000001h]
144
145 ; MMX
146 psubusb mm1, mm3
147 cvtpi2pd xmm0, mm3
148 paddd mm1, mm3
149 paddd xmm1, xmm3
150
151%if __YASM_VERSION_ID__ >= 001030000h ; Old yasm doesn't support the instructions below
152 adcx eax, ebx
153 adcx eax, [edi]
154
155 adox eax, ebx
156 adox eax, [edi]
157 adox eax, [edi + 1000h]
158
159 tzcnt ax, bx
160 tzcnt eax, ebx
161 tzcnt ax, [edi]
162 tzcnt eax, [edi]
163 tzcnt eax, [edi + 1000h]
164 vpmovsxbw ymm0, xmm1
165 vpmovzxbq ymm1, [100h]
166 vgatherqps xmm0,dword [eax+xmm0*2],xmm0
167 vgatherqpd xmm0,qword [eax+xmm0*2],xmm0
168%endif
169
170 movbe eax, [edi]
171 movbe ebx, [edi + 1000h]
172 movbe ax, [edi]
173 movbe [edi], eax
174
175 crc32 eax, bl
176 crc32 eax, bx
177 crc32 eax, ebx
178 crc32 eax, byte [edi]
179 crc32 eax, word [edi]
180 crc32 eax, dword [edi]
181
182 popcnt ax, bx
183 popcnt eax, ebx
184 popcnt ax, [edi]
185 popcnt eax, [edi]
186 popcnt eax, [edi + 1000h]
187
188 lzcnt ax, bx
189 lzcnt eax, ebx
190 lzcnt ax, [edi]
191 lzcnt eax, [edi]
192 lzcnt eax, [edi + 1000h]
193
194 vmread eax, ebx
195 vmwrite eax, ebx
196
197 movd mm0, [edi]
198 movq mm0, [edi]
199 movq mm0, mm1
200
201 vmovups xmm0, xmm1
202 vmovaps ymm0, ymm1
203 vunpcklps xmm0, xmm1, xmm2
204 vunpcklps ymm0, ymm1, ymm2
205
206 lddqu xmm1, [ds:ebp+edi*8+00f000001h]
207 vlddqu xmm1, [ds:ebp+edi*8+00f000001h]
208 vlddqu ymm1, [ds:ebp+edi*8+00f000001h]
209
210 vpmovsxbw xmm0,qword [0x100]
211 vbroadcastf128 ymm0,oword [0x100]
212
213 palignr mm0, mm1, 1
214 vpinsrb xmm0, xmm1, eax, 1
215 vpinsrb xmm0, xmm1, [100h], 1
216 vinsertps xmm0, xmm1, xmm2, 1
217 vinsertps xmm0, xmm1, [100h], 1
218
219 vblendvps xmm0, xmm1, xmm2, xmm3
220 vblendvps ymm0, ymm1, ymm2, ymm3
221
222 aesimc xmm0, xmm1
223
224 pmovzxbq xmm0, xmm1
225 pmovzxbq xmm1, [100h]
226
227 vfmaddsub132pd ymm1, ymm2, ymm3
228
229 blsr eax, ebx
230 blsi eax, [ebx]
231 db 0c4h, 0e2h, 0f8h, 0f3h, 01bh ; blsi rax, dword [ebx] - but VEX.W=1 is ignored, so same as previous
232 blsmsk eax, [ebx+edi*2]
233 shlx eax, ebx, ecx
234
235 pmovmskb eax, mm2
236 pmovmskb eax, xmm3
237 vpmovmskb eax, xmm3
238 vpmovmskb eax, ymm3
239
240ENDPROC TestProc32
241
242
243%ifndef RT_OS_OS2
244BITS 64
245align 16
246BEGINPROC TestProc64
247 mov cr8, rax
248 mov cr8, rbx
249 mov [0xfffe0080], rax
250 mov [0xfffe0080], rbx
251 mov rax, cr8
252 mov rbx, cr8
253 mov rax, [0xfffe0080]
254 mov rbx, [0xfffe0080]
255 divsd xmm1, xmm0
256 ; invept rdi, dqword [rsi]
257 DB 0x66, 0x0F, 0x38, 0x80, 0x3E
258 ; invept rcx, dqword [rdx]
259 DB 0x66, 0x0F, 0x38, 0x80, 0xA
260 ;invvpid rdi, dqword [rsi]
261 DB 0x66, 0x0F, 0x38, 0x81, 0x3E
262 ; invvpid rcx, dqword [rdx]
263 DB 0x66, 0x0F, 0x38, 0x81, 0xA
264 mov rdi, [rsi]
265 mov rcx, [rdx]
266 db 48h
267 db 0c7h
268 db 42h
269 db 18h
270 db 20h
271 db 3eh
272 db 23h
273 db 80h
274 call qword [r8+10h]
275 ; test
276 db 48h
277 db 8bh
278 db 44h
279 db 0ah
280 db 0f8h
281 ;incorrectly assembled by yasm; REX.W should not be added!
282 ;test rax, dword 0cc90cc90h
283 db 8bh
284 db 04h
285 db 8dh
286 db 00h
287 db 00h
288 db 0feh
289 db 0ffh
290 mov qword [rcx+rdx], 0
291 mov dword [rcx+rdx], 0
292 and [r15], rax
293 movzx rcx, sil
294 and sil, 3
295 movzx ecx, ah
296 and ah, 3
297
298 sub rcx, 1234h
299 mov rax, qword [0cc90cc90h]
300 mov rax, qword [00c90cc90h]
301 mov rax, dword 0cc90cc90h
302 mov rax, qword 0ffffcc90cc90h
303
304 movzx rax,byte [edx]
305 movzx rax,word [edx]
306 movzx rax,byte [rdx]
307 lock cmpxchg [rcx], rax
308 lock cmpxchg [rcx], ax
309 lock cmpxchg [r15], dl
310 movzx RSI, word [R8]
311 in al, dx
312 in ax, dx
313 in eax, dx
314 mov rbx, [rcx + rax*4 + 17]
315 mov rbx, [rbp + rax*4 + 4]
316 mov rbx, [rbp + rax*4]
317 mov rbx, [ebp + eax*4]
318 int 80h
319 in al, 60h
320 in ax, dx
321 out 64h, eax
322
323 movss xmm0, xmm14
324 movsd xmm6, xmm1
325
326 movbe eax, [rdi]
327 movbe ax, [rdi]
328 movbe rax, [rdi]
329
330 crc32 eax, bl
331 crc32 eax, bx
332 crc32 eax, ebx
333 crc32 eax, byte [edi]
334 crc32 eax, word [edi]
335 crc32 eax, dword [edi]
336
337 crc32 rax, bl
338 crc32 rax, byte [rdi]
339 crc32 rax, qword [rdi]
340
341%if __YASM_VERSION_ID__ >= 001030000h ; Old yasm doesn't support the instructions below
342
343 adcx eax, ebx
344 adcx rax, rbx
345 adcx r8, r11
346 adcx r8d, edx
347
348 adox eax, ebx
349 adox eax, [edi]
350 adox eax, [edi + 1000h]
351
352 adox rax, rbx
353 adox rax, [rdi]
354 adox rax, [rdi + 1000h]
355 adox rax, [edi + 1000h]
356
357 tzcnt ax, bx
358 tzcnt eax, ebx
359 tzcnt rax, rbx
360 tzcnt ax, [edi]
361 tzcnt eax, [edi]
362 tzcnt eax, [edi + 1000h]
363
364 vpunpcklbw ymm1, ymm2, ymm3
365 vpmovsxbw ymm4,[0x100]
366 vgatherqpd xmm0,qword [rbx+xmm11*2],xmm2
367%endif
368
369 popcnt ax, bx
370 popcnt eax, ebx
371 popcnt rax, rbx
372 popcnt ax, [edi]
373 popcnt eax, [edi]
374 popcnt eax, [edi + 1000h]
375 popcnt rax, [rdi + 1000h]
376
377 lzcnt ax, bx
378 lzcnt eax, ebx
379 lzcnt rax, rbx
380 lzcnt ax, [edi]
381 lzcnt eax, [edi]
382 lzcnt eax, [edi + 1000h]
383 lzcnt eax, [rdi]
384 lzcnt ax, [rdi]
385 lzcnt rax, [rdi]
386 lzcnt r8d, [rdi]
387
388 vmread rax, rbx
389 vmwrite rax, rbx
390
391 getsec
392
393 movd mm0, [rdi]
394 movq mm0, [edi]
395 movq mm0, mm1
396
397 vmovups xmm0, xmm1
398 vmovaps ymm0, ymm1
399 vunpcklps xmm0, xmm1, xmm2
400 vunpcklps ymm0, ymm1, ymm2
401 vunpcklps ymm0, ymm10, ymm2
402
403 vmovups xmm5, xmm9
404
405 vcmpps xmm1, xmm2, xmm3, 12
406
407 lddqu xmm1, [ebp+edi*8+00f000001h]
408 vlddqu xmm1, [rbp+rdi*8+00f000001h]
409 vlddqu ymm1, [rbp+rdi*8+00f000001h]
410
411 vbroadcastf128 ymm0,oword [0x100]
412 vmovlps xmm0, xmm1, [100h]
413 vmovlps xmm0, xmm1, [eax + ebx]
414 vmovlps xmm0, xmm1, [rax + rbx]
415 vmovlps xmm10, xmm1, [rax]
416
417 vblendvpd xmm0, xmm1, [100h], xmm3
418
419 dpps xmm0, xmm1, 1
420
421 extractps eax, xmm2, 3
422 vzeroupper
423 vzeroall
424
425 movlps xmm0, [100h]
426 movlps xmm0, [eax + ebx]
427 movlps xmm10, [rax + rbx]
428 movhlps xmm0, xmm1
429
430 blsr eax, ebx
431 blsr rax, rbx
432 blsi eax, [rbx]
433 blsi rax, [rbx]
434 db 0c4h, 0e2h, 0f8h | 4, 0f3h, 01bh ; blsi rax, [rbx] with VEX.L=1 - should be invalid
435 blsmsk eax, [rbx+rdi*2]
436 blsmsk rax, [rbx+rdi*2]
437 blsmsk r8, [rbx+rdi*2]
438
439 shlx eax, ebx, ecx
440 shlx r8, rax, r15
441
442 pmovmskb eax, mm2
443 pmovmskb r9, mm2
444 pmovmskb eax, xmm3
445 pmovmskb r10, xmm3
446 vpmovmskb eax, xmm3
447 vpmovmskb rax, xmm3
448 vpmovmskb r11, ymm9
449
450 ret
451ENDPROC TestProc64
452%endif ; !OS2
453
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette