Index: lldb/lit/Register/Inputs/x86-mm-xmm-write.cpp =================================================================== --- /dev/null +++ lldb/lit/Register/Inputs/x86-mm-xmm-write.cpp @@ -0,0 +1,68 @@ +#include +#include +#include + +struct alignas(16) xmm_t { + uint64_t a, b; +}; + +int main() { + constexpr uint64_t mm_fill = 0x0F0F0F0F0F0F0F0F; + constexpr xmm_t xmm_fill = { mm_fill, mm_fill }; + + uint64_t mm[8]; + xmm_t xmm[8]; + + asm volatile( + "movq %2, %%mm0\n\t" + "movq %2, %%mm1\n\t" + "movq %2, %%mm2\n\t" + "movq %2, %%mm3\n\t" + "movq %2, %%mm4\n\t" + "movq %2, %%mm5\n\t" + "movq %2, %%mm6\n\t" + "movq %2, %%mm7\n\t" + "\n\t" + "movaps %2, %%xmm0\n\t" + "movaps %2, %%xmm1\n\t" + "movaps %2, %%xmm2\n\t" + "movaps %2, %%xmm3\n\t" + "movaps %2, %%xmm4\n\t" + "movaps %2, %%xmm5\n\t" + "movaps %2, %%xmm6\n\t" + "movaps %2, %%xmm7\n\t" + "\n\t" + "int3\n\t" + "\n\t" + "lea %0, %%rbx\n\t" + "movq %%mm0, (%%rbx)\n\t" + "movq %%mm1, 8(%%rbx)\n\t" + "movq %%mm2, 16(%%rbx)\n\t" + "movq %%mm3, 24(%%rbx)\n\t" + "movq %%mm4, 32(%%rbx)\n\t" + "movq %%mm5, 40(%%rbx)\n\t" + "movq %%mm6, 48(%%rbx)\n\t" + "movq %%mm7, 56(%%rbx)\n\t" + "\n\t" + "lea %1, %%rbx\n\t" + "movaps %%xmm0, (%%rbx)\n\t" + "movaps %%xmm1, 16(%%rbx)\n\t" + "movaps %%xmm2, 32(%%rbx)\n\t" + "movaps %%xmm3, 48(%%rbx)\n\t" + "movaps %%xmm4, 64(%%rbx)\n\t" + "movaps %%xmm5, 80(%%rbx)\n\t" + "movaps %%xmm6, 96(%%rbx)\n\t" + "movaps %%xmm7, 112(%%rbx)\n\t" + : "=m"(mm), "=m"(xmm) + : "m"(xmm_fill) + : "%rbx", "%mm0", "%mm1", "%mm2", "%mm3", "%mm4", "%mm5", "%mm6", "%mm7", + "%xmm0", "%xmm1", "%xmm2", "%xmm3", "%xmm4", "%xmm5", "%xmm6", "%xmm7" + ); + + for (int i = 0; i < 8; ++i) + printf("mm%d = 0x%016" PRIx64 "\n", i, mm[i]); + for (int i = 0; i < 8; ++i) + printf("xmm%d = 0x%016" PRIx64 "%016" PRIx64 "\n", i, xmm[i].b, xmm[i].a); + + return 0; +} Index: lldb/lit/Register/x86-mm-xmm-write.test =================================================================== --- /dev/null +++ lldb/lit/Register/x86-mm-xmm-write.test @@ -0,0 +1,45 @@ +# XFAIL: system-darwin +# XFAIL: system-windows +# REQUIRES: native && (target-x86 || target-x86_64) && native-cpu-sse +# RUN: %clangxx %p/Inputs/x86-mm-xmm-write.cpp -o %t +# RUN: %lldb -b -s %s %t | FileCheck %s +process launch + +register write mm0 0x0102030405060708 +register write mm1 0x1112131415161718 +register write mm2 0x2122232425262728 +register write mm3 0x3132333435363738 +register write mm4 0x4142434445464748 +register write mm5 0x5152535455565758 +register write mm6 0x6162636465666768 +register write mm7 0x7172737475767778 + +register write xmm0 "{0x01 0x0e 0x0c 0x0a 0x08 0x06 0x04 0x02 0x00 0x0f 0x0d 0x0b 0x09 0x07 0x05 0x03}" +register write xmm1 "{0x11 0x1e 0x1c 0x1a 0x18 0x16 0x14 0x12 0x10 0x1f 0x1d 0x1b 0x19 0x17 0x15 0x13}" +register write xmm2 "{0x21 0x2e 0x2c 0x2a 0x28 0x26 0x24 0x22 0x20 0x2f 0x2d 0x2b 0x29 0x27 0x25 0x23}" +register write xmm3 "{0x31 0x3e 0x3c 0x3a 0x38 0x36 0x34 0x32 0x30 0x3f 0x3d 0x3b 0x39 0x37 0x35 0x33}" +register write xmm4 "{0x41 0x4e 0x4c 0x4a 0x48 0x46 0x44 0x42 0x40 0x4f 0x4d 0x4b 0x49 0x47 0x45 0x43}" +register write xmm5 "{0x51 0x5e 0x5c 0x5a 0x58 0x56 0x54 0x52 0x50 0x5f 0x5d 0x5b 0x59 0x57 0x55 0x53}" +register write xmm6 "{0x61 0x6e 0x6c 0x6a 0x68 0x66 0x64 0x62 0x60 0x6f 0x6d 0x6b 0x69 0x67 0x65 0x63}" +register write xmm7 "{0x71 0x7e 0x7c 0x7a 0x78 0x76 0x74 0x72 0x70 0x7f 0x7d 0x7b 0x79 0x77 0x75 0x73}" + +process continue +# CHECK-DAG: mm0 = 0x0102030405060708 +# CHECK-DAG: mm1 = 0x1112131415161718 +# CHECK-DAG: mm2 = 0x2122232425262728 +# CHECK-DAG: mm3 = 0x3132333435363738 +# CHECK-DAG: mm4 = 0x4142434445464748 +# CHECK-DAG: mm5 = 0x5152535455565758 +# CHECK-DAG: mm6 = 0x6162636465666768 +# CHECK-DAG: mm7 = 0x7172737475767778 + +# CHECK-DAG: xmm0 = 0x030507090b0d0f00020406080a0c0e01 +# CHECK-DAG: xmm1 = 0x131517191b1d1f10121416181a1c1e11 +# CHECK-DAG: xmm2 = 0x232527292b2d2f20222426282a2c2e21 +# CHECK-DAG: xmm3 = 0x333537393b3d3f30323436383a3c3e31 +# CHECK-DAG: xmm4 = 0x434547494b4d4f40424446484a4c4e41 +# CHECK-DAG: xmm5 = 0x535557595b5d5f50525456585a5c5e51 +# CHECK-DAG: xmm6 = 0x636567696b6d6f60626466686a6c6e61 +# CHECK-DAG: xmm7 = 0x737577797b7d7f70727476787a7c7e71 + +# CHECK: Process {{[0-9]+}} exited with status = 0