| OLD | NEW |
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 1003 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1014 } else if (v->IsCompare()) { | 1014 } else if (v->IsCompare()) { |
| 1015 HCompare* compare = HCompare::cast(v); | 1015 HCompare* compare = HCompare::cast(v); |
| 1016 Token::Value op = compare->token(); | 1016 Token::Value op = compare->token(); |
| 1017 HValue* left = compare->left(); | 1017 HValue* left = compare->left(); |
| 1018 HValue* right = compare->right(); | 1018 HValue* right = compare->right(); |
| 1019 Representation r = compare->GetInputRepresentation(); | 1019 Representation r = compare->GetInputRepresentation(); |
| 1020 if (r.IsInteger32()) { | 1020 if (r.IsInteger32()) { |
| 1021 ASSERT(left->representation().IsInteger32()); | 1021 ASSERT(left->representation().IsInteger32()); |
| 1022 ASSERT(right->representation().IsInteger32()); | 1022 ASSERT(right->representation().IsInteger32()); |
| 1023 return new LCmpIDAndBranch(UseRegisterAtStart(left), | 1023 return new LCmpIDAndBranch(UseRegisterAtStart(left), |
| 1024 UseOrConstantAtStart(right)); | 1024 UseRegisterAtStart(right)); |
| 1025 } else if (r.IsDouble()) { | 1025 } else if (r.IsDouble()) { |
| 1026 ASSERT(left->representation().IsDouble()); | 1026 ASSERT(left->representation().IsDouble()); |
| 1027 ASSERT(right->representation().IsDouble()); | 1027 ASSERT(right->representation().IsDouble()); |
| 1028 return new LCmpIDAndBranch(UseRegisterAtStart(left), | 1028 return new LCmpIDAndBranch(UseRegisterAtStart(left), |
| 1029 UseRegisterAtStart(right)); | 1029 UseRegisterAtStart(right)); |
| 1030 } else { | 1030 } else { |
| 1031 ASSERT(left->representation().IsTagged()); | 1031 ASSERT(left->representation().IsTagged()); |
| 1032 ASSERT(right->representation().IsTagged()); | 1032 ASSERT(right->representation().IsTagged()); |
| 1033 bool reversed = op == Token::GT || op == Token::LTE; | 1033 bool reversed = op == Token::GT || op == Token::LTE; |
| 1034 LOperand* left_operand = UseFixed(left, reversed ? r0 : r1); | 1034 LOperand* left_operand = UseFixed(left, reversed ? r0 : r1); |
| (...skipping 377 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1412 } | 1412 } |
| 1413 | 1413 |
| 1414 | 1414 |
| 1415 LInstruction* LChunkBuilder::DoCompare(HCompare* instr) { | 1415 LInstruction* LChunkBuilder::DoCompare(HCompare* instr) { |
| 1416 Token::Value op = instr->token(); | 1416 Token::Value op = instr->token(); |
| 1417 Representation r = instr->GetInputRepresentation(); | 1417 Representation r = instr->GetInputRepresentation(); |
| 1418 if (r.IsInteger32()) { | 1418 if (r.IsInteger32()) { |
| 1419 ASSERT(instr->left()->representation().IsInteger32()); | 1419 ASSERT(instr->left()->representation().IsInteger32()); |
| 1420 ASSERT(instr->right()->representation().IsInteger32()); | 1420 ASSERT(instr->right()->representation().IsInteger32()); |
| 1421 LOperand* left = UseRegisterAtStart(instr->left()); | 1421 LOperand* left = UseRegisterAtStart(instr->left()); |
| 1422 LOperand* right = UseOrConstantAtStart(instr->right()); | 1422 LOperand* right = UseRegisterAtStart(instr->right()); |
| 1423 return DefineAsRegister(new LCmpID(left, right)); | 1423 return DefineAsRegister(new LCmpID(left, right)); |
| 1424 } else if (r.IsDouble()) { | 1424 } else if (r.IsDouble()) { |
| 1425 ASSERT(instr->left()->representation().IsDouble()); | 1425 ASSERT(instr->left()->representation().IsDouble()); |
| 1426 ASSERT(instr->right()->representation().IsDouble()); | 1426 ASSERT(instr->right()->representation().IsDouble()); |
| 1427 LOperand* left = UseRegisterAtStart(instr->left()); | 1427 LOperand* left = UseRegisterAtStart(instr->left()); |
| 1428 LOperand* right = UseRegisterAtStart(instr->right()); | 1428 LOperand* right = UseRegisterAtStart(instr->right()); |
| 1429 return DefineAsRegister(new LCmpID(left, right)); | 1429 return DefineAsRegister(new LCmpID(left, right)); |
| 1430 } else { | 1430 } else { |
| 1431 ASSERT(instr->left()->representation().IsTagged()); | 1431 ASSERT(instr->left()->representation().IsTagged()); |
| 1432 ASSERT(instr->right()->representation().IsTagged()); | 1432 ASSERT(instr->right()->representation().IsTagged()); |
| (...skipping 515 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1948 | 1948 |
| 1949 | 1949 |
| 1950 LInstruction* LChunkBuilder::DoLeaveInlined(HLeaveInlined* instr) { | 1950 LInstruction* LChunkBuilder::DoLeaveInlined(HLeaveInlined* instr) { |
| 1951 HEnvironment* outer = current_block_->last_environment()->outer(); | 1951 HEnvironment* outer = current_block_->last_environment()->outer(); |
| 1952 current_block_->UpdateEnvironment(outer); | 1952 current_block_->UpdateEnvironment(outer); |
| 1953 return NULL; | 1953 return NULL; |
| 1954 } | 1954 } |
| 1955 | 1955 |
| 1956 | 1956 |
| 1957 } } // namespace v8::internal | 1957 } } // namespace v8::internal |
| OLD | NEW |