Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(6)

Side by Side Diff: test/mjsunit/bitops-info.js

Issue 6673064: Fix incorrect assumption on bit-and on ARM (Closed) Base URL: http://v8.googlecode.com/svn/branches/2.5/
Patch Set: Created 9 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « src/version.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2010 the V8 project authors. All rights reserved. 1 // Copyright 2010 the V8 project authors. All rights reserved.
2 // Redistribution and use in source and binary forms, with or without 2 // Redistribution and use in source and binary forms, with or without
3 // modification, are permitted provided that the following conditions are 3 // modification, are permitted provided that the following conditions are
4 // met: 4 // met:
5 // 5 //
6 // * Redistributions of source code must retain the above copyright 6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer. 7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above 8 // * Redistributions in binary form must reproduce the above
9 // copyright notice, this list of conditions and the following 9 // copyright notice, this list of conditions and the following
10 // disclaimer in the documentation and/or other materials provided 10 // disclaimer in the documentation and/or other materials provided
(...skipping 19 matching lines...) Expand all
30 } 30 }
31 31
32 function hidden_smi() { 32 function hidden_smi() {
33 return 46512102; // It's a Smi 33 return 46512102; // It's a Smi
34 } 34 }
35 35
36 function hidden_int32() { 36 function hidden_int32() {
37 return 1600822924; // It's a signed Int32. 37 return 1600822924; // It's a signed Int32.
38 } 38 }
39 39
40
41 function f() { 40 function f() {
42 var x = non_int32(); // Not a constant. 41 var x = non_int32(); // Not a constant.
43 var y = hidden_smi(); // Not a constant. 42 var y = hidden_smi(); // Not a constant.
44 var z = hidden_int32(); 43 var z = hidden_int32();
45 assertEquals(46512102 & 2600822924, 46512102 & x, "1"); 44 assertEquals(46512102 & 2600822924, 46512102 & x, "1");
46 assertEquals(1600822924 & 2600822924, 1600822924 & x, "2"); 45 assertEquals(1600822924 & 2600822924, 1600822924 & x, "2");
47 assertEquals(2600822924 & 2600822924, 2600822924 & x, "3"); 46 assertEquals(2600822924 & 2600822924, 2600822924 & x, "3");
48 assertEquals(46512102 & 46512102, 46512102 & y, "4"); 47 assertEquals(46512102 & 46512102, 46512102 & y, "4");
49 assertEquals(1600822924 & 46512102, 1600822924 & y, "5"); 48 assertEquals(1600822924 & 46512102, 1600822924 & y, "5");
50 assertEquals(2600822924 & 46512102, 2600822924 & y, "6"); 49 assertEquals(2600822924 & 46512102, 2600822924 & y, "6");
51 assertEquals(46512102 & 1600822924, 46512102 & z, "7"); 50 assertEquals(46512102 & 1600822924, 46512102 & z, "7");
52 assertEquals(1600822924 & 1600822924, 1600822924 & z, "8"); 51 assertEquals(1600822924 & 1600822924, 1600822924 & z, "8");
53 assertEquals(2600822924 & 1600822924, 2600822924 & z, "9"); 52 assertEquals(2600822924 & 1600822924, 2600822924 & z, "9");
54 assertEquals(46512102 & 2600822924, y & x, "10"); 53 assertEquals(46512102 & 2600822924, y & x, "10");
55 assertEquals(1600822924 & 2600822924, z & x, "11"); 54 assertEquals(1600822924 & 2600822924, z & x, "11");
56 55
57 assertEquals(46512102 & 2600822924, x & 46512102, "1rev"); 56 assertEquals(46512102 & 2600822924, x & 46512102, "1rev");
58 assertEquals(1600822924 & 2600822924, x & 1600822924, "2rev"); 57 assertEquals(1600822924 & 2600822924, x & 1600822924, "2rev");
59 assertEquals(2600822924 & 2600822924, x & 2600822924, "3rev"); 58 assertEquals(2600822924 & 2600822924, x & 2600822924, "3rev");
60 assertEquals(46512102 & 46512102, y & 46512102, "4rev"); 59 assertEquals(46512102 & 46512102, y & 46512102, "4rev");
61 assertEquals(1600822924 & 46512102, y & 1600822924, "5rev"); 60 assertEquals(1600822924 & 46512102, y & 1600822924, "5rev");
62 assertEquals(2600822924 & 46512102, y & 2600822924, "6rev"); 61 assertEquals(2600822924 & 46512102, y & 2600822924, "6rev");
63 assertEquals(46512102 & 1600822924, z & 46512102, "7rev"); 62 assertEquals(46512102 & 1600822924, z & 46512102, "7rev");
64 assertEquals(1600822924 & 1600822924, z & 1600822924, "8rev"); 63 assertEquals(1600822924 & 1600822924, z & 1600822924, "8rev");
65 assertEquals(2600822924 & 1600822924, z & 2600822924, "9rev"); 64 assertEquals(2600822924 & 1600822924, z & 2600822924, "9rev");
66 assertEquals(46512102 & 2600822924, x & y, "10rev"); 65 assertEquals(46512102 & 2600822924, x & y, "10rev");
67 assertEquals(1600822924 & 2600822924, x & z, "11rev"); 66 assertEquals(1600822924 & 2600822924, x & z, "11rev");
68 67
68 assertEquals((46512102 & -0x20123456) | 1, (y & -0x20123456) | 1, "12");
69 assertEquals((1600822924 & -0x20123456) | 1, (z & -0x20123456) | 1, "13");
70 assertEquals((2600822924 & -0x20123456) | 1, (x & -0x20123456) | 1, "14");
71 assertEquals((46512102 & -0x20123456) | 1, (-0x20123456 & y) | 1, "12rev");
72 assertEquals((1600822924 & -0x20123456) | 1, (-0x20123456 & z) | 1, "13rev");
73 assertEquals((2600822924 & -0x20123456) | 1, (-0x20123456 & x) | 1, "14rev");
74
69 assertEquals(2600822924 & 2600822924, x & x, "xx"); 75 assertEquals(2600822924 & 2600822924, x & x, "xx");
70 assertEquals(y, y & y, "yy"); 76 assertEquals(y, y & y, "yy");
71 assertEquals(z, z & z, "zz"); 77 assertEquals(z, z & z, "zz");
72 } 78 }
73 79
74 80
75 for (var i = 0; i < 5; i++) { 81 for (var i = 0; i < 5; i++) {
76 f(); 82 f();
77 } 83 }
OLDNEW
« no previous file with comments | « src/version.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698