OLD | NEW |
---|---|
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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/code-stubs.h" | 5 #include "src/code-stubs.h" |
6 | 6 |
7 #include <sstream> | 7 #include <sstream> |
8 | 8 |
9 #include "src/bootstrapper.h" | 9 #include "src/bootstrapper.h" |
10 #include "src/code-factory.h" | 10 #include "src/code-factory.h" |
(...skipping 1524 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1535 | 1535 |
1536 assembler->Bind(&do_fmod); | 1536 assembler->Bind(&do_fmod); |
1537 { | 1537 { |
1538 Node* value = assembler->Float64Mod(var_dividend_float64.value(), | 1538 Node* value = assembler->Float64Mod(var_dividend_float64.value(), |
1539 var_divisor_float64.value()); | 1539 var_divisor_float64.value()); |
1540 Node* result = assembler->ChangeFloat64ToTagged(value); | 1540 Node* result = assembler->ChangeFloat64ToTagged(value); |
1541 assembler->Return(result); | 1541 assembler->Return(result); |
1542 } | 1542 } |
1543 } | 1543 } |
1544 | 1544 |
1545 void LeftShiftStub::GenerateAssembly( | |
1546 compiler::CodeStubAssembler* assembler) const { | |
1547 using compiler::Node; | |
1548 | |
1549 Node* lhs = assembler->Parameter(0); | |
1550 Node* rhs = assembler->Parameter(1); | |
1551 Node* context = assembler->Parameter(2); | |
1552 Node* lhs_value = assembler->TruncateTaggedToWord32(context, lhs); | |
1553 Node* rhs_value = assembler->TruncateTaggedToWord32(context, rhs); | |
1554 Node* shift_count = | |
1555 assembler->Word32And(rhs_value, assembler->Int32Constant(0x1f)); | |
1556 Node* value = assembler->Word32Shl(lhs_value, shift_count); | |
1557 Node* result = assembler->ChangeInt32ToTagged(value); | |
1558 assembler->Return(result); | |
1559 } | |
1560 | |
1561 void SignedRightShiftStub::GenerateAssembly( | |
1562 compiler::CodeStubAssembler* assembler) const { | |
1563 using compiler::Node; | |
1564 | |
1565 Node* lhs = assembler->Parameter(0); | |
1566 Node* rhs = assembler->Parameter(1); | |
1567 Node* context = assembler->Parameter(2); | |
1568 Node* lhs_value = assembler->TruncateTaggedToWord32(context, lhs); | |
1569 Node* rhs_value = assembler->TruncateTaggedToWord32(context, rhs); | |
1570 Node* shift_count = | |
1571 assembler->Word32And(rhs_value, assembler->Int32Constant(0x1f)); | |
1572 Node* value = assembler->Word32Sar(lhs_value, shift_count); | |
1573 Node* result = assembler->ChangeInt32ToTagged(value); | |
1574 assembler->Return(result); | |
1575 } | |
1576 | |
1577 void UnsignedRightShiftStub::GenerateAssembly( | |
1578 compiler::CodeStubAssembler* assembler) const { | |
1579 using compiler::Node; | |
1580 typedef compiler::CodeStubAssembler::Label Label; | |
1581 | |
1582 Node* lhs = assembler->Parameter(0); | |
1583 Node* rhs = assembler->Parameter(1); | |
1584 Node* context = assembler->Parameter(2); | |
1585 Node* lhs_value = assembler->TruncateTaggedToWord32(context, lhs); | |
1586 Node* rhs_value = assembler->TruncateTaggedToWord32(context, rhs); | |
1587 Node* shift_count = | |
1588 assembler->Word32And(rhs_value, assembler->Int32Constant(0x1f)); | |
1589 Node* value = assembler->Word32Shr(lhs_value, shift_count); | |
1590 | |
1591 Label if_smi_overflow(assembler, Label::kDeferred), | |
Benedikt Meurer
2016/04/12 12:55:20
Nit: Can you wrap this into ChangeUint32ToTagged?
epertoso
2016/04/12 15:10:16
Sure.
| |
1592 if_not_smi_overflow(assembler); | |
1593 // If the sign bit on {value} is set, we always need a heap number to | |
1594 // represent the unsigned value. This is sufficient for both 32 and 31 bit | |
1595 // Smis, as ChangeInt32ToTagged will allocate a HeapNumber for us when tagging | |
1596 // the Smi causes an 32-bit integer overflow. | |
1597 assembler->Branch( | |
1598 assembler->Int32LessThan(value, assembler->Int32Constant(0)), | |
1599 &if_smi_overflow, &if_not_smi_overflow); | |
1600 | |
1601 assembler->Bind(&if_not_smi_overflow); | |
1602 { | |
1603 Node* result = assembler->ChangeInt32ToTagged(value); | |
1604 assembler->Return(result); | |
1605 } | |
1606 | |
1607 assembler->Bind(&if_smi_overflow); | |
1608 { | |
1609 Node* float64_value = assembler->ChangeUint32ToFloat64(value); | |
1610 Node* result = assembler->AllocateHeapNumberWithValue(float64_value); | |
1611 assembler->Return(result); | |
1612 } | |
1613 } | |
1614 | |
1545 void BitwiseOrStub::GenerateAssembly( | 1615 void BitwiseOrStub::GenerateAssembly( |
1546 compiler::CodeStubAssembler* assembler) const { | 1616 compiler::CodeStubAssembler* assembler) const { |
1547 using compiler::Node; | 1617 using compiler::Node; |
1548 | 1618 |
1549 Node* lhs = assembler->Parameter(0); | 1619 Node* lhs = assembler->Parameter(0); |
1550 Node* rhs = assembler->Parameter(1); | 1620 Node* rhs = assembler->Parameter(1); |
1551 Node* context = assembler->Parameter(2); | 1621 Node* context = assembler->Parameter(2); |
1552 Node* lhs_value = assembler->TruncateTaggedToWord32(context, lhs); | 1622 Node* lhs_value = assembler->TruncateTaggedToWord32(context, lhs); |
1553 Node* rhs_value = assembler->TruncateTaggedToWord32(context, rhs); | 1623 Node* rhs_value = assembler->TruncateTaggedToWord32(context, rhs); |
1554 Node* value = assembler->Word32Or(lhs_value, rhs_value); | 1624 Node* value = assembler->Word32Or(lhs_value, rhs_value); |
(...skipping 2456 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
4011 if (type->Is(Type::UntaggedPointer())) { | 4081 if (type->Is(Type::UntaggedPointer())) { |
4012 return Representation::External(); | 4082 return Representation::External(); |
4013 } | 4083 } |
4014 | 4084 |
4015 DCHECK(!type->Is(Type::Untagged())); | 4085 DCHECK(!type->Is(Type::Untagged())); |
4016 return Representation::Tagged(); | 4086 return Representation::Tagged(); |
4017 } | 4087 } |
4018 | 4088 |
4019 } // namespace internal | 4089 } // namespace internal |
4020 } // namespace v8 | 4090 } // namespace v8 |
OLD | NEW |