[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v3 3/3] x86/emulate: added tests for {, v}movd mm, r32/m32 and {, v}movq xmm, r64/m64
Signed-off-by: Mihai Donțu <mdontu@xxxxxxxxxxxxxxx> --- Changed since v2: * added tests for {,v}movq xmm,r64 --- tools/tests/x86_emulator/test_x86_emulator.c | 120 +++++++++++++++++++++++++++ 1 file changed, 120 insertions(+) diff --git a/tools/tests/x86_emulator/test_x86_emulator.c b/tools/tests/x86_emulator/test_x86_emulator.c index 8994149..fb59b0f 100644 --- a/tools/tests/x86_emulator/test_x86_emulator.c +++ b/tools/tests/x86_emulator/test_x86_emulator.c @@ -650,6 +650,88 @@ int main(int argc, char **argv) #define check_eip(which) (regs.eip == (unsigned long)instr + \ (unsigned long)which##_len) + printf("%-40s", "Testing movd %%mm3,32(%%eax)..."); + if ( stack_exec && cpu_has_mmx ) + { + decl_insn(movd_to_mem32); + + asm volatile ( "pcmpeqb %%mm3, %%mm3\n" + put_insn(movd_to_mem32, "movd %%mm3, 32(%%eax)") + :: ); + + *(res + 8) = 0xbdbdbdbd; + set_insn(movd_to_mem32); + regs.eax = (unsigned long)res; + rc = x86_emulate(&ctxt, &emulops); + if ( (rc != X86EMUL_OKAY) || *(res + 8) != 0xffffffff || + !check_eip(movd_to_mem32) ) + goto fail; + printf("okay\n"); + } + else + printf("skipped\n"); + + printf("%-40s", "Testing movd %%mm3,%%eax..."); + if ( stack_exec && cpu_has_mmx ) + { + decl_insn(movd_to_reg); + + asm volatile ( "pcmpeqb %%mm3, %%mm3\n" + put_insn(movd_to_reg, "movd %%mm3, %%eax") + :: ); + + set_insn(movd_to_reg); + regs.rax = 0xbdbdbdbdbdbdbdbd; + rc = x86_emulate(&ctxt, &emulops); + if ( (rc != X86EMUL_OKAY) || regs.eax != 0xbdbdbdbdffffffff || + !check_eip(movd_to_reg) ) + goto fail; + printf("okay\n"); + } + else + printf("skipped\n"); + + printf("%-40s", "Testing vmovd %%xmm1,32(%%eax)..."); + if ( stack_exec && cpu_has_avx ) + { + decl_insn(vmovd_to_mem32); + + asm volatile ( "pcmpeqb %%xmm1, %%xmm1\n" + put_insn(vmovd_to_mem32, "vmovd %%xmm1, 32(%%eax)") + :: ); + + *(res + 8) = 0xbdbdbdbd; + set_insn(vmovd_to_mem32); + regs.eax = (unsigned long)res; + rc = x86_emulate(&ctxt, &emulops); + if ( (rc != X86EMUL_OKAY) || *(res + 8) != 0xffffffff || + !check_eip(vmovd_to_mem32) ) + goto fail; + printf("okay\n"); + } + else + printf("skipped\n"); + + printf("%-40s", "Testing vmovd %%xmm1,%%eax..."); + if ( stack_exec && cpu_has_avx ) + { + decl_insn(vmovd_to_reg); + + asm volatile ( "pcmpeqb %%xmm1, %%xmm1\n" + put_insn(vmovd_to_reg, "vmovd %%xmm1, %%eax") + :: ); + + set_insn(vmovd_to_reg); + regs.rax = 0xbdbdbdbdbdbdbdbd; + rc = x86_emulate(&ctxt, &emulops); + if ( (rc != X86EMUL_OKAY) || regs.rax != 0xbdbdbdbdffffffff || + !check_eip(vmovd_to_reg) ) + goto fail; + printf("okay\n"); + } + else + printf("skipped\n"); + printf("%-40s", "Testing movq %mm3,(%ecx)..."); if ( stack_exec && cpu_has_mmx ) { @@ -719,6 +801,25 @@ int main(int argc, char **argv) else printf("skipped\n"); + printf("%-40s", "Testing movq %%xmm0,%%rax..."); + if ( stack_exec && cpu_has_sse ) + { + decl_insn(movq_to_reg); + + asm volatile ( "pcmpgtb %%xmm0, %%xmm0\n" + put_insn(movq_to_reg, "movq %%xmm0, %%rax") + :: ); + + set_insn(movq_to_reg); + regs.rax = 0xbdbdbdbdbdbdbdbd; + rc = x86_emulate(&ctxt, &emulops); + if ( rc != X86EMUL_OKAY || regs.rax || !check_eip(movq_to_reg) ) + goto fail; + printf("okay\n"); + } + else + printf("skipped\n"); + printf("%-40s", "Testing vmovq %%xmm1,32(%%eax)..."); if ( stack_exec && cpu_has_avx ) { @@ -741,6 +842,25 @@ int main(int argc, char **argv) else printf("skipped\n"); + printf("%-40s", "Testing vmovq %%xmm1,%%rax..."); + if ( stack_exec && cpu_has_avx ) + { + decl_insn(vmovq_to_reg); + + asm volatile ( "pcmpgtb %%xmm1, %%xmm1\n" + put_insn(vmovq_to_reg, "vmovq %%xmm1, %%rax") + :: ); + + set_insn(vmovq_to_reg); + regs.rax = 0xbdbdbdbdbdbdbdbd; + rc = x86_emulate(&ctxt, &emulops); + if ( rc != X86EMUL_OKAY || regs.rax || !check_eip(vmovq_to_reg) ) + goto fail; + printf("okay\n"); + } + else + printf("skipped\n"); + printf("%-40s", "Testing movdqu %xmm2,(%ecx)..."); if ( stack_exec && cpu_has_sse2 ) { -- 2.9.2 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |