973
|
1 // $HeadURL$
|
|
2 // $Date$
|
|
3 // $Author$
|
|
4
|
|
5 module dstress.run.a.asm_pextrw_01_A;
|
|
6
|
1017
|
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 haveSSE!()();
|
|
18
|
1285
|
19 ushort[] X = [cast(ushort)1, 2, 3, 4, 5, 0xFFFF, 7, 0];
|
|
20 ushort* x = X.ptr;
|
|
21
|
973
|
22 uint a;
|
|
23 uint b;
|
1044
|
24
|
1182
|
25 static if(size_t.sizeof == 4){
|
|
26 asm{
|
|
27 mov EAX, x;
|
|
28 movdqu XMM0, [EAX];
|
|
29 pextrw EAX, XMM0, 5;
|
|
30 mov a, EAX;
|
|
31 pextrw EDX, XMM0, 1;
|
|
32 mov b, EDX;
|
|
33 }
|
|
34 }else static if(size_t.sizeof == 8){
|
|
35 asm{
|
|
36 mov RAX, x;
|
|
37 movdqu XMM0, [RAX];
|
|
38 pextrw EAX, XMM0, 5;
|
|
39 mov a, EAX;
|
|
40 pextrw EDX, XMM0, 1;
|
|
41 mov b, EDX;
|
|
42 }
|
|
43 }else{
|
|
44 static assert(0, "unhandled pointer size");
|
973
|
45 }
|
|
46
|
|
47 if(a != 0xFFFF){
|
|
48 assert(0);
|
|
49 }
|
|
50 if(b != 2){
|
|
51 assert(0);
|
|
52 }
|
|
53
|
|
54 return 0;
|
|
55 }
|
1017
|
56 }else{
|
|
57 pragma(msg, "DSTRESS{XFAIL}: no inline ASM support");
|
|
58 static assert(0);
|
973
|
59 }
|