Flutter Engine
The Flutter Engine
Loading...
Searching...
No Matches
Public Member Functions | Private Member Functions | List of all members
dart::BranchInstr Class Reference

#include <il.h>

Inheritance diagram for dart::BranchInstr:
dart::Instruction dart::ZoneAllocated

Public Member Functions

 BranchInstr (ComparisonInstr *comparison, intptr_t deopt_id)
 
virtual intptr_t ArgumentCount () const
 
virtual void SetMoveArguments (MoveArgumentsArray *move_arguments)
 
virtual MoveArgumentsArrayGetMoveArguments () const
 
intptr_t InputCount () const
 
ValueInputAt (intptr_t i) const
 
virtual TokenPosition token_pos () const
 
virtual intptr_t inlining_id () const
 
virtual void set_inlining_id (intptr_t value)
 
virtual bool has_inlining_id () const
 
virtual bool ComputeCanDeoptimize () const
 
virtual bool CanBecomeDeoptimizationTarget () const
 
virtual bool HasUnknownSideEffects () const
 
virtual bool CanCallDart () const
 
ComparisonInstrcomparison () const
 
void SetComparison (ComparisonInstr *comp)
 
virtual intptr_t DeoptimizationTarget () const
 
virtual Representation RequiredInputRepresentation (intptr_t i) const
 
virtual InstructionCanonicalize (FlowGraph *flow_graph)
 
void set_constant_target (TargetEntryInstr *target)
 
TargetEntryInstrconstant_target () const
 
virtual void CopyDeoptIdFrom (const Instruction &instr)
 
virtual bool MayThrow () const
 
TargetEntryInstrtrue_successor () const
 
TargetEntryInstrfalse_successor () const
 
TargetEntryInstr ** true_successor_address ()
 
TargetEntryInstr ** false_successor_address ()
 
virtual intptr_t SuccessorCount () const
 
virtual BlockEntryInstrSuccessorAt (intptr_t index) const
 
- Public Member Functions inherited from dart::Instruction
 Instruction (const InstructionSource &source, intptr_t deopt_id=DeoptId::kNone)
 
 Instruction (intptr_t deopt_id=DeoptId::kNone)
 
virtual ~Instruction ()
 
virtual Tag tag () const =0
 
virtual intptr_t statistics_tag () const
 
intptr_t deopt_id () const
 
InstructionSource source () const
 
void SetInputAt (intptr_t i, Value *value)
 
InputsIterable inputs ()
 
void UnuseAllInputs ()
 
ValueArgumentValueAt (intptr_t index) const
 
DefinitionArgumentAt (intptr_t index) const
 
virtual void ReplaceInputsWithMoveArguments (MoveArgumentsArray *move_arguments)
 
bool HasMoveArguments () const
 
void RepairArgumentUsesInEnvironment () const
 
virtual bool ComputeCanDeoptimizeAfterCall () const
 
bool CanDeoptimize () const
 
virtual void Accept (InstructionVisitor *visitor)=0
 
Instructionprevious () const
 
void set_previous (Instruction *instr)
 
Instructionnext () const
 
void set_next (Instruction *instr)
 
void LinkTo (Instruction *next)
 
InstructionRemoveFromGraph (bool return_previous=true)
 
SuccessorsIterable successors () const
 
void Goto (JoinEntryInstr *entry)
 
virtual const char * DebugName () const =0
 
void CheckField (const Field &field) const
 
const char * ToCString () const
 
 DECLARE_INSTRUCTION_TYPE_CHECK (BlockEntryWithInitialDefs, BlockEntryWithInitialDefs) template< typename T > T *Cast()
 
template<typename T >
const TCast () const
 
LocationSummarylocs ()
 
bool HasLocs () const
 
virtual LocationSummaryMakeLocationSummary (Zone *zone, bool is_optimizing) const =0
 
void InitializeLocationSummary (Zone *zone, bool optimizing)
 
virtual void EmitNativeCode (FlowGraphCompiler *compiler)
 
Environmentenv () const
 
void SetEnvironment (Environment *deopt_env)
 
