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