1062
|
1 // $HeadURL$
|
|
2 // $Date$
|
|
3 // $Author$
|
|
4
|
|
5 module dstress.run.a.asm_pmulhrw_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 have3DNow!()();
|
|
18
|
|
19 ulong a = 0xD250_5321_7007_FFFF;
|
|
20 ulong b = 0x8807_EC22_7FFE_FFFF;
|
|
21 ulong c;
|
|
22
|
|
23 asm{
|
|
24 movq MM0, a;
|
|
25 movq MM1, b;
|
|
26 pmulhrw MM0, MM1;
|
|
27 movq c, MM0;
|
|
28 }
|
|
29
|
|
30 if(c != 0x1569_F98C_3803_0000){
|
|
31 assert(0);
|
|
32 }
|
|
33
|
|
34 return 0;
|
|
35 }
|
|
36 }else{
|
|
37 pragma(msg, "DSTRESS{XPASS}: no inline ASM support");
|
|
38 static assert(0);
|
|
39 }
|