void RemoveEnvironment ()
 
void ReplaceInEnvironment (Definition *current, Definition *replacement)
 
virtual intptr_t NumberOfInputsConsumedBeforeCall () const
 
intptr_t GetPassSpecificId (CompilerPass::Id pass) const
 
void SetPassSpecificId (CompilerPass::Id pass, intptr_t id)
 
bool HasPassSpecificId (CompilerPass::Id pass) const
 
bool HasUnmatchedInputRepresentations () const
 
SpeculativeMode SpeculativeModeOfInputs () const
 
virtual SpeculativeMode SpeculativeModeOfInput (intptr_t index) const
 
virtual Representation representation () const
 
bool WasEliminated () const
 
void InsertBefore (Instruction *next)
 
void InsertAfter (Instruction *prev)
 
InstructionAppendInstruction (Instruction *tail)
 
virtual bool AllowsCSE () const
 
virtual bool CanTriggerGC () const
 
virtual BlockEntryInstrGetBlock ()
 
virtual uword Hash () const
 
bool Equals (const Instruction &other) const
 
virtual bool AttributesEqual (const Instruction &other) const
 
void InheritDeoptTarget (Zone *zone, Instruction *other)
 
bool NeedsEnvironment () const
 
void InheritDeoptTargetAfter (FlowGraph *flow_graph, Definition *call, Definition *result)
 
virtual bool MayHaveVisibleEffect () const
 
virtual bool CanEliminate (const BlockEntryInstr *block) const
 
bool CanEliminate ()
 
bool IsDominatedBy (Instruction *dom)
 
void ClearEnv ()
 
void Unsupported (FlowGraphCompiler *compiler)
 
virtual bool UseSharedSlowPathStub (bool is_optimizing) const
 
Location::Kind RegisterKindForResult () const
 
- Public Member Functions inherited from dart::ZoneAllocated
 ZoneAllocated ()
 
void * operator new (size_t size)
 
void * operator new (size_t size, Zone *zone)
 
void operator delete (void *pointer)
 

Private Member Functions

virtual void RawSetInputAt (intptr_t i, Value *value)
 

Additional Inherited Members

- Public Types inherited from dart::Instruction
enum  Tag { FOR_EACH_INSTRUCTION =(DECLARE_TAG) kNumInstructions }
 
enum  SpeculativeMode { kGuardInputs , kNotSpeculative }
 
using InputsIterable = InstructionIndexedPropertyIterable< InputsTrait >
 
using SuccessorsIterable = InstructionIndexedPropertyIterable< SuccessorsTrait >
 
- Static Public Member Functions inherited from dart::Instruction
static const ICDataGetICData (const ZoneGrowableArray< const ICData * > &ic_data_array, intptr_t deopt_id, bool is_static_call)
 
static LocationSummaryMakeCallSummary (Zone *zone, const Instruction *instr, LocationSummary *locs=nullptr)
 
static bool SlowPathSharingSupported (bool is_optimizing)
 
- Static Public Attributes inherited from dart::Instruction
static const intptr_t kInstructionAttrs [kNumInstructions]
 
- Protected Member Functions inherited from dart::Instruction
intptr_t GetDeoptId () const
 
void WriteExtraWithoutInputs (FlowGraphSerializer *s)
 
void ReadExtraWithoutInputs (FlowGraphDeserializer *d)
 

Detailed Description

Definition at line 3954 of file il.h.

Constructor & Destructor Documentation

◆ BranchInstr()

dart::BranchInstr::BranchInstr ( ComparisonInstr comparison,
intptr_t  deopt_id 
)
inlineexplicit

Definition at line 3956 of file il.h.

3957 : Instruction(deopt_id), comparison_(comparison) {
3958 ASSERT(comparison->env() == nullptr);
3959 for (intptr_t i = comparison->InputCount() - 1; i >= 0; --i) {
3961 }
3962 }
ComparisonInstr * comparison() const
Definition il.h:4003
virtual intptr_t InputCount() const =0
Instruction(const InstructionSource &source, intptr_t deopt_id=DeoptId::kNone)
Definition il.h:974
virtual Value * InputAt(intptr_t i) const =0
Environment * env() const
Definition il.h:1209
intptr_t deopt_id() const
Definition il.h:987
void set_instruction(Instruction *instruction)
Definition il.h:122
#define ASSERT(E)

