OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/v8.h" | 5 #include "src/v8.h" |
6 #include "test/cctest/cctest.h" | 6 #include "test/cctest/cctest.h" |
7 | 7 |
8 #include "src/compiler/graph-inl.h" | 8 #include "src/compiler/graph-inl.h" |
9 #include "src/compiler/js-typed-lowering.h" | 9 #include "src/compiler/js-typed-lowering.h" |
10 #include "src/compiler/node-properties-inl.h" | 10 #include "src/compiler/node-properties-inl.h" |
(...skipping 309 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
320 for (int k = 0; k < R.kNumberOps; k += 2) { | 320 for (int k = 0; k < R.kNumberOps; k += 2) { |
321 Node* add = R.Binop(R.ops[k], p0, p1); | 321 Node* add = R.Binop(R.ops[k], p0, p1); |
322 Node* r = R.reduce(add); | 322 Node* r = R.reduce(add); |
323 | 323 |
324 R.CheckPureBinop(R.ops[k + 1], r); | 324 R.CheckPureBinop(R.ops[k + 1], r); |
325 Node* r0 = r->InputAt(0); | 325 Node* r0 = r->InputAt(0); |
326 Node* r1 = r->InputAt(1); | 326 Node* r1 = r->InputAt(1); |
327 | 327 |
328 CheckToI32(p0, r0, R.signedness[k]); | 328 CheckToI32(p0, r0, R.signedness[k]); |
329 | 329 |
330 R.CheckPureBinop(IrOpcode::kWord32And, r1); | 330 if (r1->opcode() == IrOpcode::kWord32And) { |
331 CheckToI32(p1, r1->InputAt(0), R.signedness[k + 1]); | 331 R.CheckPureBinop(IrOpcode::kWord32And, r1); |
332 R.CheckInt32Constant(0x1F, r1->InputAt(1)); | 332 CheckToI32(p1, r1->InputAt(0), R.signedness[k + 1]); |
| 333 R.CheckInt32Constant(0x1F, r1->InputAt(1)); |
| 334 } else { |
| 335 CheckToI32(p1, r1, R.signedness[k]); |
| 336 } |
333 } | 337 } |
334 } | 338 } |
335 } | 339 } |
336 } | 340 } |
337 | 341 |
338 | 342 |
339 // A helper class for testing lowering of bitwise operators. | 343 // A helper class for testing lowering of bitwise operators. |
340 class JSBitwiseTypedLoweringTester : public JSTypedLoweringTester { | 344 class JSBitwiseTypedLoweringTester : public JSTypedLoweringTester { |
341 public: | 345 public: |
342 static const int kNumberOps = 6; | 346 static const int kNumberOps = 6; |
(...skipping 997 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1340 CHECK_EQ(p1, r->InputAt(0)); | 1344 CHECK_EQ(p1, r->InputAt(0)); |
1341 CHECK_EQ(p0, r->InputAt(1)); | 1345 CHECK_EQ(p0, r->InputAt(1)); |
1342 } else { | 1346 } else { |
1343 CHECK_EQ(p0, r->InputAt(0)); | 1347 CHECK_EQ(p0, r->InputAt(0)); |
1344 CHECK_EQ(p1, r->InputAt(1)); | 1348 CHECK_EQ(p1, r->InputAt(1)); |
1345 } | 1349 } |
1346 } | 1350 } |
1347 } | 1351 } |
1348 } | 1352 } |
1349 } | 1353 } |
OLD | NEW |