1019
|
1 // $HeadURL$
|
|
2 // $Date$
|
|
3 // $Author$
|
|
4
|
|
5 module dstress.run.a.asm_pshufhw_01_A;
|
|
6
|
|
7 version(D_InlineAsm_X86){
|
|
8 version = runTest;
|
|
9 }else version(D_InlineAsm_X86_64){
|
|
10 version = runTest;
|
|
11 }
|
|
12
|
|
13 version(runTest){
|
|
14 import addon.cpuinfo;
|
|
15
|
|
16 int main(){
|
|
17 haveSSE2!()();
|
|
18
|
1329
|
19 short[] A = [9, 9, 9, 9, 9, 9, 9, 9];
|
|
20 short* a = A.ptr;
|
1019
|
21
|
1329
|
22 short[] B = [1, 2, 3, 4, 5, 6, 7, 8];
|
|
23 short* b = B.ptr;
|
|
24
|
|
25 short* c = (new short[8]).ptr;
|
1019
|
26
|
|
27 asm{
|
1329
|
28 mov EAX, a;
|
|
29 movdqu XMM0, [EAX];
|
|
30 mov EAX, b;
|
|
31 movdqu XMM1, [EAX];
|
1044
|
32 pshufhw XMM0, XMM1, 0b11_10_01_00;
|
1329
|
33 mov EAX, c;
|
|
34 movdqu [EAX], XMM0;
|
1019
|
35 }
|
|
36
|
1329
|
37 if(c[0] != 1){
|
1019
|
38 assert(0);
|
|
39 }
|
1329
|
40 if(c[1] != 2){
|
1019
|
41 assert(0);
|
|
42 }
|
1329
|
43 if(c[2] != 3){
|
1019
|
44 assert(0);
|
|
45 }
|
1329
|
46 if(c[3] != 4){
|
1019
|
47 assert(0);
|
|
48 }
|
|
49 if(c[4] != 5){
|
|
50 assert(0);
|
|
51 }
|
|
52 if(c[5] != 6){
|
|
53 assert(0);
|
|
54 }
|
|
55 if(c[6] != 7){
|
|
56 assert(0);
|
|
57 }
|
|
58 if(c[7] != 8){
|
|
59 assert(0);
|
|
60 }
|
|
61
|
|
62 return 0;
|
|
63 }
|
|
64 }else{
|
|
65 pragma(msg, "DSTRESS{XFAIL}: no inline ASM support");
|
|
66 static assert(0);
|
|
67 }
|