Member Function Documentation

◆ ArgumentCount()

virtual intptr_t dart::BranchInstr::ArgumentCount ( ) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 3966 of file il.h.

3966 {
3967 return comparison()->ArgumentCount();
3968 }
virtual intptr_t ArgumentCount() const
Definition il.h:1035

◆ CanBecomeDeoptimizationTarget()

virtual bool dart::BranchInstr::CanBecomeDeoptimizationTarget ( ) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 3993 of file il.h.

3993 {
3995 }
virtual bool CanBecomeDeoptimizationTarget() const
Definition il.h:3864

◆ CanCallDart()

virtual bool dart::BranchInstr::CanCallDart ( ) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 4001 of file il.h.

4001{ return comparison()->CanCallDart(); }
virtual bool CanCallDart() const
Definition il.h:1298

◆ Canonicalize()

Instruction * dart::BranchInstr::Canonicalize ( FlowGraph flow_graph)
virtual

Reimplemented from dart::Instruction.

Definition at line 3645 of file il.cc.

3645 {
3646 Zone* zone = flow_graph->zone();
3647 if (comparison()->IsStrictCompare()) {
3648 bool negated = false;
3649 Definition* replacement = CanonicalizeStrictCompare(
3650 comparison()->AsStrictCompare(), &negated, /*is_branch=*/true);
3651 if (replacement == comparison()) {
3652 return this;
3653 }
3654 ComparisonInstr* comp = replacement->AsComparison();
3655 if ((comp == nullptr) || comp->CanDeoptimize() ||
3656 comp->HasUnmatchedInputRepresentations()) {
3657 return this;
3658 }
3659
3660 // Replace the comparison if the replacement is used at this branch,
3661 // and has exactly one use.
3662 Value* use = comp->input_use_list();
3663 if ((use->instruction() == this) && comp->HasOnlyUse(use)) {
3664 if (negated) {
3665 comp->NegateComparison();
3666 }
3668 flow_graph->CopyDeoptTarget(this, comp);
3669 // Unlink environment from the comparison since it is copied to the
3670 // branch instruction.
3671 comp->RemoveEnvironment();
3672
3673 comp->RemoveFromGraph();
3674 SetComparison(comp);
3675 if (FLAG_trace_optimization && flow_graph->should_print()) {
3676 THR_Print("Merging comparison v%" Pd "\n", comp->ssa_temp_index());
3677 }
3678 // Clear the comparison's temp index and ssa temp index since the
3679 // value of the comparison is not used outside the branch anymore.
3680 ASSERT(comp->input_use_list() == nullptr);
3681 comp->ClearSSATempIndex();
3682 comp->ClearTempIndex();
3683 }
3684
3685 return this;
3686 }
3687
3688 if (comparison()->IsEqualityCompare() &&
3689 comparison()->operation_cid() == kSmiCid) {
3690 BinarySmiOpInstr* bit_and = nullptr;
3691 bool negate = false;
3693 &negate)) {
3694 bit_and = comparison()->left()->definition()->AsBinarySmiOp();
3695 } else if (RecognizeTestPattern(comparison()->right(), comparison()->left(),
3696 &negate)) {
3697 bit_and = comparison()->right()->definition()->AsBinarySmiOp();
3698 }
3699 if (bit_and != nullptr) {
3700 if (FLAG_trace_optimization && flow_graph->should_print()) {
3701 THR_Print("Merging test smi v%" Pd "\n", bit_and->ssa_temp_index());
3702 }
3703 TestSmiInstr* test = new TestSmiInstr(
3704 comparison()->source(),
3705 negate ? Token::NegateComparison(comparison()->kind())
3706 : comparison()->kind(),
3707 bit_and->left()->Copy(zone), bit_and->right()->Copy(zone));
3710 flow_graph->CopyDeoptTarget(this, bit_and);
3712 bit_and->RemoveFromGraph();
3713 }
3714 }
3715 return this;
3716}
static bool left(const SkPoint &p0, const SkPoint &p1)
static bool right(const SkPoint &p0, const SkPoint &p1)
void SetComparison(ComparisonInstr *comp)
Definition il.cc:1663
Value * right() const
Definition il.h:3829
Value * left() const
Definition il.h:3828
void RemoveEnvironment()
Definition il.cc:1280
bool CanDeoptimize() const
Definition il.h:1073
friend class ComparisonInstr
Definition il.h:1395
InstructionSource source() const
Definition il.h:1002
static Token::Kind NegateComparison(Token::Kind op)
Definition token.h:322
Definition * definition() const
Definition il.h:103
#define THR_Print(format,...)
Definition log.h:20
static Definition * CanonicalizeStrictCompare(StrictCompareInstr *compare, bool *negated, bool is_branch)
Definition il.cc:3553
static bool RecognizeTestPattern(Value *left, Value *right, bool *negate)
Definition il.cc:3611
#define Pd
Definition globals.h:408

