1017
|
1 // $HeadURL$
|
|
2 // $Date$
|
|
3 // $Author$
|
|
4
|
|
5 module dstress.run.a.asm_pandn_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;
|
1044
|
15
|
1017
|
16 int main(){
|
|
17 haveSSE2!()();
|
|
18
|
1285
|
19 ushort[] A = [
|
1017
|
20 0b01101100_01101110, 0b01101001_01101101, 0b01100011_01101011, 0b11100111_01100111,
|
|
21 0b11000110_11100110, 0b10001101_10011011, 0b00011011_10011011, 0b01100110_00000000
|
|
22 ];
|
1285
|
23 ushort* a = A.ptr;
|
|
24
|
|
25 ushort[] B = [
|
1017
|
26 0b10000000_11000000, 0b01000000_01100000, 0b00100000_00110000, 0b00010000_00011000,
|
|
27 0b00001000_00001100, 0b00000100_00000110, 0b00000010_00000011, 0b11111111_10101010
|
|
28 ];
|
1285
|
29 ushort* b = B.ptr;
|
|
30
|
|
31 ushort* c = (new ushort[8]).ptr;
|
1044
|
32
|
1182
|
33 static if(size_t.sizeof == 4){
|
|
34 asm{
|
|
35 mov EAX, a;
|
|
36 movdqu XMM0, [EAX];
|
|
37 mov EAX, b;
|
|
38 movdqu XMM1, [EAX];
|
|
39 pandn XMM0, XMM1;
|
|
40 mov EAX, c;
|
|
41 movdqu [EAX], XMM0;
|
|
42 }
|
|
43 }else static if(size_t.sizeof == 8){
|
|
44 asm{
|
|
45 mov RAX, a;
|
|
46 movdqu XMM0, [RAX];
|
|
47 mov RAX, b;
|
|
48 movdqu XMM1, [RAX];
|
|
49 pandn XMM0, XMM1;
|
|
50 mov RAX, c;
|
|
51 movdqu [RAX], XMM0;
|
|
52 }
|
|
53 }else{
|
|
54 static assert(0, "unhandled pointer size");
|
1017
|
55 }
|
|
56
|
1164
|
57 if(c[0] != ((a[0] ^ 0xFFFF) & b[0])){
|
1017
|
58 assert(0);
|
|
59 }
|
1164
|
60 if(c[1] != ((a[1] ^ 0xFFFF) & b[1])){
|
1017
|
61 assert(0);
|
|
62 }
|
1164
|
63 if(c[2] != ((a[2] ^ 0xFFFF) & b[2])){
|
|
64 assert(0);
|
|
65 }
|
|
66 if(c[3] != ((a[3] ^ 0xFFFF) & b[3])){
|
1017
|
67 assert(0);
|
|
68 }
|
1164
|
69 if(c[4] != ((a[4] ^ 0xFFFF) & b[4])){
|
1017
|
70 assert(0);
|
|
71 }
|
1164
|
72 if(c[5] != ((a[5] ^ 0xFFFF) & b[5])){
|
1017
|
73 assert(0);
|
|
74 }
|
1164
|
75 if(c[6] != ((a[6] ^ 0xFFFF) & b[6])){
|
1017
|
76 assert(0);
|
|
77 }
|
1164
|
78 if(c[7] != ((a[7] ^ 0xFFFF) & b[7])){
|
1017
|
79 assert(0);
|
|
80 }
|
|
81 return 0;
|
|
82 }
|
|
83 }else{
|
|
84 pragma(msg, "DSTRESS{XFAIL}: no inline ASM support");
|
|
85 static assert(0);
|
|
86 }
|