1027
|
1 // $HeadURL$
|
|
2 // $Date$
|
|
3 // $Author$
|
|
4
|
|
5 module dstress.run.a.asm_psrld_01_B;
|
|
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
|
|
19 const uint[4] A = [
|
|
20 (1 << 31) | 1,
|
|
21 (1 << 31) | (1 << 8),
|
|
22 (1 << 31) | (1 << 16),
|
|
23 (1 << 31) | (1 << 23)];
|
|
24
|
|
25 const long[2] B = [0x8FFF_FFFF_FFFF_FFFF, 1];
|
|
26 uint[4] c;
|
|
27
|
|
28 asm{
|
|
29 movdqu XMM0, A;
|
|
30 psrld XMM0, 1;
|
|
31 movdqu c, XMM0;
|
|
32 }
|
|
33
|
|
34 if(c[0] != (1 << 30)){
|
|
35 assert(0);
|
|
36 }
|
|
37 if(c[1] != ((1 << 30) | (1 << 7))){
|
|
38 assert(0);
|
|
39 }
|
|
40 if(c[2] != ((1 << 30) | (1 << 15))){
|
|
41 assert(0);
|
|
42 }
|
|
43 if(c[3] != ((1 << 30) | (1 << 22))){
|
|
44 assert(0);
|
|
45 }
|
|
46
|
|
47 return 0;
|
|
48 }
|
|
49 }else{
|
|
50 pragma(msg, "DSTRESS{XFAIL}: no inline ASM support");
|
|
51 static assert(0);
|
|
52 }
|