◆ comparison()

ComparisonInstr * dart::BranchInstr::comparison ( ) const
inline

Definition at line 4003 of file il.h.

4003{ return comparison_; }

◆ ComputeCanDeoptimize()

virtual bool dart::BranchInstr::ComputeCanDeoptimize ( ) const
inlinevirtual

Implements dart::Instruction.

Definition at line 3989 of file il.h.

3989 {
3990 return comparison()->ComputeCanDeoptimize();
3991 }
virtual bool ComputeCanDeoptimize() const =0

◆ constant_target()

TargetEntryInstr * dart::BranchInstr::constant_target ( ) const
inline

Definition at line 4020 of file il.h.

4020{ return constant_target_; }

◆ CopyDeoptIdFrom()

virtual void dart::BranchInstr::CopyDeoptIdFrom ( const Instruction instr)
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 4022 of file il.h.

4022 {
4024 comparison()->CopyDeoptIdFrom(instr);
4025 }
virtual void CopyDeoptIdFrom(const Instruction &instr)
Definition il.h:1405

◆ DeoptimizationTarget()

virtual intptr_t dart::BranchInstr::DeoptimizationTarget ( ) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 4006 of file il.h.

4006 {
4007 return comparison()->DeoptimizationTarget();
4008 }
virtual intptr_t DeoptimizationTarget() const
Definition il.h:3865

◆ false_successor()

TargetEntryInstr * dart::BranchInstr::false_successor ( ) const
inline

Definition at line 4030 of file il.h.

4030{ return false_successor_; }

◆ false_successor_address()

TargetEntryInstr ** dart::BranchInstr::false_successor_address ( )
inline

Definition at line 4033 of file il.h.

4033{ return &false_successor_; }

◆ GetMoveArguments()

virtual MoveArgumentsArray * dart::BranchInstr::GetMoveArguments ( ) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 3972 of file il.h.

3972 {
3973 return comparison()->GetMoveArguments();
3974 }
virtual MoveArgumentsArray * GetMoveArguments() const
Definition il.h:1044

◆ has_inlining_id()

virtual bool dart::BranchInstr::has_inlining_id ( ) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 3985 of file il.h.

3985 {
3986 return comparison_->has_inlining_id();
3987 }

◆ HasUnknownSideEffects()

virtual bool dart::BranchInstr::HasUnknownSideEffects ( ) const
inlinevirtual

Implements dart::Instruction.

Definition at line 3997 of file il.h.

3997 {
3999 }
virtual bool HasUnknownSideEffects() const =0

◆ inlining_id()

virtual intptr_t dart::BranchInstr::inlining_id ( ) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 3981 of file il.h.

3981{ return comparison_->inlining_id(); }

◆ InputAt()

Value * dart::BranchInstr::InputAt ( intptr_t  i) const
inlinevirtual

Implements dart::Instruction.

Definition at line 3978 of file il.h.

3978{ return comparison()->InputAt(i); }

◆ InputCount()

intptr_t dart::BranchInstr::InputCount ( ) const
inlinevirtual

