Mercurial > projects > dstress
diff run/a/asm_pfrcpit1_01_B.d @ 1288:61d7e32e70a8
partial inline asm review
author | thomask |
---|---|
date | Wed, 27 Dec 2006 11:59:19 +0000 |
parents | 03c97933de98 |
children | 7a397590d6e0 |
line wrap: on
line diff
--- a/run/a/asm_pfrcpit1_01_B.d Wed Dec 27 11:59:05 2006 +0000 +++ b/run/a/asm_pfrcpit1_01_B.d Wed Dec 27 11:59:19 2006 +0000 @@ -17,30 +17,49 @@ haveMMX!()(); have3DNow!()(); - const float[2] A = [2.0f, -0.5f]; - float[2] c; + float* a = (new float[2]).ptr; + a[0] = 2.0f; + a[1] = -0.5f; + + float* c = (new float[2]).ptr; - asm{ - movq MM1, A; - pfrcp MM0, MM1; - pfrcpit1 MM0, MM1; - movq c, MM0; - emms; + static if(size_t.sizeof == 4){ + asm{ + mov EAX, a; + movq MM1, [EAX]; + pfrcp MM0, MM1; + pfrcpit1 MM0, MM1; + mov EAX, c; + movq [EAX], MM0; + emms; + } + }else static if(size_t.sizeof == 8){ + asm{ + mov RAX, a; + movq MM1, [RAX]; + pfrcp MM0, MM1; + pfrcpit1 MM0, MM1; + mov RAX, c; + movq [RAX], MM0; + emms; + } + }else{ + static assert(0, "unhandled pointer size"); } c[0] -= 1.007812f; if(c[0] < 0.0f){ c[0] = -c[0]; } - if(c[0] > float.epsilon * (1 << 11)){ + if(c[0] > float.epsilon * (1 << 8)){ assert(0); } - c[1] += 1.007812f; - if(c[0] < 0.0f){ - c[0] = -c[0]; + c[1] -= 1.007812; + if(c[1] < 0.0f){ + c[1] = -c[1]; } - if(c[0] > float.epsilon * (1 << 11)){ + if(c[1] > float.epsilon * (1 << 8)){ assert(0); }