1027
|
1 // $HeadURL$
|
|
2 // $Date$
|
|
3 // $Author$
|
|
4
|
|
5 module dstress.run.a.asm_psrad_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
|
|
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 movdqu XMM1, B;
|
|
31 psrad XMM0, XMM1;
|
|
32 movdqu c, XMM0;
|
|
33 }
|
|
34
|
|
35 if(c[0] != (3 << 30)){
|
|
36 assert(0);
|
|
37 }
|
|
38 if(c[1] != ((3 << 30) | (1 << 7))){
|
|
39 assert(0);
|
|
40 }
|
|
41 if(c[2] != ((3 << 30) | (1 << 15))){
|
|
42 assert(0);
|
|
43 }
|
|
44 if(c[3] != ((3 << 30) | (1 << 22))){
|
|
45 assert(0);
|
|
46 }
|
|
47
|
|
48 return 0;
|
|
49 }
|
|
50 }else{
|
|
51 pragma(msg, "DSTRESS{XFAIL}: no inline ASM support");
|
|
52 static assert(0);
|
|
53 }
|