Implements dart::Instruction.

Definition at line 3976 of file il.h.

3976{ return comparison()->InputCount(); }

◆ MayThrow()

virtual bool dart::BranchInstr::MayThrow ( ) const
inlinevirtual

Implements dart::Instruction.

Definition at line 4027 of file il.h.

4027{ return comparison()->MayThrow(); }
virtual bool MayThrow() const =0

◆ RawSetInputAt()

virtual void dart::BranchInstr::RawSetInputAt ( intptr_t  i,
Value value 
)
inlineprivatevirtual

Implements dart::Instruction.

Definition at line 4047 of file il.h.

4047 {
4048 comparison()->RawSetInputAt(i, value);
4049 }

◆ RequiredInputRepresentation()

virtual Representation dart::BranchInstr::RequiredInputRepresentation ( intptr_t  i) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 4010 of file il.h.

4010 {
4012 }
virtual Representation RequiredInputRepresentation(intptr_t idx) const
Definition il.h:1235

◆ set_constant_target()

void dart::BranchInstr::set_constant_target ( TargetEntryInstr target)
inline

Definition at line 4016 of file il.h.

4016 {
4018 constant_target_ = target;
4019 }
TargetEntryInstr * false_successor() const
Definition il.h:4030
TargetEntryInstr * true_successor() const
Definition il.h:4029
uint32_t * target

◆ set_inlining_id()

virtual void dart::BranchInstr::set_inlining_id ( intptr_t  value)
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 3982 of file il.h.

3982 {
3983 return comparison_->set_inlining_id(value);
3984 }

◆ SetComparison()

void dart::BranchInstr::SetComparison ( ComparisonInstr comp)

Definition at line 1663 of file il.cc.

1663 {
1664 for (intptr_t i = new_comparison->InputCount() - 1; i >= 0; --i) {
1665 Value* input = new_comparison->InputAt(i);
1666 input->definition()->AddInputUse(input);
1667 input->set_instruction(this);
1668 }
1669 // There should be no need to copy or unuse an environment.
1670 ASSERT(comparison()->env() == nullptr);
1671 ASSERT(new_comparison->env() == nullptr);
1672 // Remove the current comparison's input uses.
1674 ASSERT(!new_comparison->HasUses());
1675 comparison_ = new_comparison;
1676}
void UnuseAllInputs()
Definition il.cc:1525

◆ SetMoveArguments()

virtual void dart::BranchInstr::SetMoveArguments ( MoveArgumentsArray move_arguments)
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 3969 of file il.h.

3969 {
3970 comparison()->SetMoveArguments(move_arguments);
3971 }
virtual void SetMoveArguments(MoveArgumentsArray *move_arguments)
Definition il.h:1040

◆ SuccessorAt()

BlockEntryInstr * dart::BranchInstr::SuccessorAt ( intptr_t  index) const
virtual

Reimplemented from dart::Instruction.

Definition at line 2005 of file il.cc.

2005 {
2006 if (index == 0) return true_successor_;
2007 if (index == 1) return false_successor_;
2008 UNREACHABLE();
2009 return nullptr;
2010}
#define UNREACHABLE()
Definition assert.h:248

◆ SuccessorCount()

intptr_t dart::BranchInstr::SuccessorCount ( ) const
virtual

Reimplemented from dart::Instruction.

Definition at line 2001 of file il.cc.

2001 {
2002 return 2;
2003}

◆ token_pos()

virtual TokenPosition dart::BranchInstr::token_pos ( ) const
inlinevirtual

Reimplemented from dart::Instruction.

Definition at line 3980 of file il.h.

3980{ return comparison_->token_pos(); }

◆ true_successor()

TargetEntryInstr * dart::BranchInstr::true_successor ( ) const
inline

Definition at line 4029 of file il.h.

4029{ return true_successor_; }

◆ true_successor_address()

TargetEntryInstr ** dart::BranchInstr::true_successor_address ( )
inline

Definition at line 4032 of file il.h.

4032{ return &true_successor_; }

The documentation for this class was generated from the following files: