Commit f08bd2ce authored by Tobias Tebbi's avatar Tobias Tebbi Committed by Commit Bot

[torque][csa] fix word8 phi MachineRepresentation

Make sure that Torque/CSA generated phi's get kRepWord32 instead
of kRepWord8 or kRepWord16, since that's how we handle small
integer values in Turbofan.

Bug: v8:7793
Change-Id: I992b43287552b6117e90fbd0e11576470bc91509
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2339096
Commit-Queue: Tobias Tebbi <tebbi@chromium.org>
Reviewed-by: 's avatarJakob Gruber <jgruber@chromium.org>
Cr-Commit-Position: refs/heads/master@{#69253}
parent bd9609a0
...@@ -835,6 +835,7 @@ extern operator '==' macro Word32Equal(uint32, uint32): bool; ...@@ -835,6 +835,7 @@ extern operator '==' macro Word32Equal(uint32, uint32): bool;
extern operator '!=' macro Word32NotEqual(int32, int32): bool; extern operator '!=' macro Word32NotEqual(int32, int32): bool;
extern operator '!=' macro Word32NotEqual(uint32, uint32): bool; extern operator '!=' macro Word32NotEqual(uint32, uint32): bool;
extern operator '>>>' macro Word32Shr(uint32, uint32): uint32; extern operator '>>>' macro Word32Shr(uint32, uint32): uint32;
extern operator '>>' macro Word32Sar(int32, int32): int32;
extern operator '<<' macro Word32Shl(int32, int32): int32; extern operator '<<' macro Word32Shl(int32, int32): int32;
extern operator '<<' macro Word32Shl(uint32, uint32): uint32; extern operator '<<' macro Word32Shl(uint32, uint32): uint32;
extern operator '|' macro Word32Or(int32, int32): int32; extern operator '|' macro Word32Or(int32, int32): int32;
......
...@@ -52,6 +52,11 @@ FromConstexpr<uint8, constexpr int31>(i: constexpr int31): uint8 { ...@@ -52,6 +52,11 @@ FromConstexpr<uint8, constexpr int31>(i: constexpr int31): uint8 {
static_assert(i <= 255); static_assert(i <= 255);
return %RawDownCast<uint8>(i); return %RawDownCast<uint8>(i);
} }
FromConstexpr<int8, constexpr int31>(i: constexpr int31): int8 {
const i: int32 = i;
static_assert(-128 <= i && i <= 127);
return %RawDownCast<int8>(i);
}
FromConstexpr<Number, constexpr Smi>(s: constexpr Smi): Number { FromConstexpr<Number, constexpr Smi>(s: constexpr Smi): Number {
return SmiConstant(s); return SmiConstant(s);
} }
...@@ -149,6 +154,9 @@ Convert<intptr, uint8>(ui: uint8): intptr { ...@@ -149,6 +154,9 @@ Convert<intptr, uint8>(ui: uint8): intptr {
Convert<uint8, intptr>(i: intptr): uint8 { Convert<uint8, intptr>(i: intptr): uint8 {
return %RawDownCast<uint8>(Unsigned(TruncateIntPtrToInt32(i)) & 0xFF); return %RawDownCast<uint8>(Unsigned(TruncateIntPtrToInt32(i)) & 0xFF);
} }
Convert<int8, intptr>(i: intptr): int8 {
return %RawDownCast<int8>(TruncateIntPtrToInt32(i) << 24 >> 24);
}
Convert<int32, uint8>(i: uint8): int32 { Convert<int32, uint8>(i: uint8): int32 {
return Signed(Convert<uint32>(i)); return Signed(Convert<uint32>(i));
} }
......
...@@ -190,6 +190,11 @@ constexpr bool IsMachineRepresentationOf(MachineRepresentation r) { ...@@ -190,6 +190,11 @@ constexpr bool IsMachineRepresentationOf(MachineRepresentation r) {
return MachineRepresentationOf<T>::value == r; return MachineRepresentationOf<T>::value == r;
} }
template <class T>
constexpr MachineRepresentation PhiMachineRepresentationOf =
std::is_base_of<Word32T, T>::value ? MachineRepresentation::kWord32
: MachineRepresentationOf<T>::value;
template <class T> template <class T>
struct is_valid_type_tag { struct is_valid_type_tag {
static const bool value = std::is_base_of<Object, T>::value || static const bool value = std::is_base_of<Object, T>::value ||
......
...@@ -819,6 +819,10 @@ class V8_EXPORT_PRIVATE CodeAssembler { ...@@ -819,6 +819,10 @@ class V8_EXPORT_PRIVATE CodeAssembler {
return Unsigned( return Unsigned(
Word32Shr(static_cast<Node*>(left), static_cast<Node*>(right))); Word32Shr(static_cast<Node*>(left), static_cast<Node*>(right)));
} }
TNode<Int32T> Word32Sar(TNode<Int32T> left, TNode<Int32T> right) {
return Signed(
Word32Sar(static_cast<Node*>(left), static_cast<Node*>(right)));
}
TNode<IntPtrT> WordAnd(TNode<IntPtrT> left, TNode<IntPtrT> right) { TNode<IntPtrT> WordAnd(TNode<IntPtrT> left, TNode<IntPtrT> right) {
return Signed(WordAnd(static_cast<Node*>(left), static_cast<Node*>(right))); return Signed(WordAnd(static_cast<Node*>(left), static_cast<Node*>(right)));
...@@ -1270,20 +1274,19 @@ template <class T> ...@@ -1270,20 +1274,19 @@ template <class T>
class TypedCodeAssemblerVariable : public CodeAssemblerVariable { class TypedCodeAssemblerVariable : public CodeAssemblerVariable {
public: public:
TypedCodeAssemblerVariable(TNode<T> initial_value, CodeAssembler* assembler) TypedCodeAssemblerVariable(TNode<T> initial_value, CodeAssembler* assembler)
: CodeAssemblerVariable(assembler, MachineRepresentationOf<T>::value, : CodeAssemblerVariable(assembler, PhiMachineRepresentationOf<T>,
initial_value) {} initial_value) {}
explicit TypedCodeAssemblerVariable(CodeAssembler* assembler) explicit TypedCodeAssemblerVariable(CodeAssembler* assembler)
: CodeAssemblerVariable(assembler, MachineRepresentationOf<T>::value) {} : CodeAssemblerVariable(assembler, PhiMachineRepresentationOf<T>) {}
#if DEBUG #if DEBUG
TypedCodeAssemblerVariable(AssemblerDebugInfo debug_info, TypedCodeAssemblerVariable(AssemblerDebugInfo debug_info,
CodeAssembler* assembler) CodeAssembler* assembler)
: CodeAssemblerVariable(assembler, debug_info, : CodeAssemblerVariable(assembler, debug_info,
MachineRepresentationOf<T>::value) {} PhiMachineRepresentationOf<T>) {}
TypedCodeAssemblerVariable(AssemblerDebugInfo debug_info, TypedCodeAssemblerVariable(AssemblerDebugInfo debug_info,
TNode<T> initial_value, CodeAssembler* assembler) TNode<T> initial_value, CodeAssembler* assembler)
: CodeAssemblerVariable(assembler, debug_info, : CodeAssemblerVariable(assembler, debug_info,
MachineRepresentationOf<T>::value, PhiMachineRepresentationOf<T>, initial_value) {}
initial_value) {}
#endif // DEBUG #endif // DEBUG
TNode<T> value() const { TNode<T> value() const {
...@@ -1407,7 +1410,7 @@ class CodeAssemblerParameterizedLabel ...@@ -1407,7 +1410,7 @@ class CodeAssemblerParameterizedLabel
void CreatePhis(TNode<Types>*... results) { void CreatePhis(TNode<Types>*... results) {
const std::vector<Node*>& phi_nodes = const std::vector<Node*>& phi_nodes =
CodeAssemblerParameterizedLabelBase::CreatePhis( CodeAssemblerParameterizedLabelBase::CreatePhis(
{MachineRepresentationOf<Types>::value...}); {PhiMachineRepresentationOf<Types>...});
auto it = phi_nodes.begin(); auto it = phi_nodes.begin();
USE(it); USE(it);
ITERATE_PACK(AssignPhi(results, *(it++))); ITERATE_PACK(AssignPhi(results, *(it++)));
......
...@@ -852,6 +852,20 @@ TEST(TestNewPretenured) { ...@@ -852,6 +852,20 @@ TEST(TestNewPretenured) {
ft.Call(); ft.Call();
} }
TEST(TestWord8Phi) {
CcTest::InitializeVM();
Isolate* isolate(CcTest::i_isolate());
i::HandleScope scope(isolate);
CodeAssemblerTester asm_tester(isolate, 1);
TestTorqueAssembler m(asm_tester.state());
{
m.TestWord8Phi();
m.Return(m.UndefinedConstant());
}
FunctionTester ft(asm_tester.GenerateCode(), 0);
ft.Call();
}
} // namespace compiler } // namespace compiler
} // namespace internal } // namespace internal
} // namespace v8 } // namespace v8
...@@ -1327,4 +1327,17 @@ macro TestNewPretenured(implicit context: Context)() { ...@@ -1327,4 +1327,17 @@ macro TestNewPretenured(implicit context: Context)() {
assert(Is<ExportedSubClassBase>(obj)); assert(Is<ExportedSubClassBase>(obj));
assert(InYoungGeneration(obj) == False); assert(InYoungGeneration(obj) == False);
} }
@export
macro TestWord8Phi() {
for (let i: intptr = -5; i < 5; ++i) {
let x: int8;
if (i == -1) {
x = -1;
} else {
x = Convert<int8>(i);
}
check(x == Convert<int8>(i));
}
}
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment