Commit 6ace4a50 authored by Georg Neis's avatar Georg Neis Committed by Commit Bot

[compiler] Don't use Handle<T>::cast in code generator.

In debug mode (SLOW_DCHECK), Handle<T>::cast accesses the object to
check its type.  Obviously we can no longer do that now that we run
on a background thread.

NOTE: I think there are other parts of TF that suffer from the same
problem. I will look into fixing those as well.

Bug: v8:6048, v8:6590
Change-Id: I9abfdf30f1899cdb0c8b9078b0cf71463d608251
Reviewed-on: https://chromium-review.googlesource.com/570054Reviewed-by: 's avatarMichael Starzinger <mstarzinger@chromium.org>
Commit-Queue: Georg Neis <neis@chromium.org>
Cr-Commit-Position: refs/heads/master@{#46641}
parent a03f4451
...@@ -693,8 +693,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -693,8 +693,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
EnsureSpaceForLazyDeopt(); EnsureSpaceForLazyDeopt();
if (instr->InputAt(0)->IsImmediate()) { if (instr->InputAt(0)->IsImmediate()) {
__ Call(Handle<Code>::cast(i.InputHeapObject(0)), __ Call(i.InputCode(0), RelocInfo::CODE_TARGET);
RelocInfo::CODE_TARGET);
} else { } else {
__ add(ip, i.InputRegister(0), __ add(ip, i.InputRegister(0),
Operand(Code::kHeaderSize - kHeapObjectTag)); Operand(Code::kHeaderSize - kHeapObjectTag));
...@@ -718,8 +717,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -718,8 +717,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
i.TempRegister(2)); i.TempRegister(2));
} }
if (instr->InputAt(0)->IsImmediate()) { if (instr->InputAt(0)->IsImmediate()) {
__ Jump(Handle<Code>::cast(i.InputHeapObject(0)), __ Jump(i.InputCode(0), RelocInfo::CODE_TARGET);
RelocInfo::CODE_TARGET);
} else { } else {
__ add(ip, i.InputRegister(0), __ add(ip, i.InputRegister(0),
Operand(Code::kHeaderSize - kHeapObjectTag)); Operand(Code::kHeaderSize - kHeapObjectTag));
......
...@@ -672,8 +672,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -672,8 +672,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
EnsureSpaceForLazyDeopt(); EnsureSpaceForLazyDeopt();
if (instr->InputAt(0)->IsImmediate()) { if (instr->InputAt(0)->IsImmediate()) {
__ Call(Handle<Code>::cast(i.InputHeapObject(0)), __ Call(i.InputCode(0), RelocInfo::CODE_TARGET);
RelocInfo::CODE_TARGET);
} else { } else {
Register target = i.InputRegister(0); Register target = i.InputRegister(0);
__ Add(target, target, Code::kHeaderSize - kHeapObjectTag); __ Add(target, target, Code::kHeaderSize - kHeapObjectTag);
...@@ -708,8 +707,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -708,8 +707,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
i.TempRegister(2)); i.TempRegister(2));
} }
if (instr->InputAt(0)->IsImmediate()) { if (instr->InputAt(0)->IsImmediate()) {
__ Jump(Handle<Code>::cast(i.InputHeapObject(0)), __ Jump(i.InputCode(0), RelocInfo::CODE_TARGET);
RelocInfo::CODE_TARGET);
} else { } else {
Register target = i.InputRegister(0); Register target = i.InputRegister(0);
__ Add(target, target, Code::kHeaderSize - kHeapObjectTag); __ Add(target, target, Code::kHeaderSize - kHeapObjectTag);
......
...@@ -87,8 +87,8 @@ class InstructionOperandConverter { ...@@ -87,8 +87,8 @@ class InstructionOperandConverter {
return ToExternalReference(instr_->InputAt(index)); return ToExternalReference(instr_->InputAt(index));
} }
Handle<HeapObject> InputHeapObject(size_t index) { Handle<Code> InputCode(size_t index) {
return ToHeapObject(instr_->InputAt(index)); return ToCode(instr_->InputAt(index));
} }
Label* InputLabel(size_t index) { return ToLabel(instr_->InputAt(index)); } Label* InputLabel(size_t index) { return ToLabel(instr_->InputAt(index)); }
...@@ -159,8 +159,8 @@ class InstructionOperandConverter { ...@@ -159,8 +159,8 @@ class InstructionOperandConverter {
return ToConstant(op).ToExternalReference(); return ToConstant(op).ToExternalReference();
} }
Handle<HeapObject> ToHeapObject(InstructionOperand* op) { Handle<Code> ToCode(InstructionOperand* op) {
return ToConstant(op).ToHeapObject(); return ToConstant(op).ToCode();
} }
const Frame* frame() const { return gen_->frame(); } const Frame* frame() const { return gen_->frame(); }
......
...@@ -909,7 +909,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -909,7 +909,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
case kArchCallCodeObject: { case kArchCallCodeObject: {
EnsureSpaceForLazyDeopt(); EnsureSpaceForLazyDeopt();
if (HasImmediateInput(instr, 0)) { if (HasImmediateInput(instr, 0)) {
Handle<Code> code = Handle<Code>::cast(i.InputHeapObject(0)); Handle<Code> code = i.InputCode(0);
__ call(code, RelocInfo::CODE_TARGET); __ call(code, RelocInfo::CODE_TARGET);
} else { } else {
Register reg = i.InputRegister(0); Register reg = i.InputRegister(0);
...@@ -927,7 +927,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -927,7 +927,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
no_reg, no_reg, no_reg); no_reg, no_reg, no_reg);
} }
if (HasImmediateInput(instr, 0)) { if (HasImmediateInput(instr, 0)) {
Handle<Code> code = Handle<Code>::cast(i.InputHeapObject(0)); Handle<Code> code = i.InputCode(0);
__ jmp(code, RelocInfo::CODE_TARGET); __ jmp(code, RelocInfo::CODE_TARGET);
} else { } else {
Register reg = i.InputRegister(0); Register reg = i.InputRegister(0);
......
...@@ -561,6 +561,12 @@ Handle<HeapObject> Constant::ToHeapObject() const { ...@@ -561,6 +561,12 @@ Handle<HeapObject> Constant::ToHeapObject() const {
return value; return value;
} }
Handle<Code> Constant::ToCode() const {
DCHECK_EQ(kHeapObject, type());
Handle<Code> value(bit_cast<Code**>(static_cast<intptr_t>(value_)));
return value;
}
std::ostream& operator<<(std::ostream& os, const Constant& constant) { std::ostream& operator<<(std::ostream& os, const Constant& constant) {
switch (constant.type()) { switch (constant.type()) {
case Constant::kInt32: case Constant::kInt32:
......
...@@ -1101,6 +1101,7 @@ class V8_EXPORT_PRIVATE Constant final { ...@@ -1101,6 +1101,7 @@ class V8_EXPORT_PRIVATE Constant final {
} }
Handle<HeapObject> ToHeapObject() const; Handle<HeapObject> ToHeapObject() const;
Handle<Code> ToCode() const;
private: private:
Type type_; Type type_;
......
...@@ -613,8 +613,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -613,8 +613,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
case kArchCallCodeObject: { case kArchCallCodeObject: {
EnsureSpaceForLazyDeopt(); EnsureSpaceForLazyDeopt();
if (instr->InputAt(0)->IsImmediate()) { if (instr->InputAt(0)->IsImmediate()) {
__ Call(Handle<Code>::cast(i.InputHeapObject(0)), __ Call(i.InputCode(0), RelocInfo::CODE_TARGET);
RelocInfo::CODE_TARGET);
} else { } else {
__ Call(at, i.InputRegister(0), Code::kHeaderSize - kHeapObjectTag); __ Call(at, i.InputRegister(0), Code::kHeaderSize - kHeapObjectTag);
} }
...@@ -630,8 +629,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -630,8 +629,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
i.TempRegister(2)); i.TempRegister(2));
} }
if (instr->InputAt(0)->IsImmediate()) { if (instr->InputAt(0)->IsImmediate()) {
__ Jump(Handle<Code>::cast(i.InputHeapObject(0)), __ Jump(i.InputCode(0), RelocInfo::CODE_TARGET);
RelocInfo::CODE_TARGET);
} else { } else {
__ Jump(at, i.InputRegister(0), Code::kHeaderSize - kHeapObjectTag); __ Jump(at, i.InputRegister(0), Code::kHeaderSize - kHeapObjectTag);
} }
......
...@@ -651,8 +651,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -651,8 +651,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
case kArchCallCodeObject: { case kArchCallCodeObject: {
EnsureSpaceForLazyDeopt(); EnsureSpaceForLazyDeopt();
if (instr->InputAt(0)->IsImmediate()) { if (instr->InputAt(0)->IsImmediate()) {
__ Call(Handle<Code>::cast(i.InputHeapObject(0)), __ Call(i.InputCode(0), RelocInfo::CODE_TARGET);
RelocInfo::CODE_TARGET);
} else { } else {
__ daddiu(at, i.InputRegister(0), Code::kHeaderSize - kHeapObjectTag); __ daddiu(at, i.InputRegister(0), Code::kHeaderSize - kHeapObjectTag);
__ Call(at); __ Call(at);
...@@ -669,8 +668,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -669,8 +668,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
i.TempRegister(2)); i.TempRegister(2));
} }
if (instr->InputAt(0)->IsImmediate()) { if (instr->InputAt(0)->IsImmediate()) {
__ Jump(Handle<Code>::cast(i.InputHeapObject(0)), __ Jump(i.InputCode(0), RelocInfo::CODE_TARGET);
RelocInfo::CODE_TARGET);
} else { } else {
__ daddiu(at, i.InputRegister(0), Code::kHeaderSize - kHeapObjectTag); __ daddiu(at, i.InputRegister(0), Code::kHeaderSize - kHeapObjectTag);
__ Jump(at); __ Jump(at);
......
...@@ -834,7 +834,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -834,7 +834,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
case kArchCallCodeObject: { case kArchCallCodeObject: {
EnsureSpaceForLazyDeopt(); EnsureSpaceForLazyDeopt();
if (HasImmediateInput(instr, 0)) { if (HasImmediateInput(instr, 0)) {
Handle<Code> code = Handle<Code>::cast(i.InputHeapObject(0)); Handle<Code> code = i.InputCode(0);
__ Call(code, RelocInfo::CODE_TARGET); __ Call(code, RelocInfo::CODE_TARGET);
} else { } else {
Register reg = i.InputRegister(0); Register reg = i.InputRegister(0);
...@@ -853,7 +853,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction( ...@@ -853,7 +853,7 @@ CodeGenerator::CodeGenResult CodeGenerator::AssembleArchInstruction(
i.TempRegister(2)); i.TempRegister(2));
} }
if (HasImmediateInput(instr, 0)) { if (HasImmediateInput(instr, 0)) {
Handle<Code> code = Handle<Code>::cast(i.InputHeapObject(0)); Handle<Code> code = i.InputCode(0);
__ jmp(code, RelocInfo::CODE_TARGET); __ jmp(code, RelocInfo::CODE_TARGET);
} else { } else {
Register reg = i.InputRegister(0); Register reg = i.InputRegister(0);
......
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