Home
last modified time | relevance | path

Searched refs:LiveInterval (Results 1 – 16 of 16) sorted by relevance

/art/compiler/optimizing/
Dregister_allocator_linear_scan.h33 class LiveInterval; variable
69 bool TryAllocateFreeReg(LiveInterval* interval);
70 bool AllocateBlockedReg(LiveInterval* interval);
73 static void AddSorted(ScopedArenaVector<LiveInterval*>* array, LiveInterval* interval);
84 void AllocateSpillSlotFor(LiveInterval* interval);
95 void DumpInterval(std::ostream& stream, LiveInterval* interval) const;
98 int FindAvailableRegister(size_t* next_use, LiveInterval* current) const;
110 ScopedArenaVector<LiveInterval*> unhandled_core_intervals_;
113 ScopedArenaVector<LiveInterval*> unhandled_fp_intervals_;
117 ScopedArenaVector<LiveInterval*>* unhandled_;
[all …]
Dlive_interval_test.cc25 TEST(LiveInterval, GetStart) { in TEST() argument
31 LiveInterval* interval = BuildInterval(ranges, arraysize(ranges), allocator); in TEST()
37 LiveInterval* interval = BuildInterval(ranges, arraysize(ranges), allocator); in TEST()
42 TEST(LiveInterval, IsDeadAt) { in TEST() argument
48 LiveInterval* interval = BuildInterval(ranges, arraysize(ranges), allocator); in TEST()
58 LiveInterval* interval = BuildInterval(ranges, arraysize(ranges), allocator); in TEST()
70 TEST(LiveInterval, Covers) { in TEST() argument
76 LiveInterval* interval = BuildInterval(ranges, arraysize(ranges), allocator); in TEST()
86 LiveInterval* interval = BuildInterval(ranges, arraysize(ranges), allocator); in TEST()
98 TEST(LiveInterval, FirstIntersectionWith) { in TEST() argument
[all …]
Dregister_allocator.h32 class LiveInterval; variable
67 static bool ValidateIntervals(ArrayRef<LiveInterval* const> intervals,
84 static LiveInterval* Split(LiveInterval* interval, size_t position);
88 LiveInterval* SplitBetween(LiveInterval* interval, size_t from, size_t to);
Dregister_allocator_graph_color.h126 static LiveInterval* TrySplit(LiveInterval* interval, size_t position);
132 void SplitAtRegisterUses(LiveInterval* interval);
145 void ColorSpillSlots(ArrayRef<LiveInterval* const> nodes, /* out */ size_t* num_stack_slots_used);
157 ScopedArenaVector<LiveInterval*> core_intervals_;
158 ScopedArenaVector<LiveInterval*> fp_intervals_;
161 ScopedArenaVector<LiveInterval*> temp_intervals_;
Dregister_allocator_linear_scan.cc39 static bool IsLowOfUnalignedPairInterval(LiveInterval* low) { in IsLowOfUnalignedPairInterval()
86 static bool ShouldProcess(bool processing_core_registers, LiveInterval* interval) { in ShouldProcess()
103 ArrayRef<LiveInterval* const>(temp_intervals_)); in AllocateRegisters()
134 LiveInterval* interval = location.IsRegister() in BlockRegister()
141 interval = LiveInterval::MakeFixedInterval(allocator_, reg, type); in BlockRegister()
192 for (LiveInterval* fixed : physical_core_register_intervals_) { in AllocateRegistersInternal()
212 for (LiveInterval* fixed : physical_fp_register_intervals_) { in AllocateRegistersInternal()
241 LiveInterval* interval = in ProcessInstruction()
242 LiveInterval::MakeTempInterval(allocator_, DataType::Type::kInt32); in ProcessInstruction()
250 LiveInterval* interval = in ProcessInstruction()
[all …]
Dregister_allocator.cc59 LiveInterval* bad_live_interval = reinterpret_cast<LiveInterval*>(0xebad7113u); in ~RegisterAllocator()
84 explicit AllRangesIterator(LiveInterval* interval) in AllRangesIterator()
90 LiveInterval* CurrentInterval() const { return current_interval_; } in CurrentInterval()
103 LiveInterval* current_interval_;
109 bool RegisterAllocator::ValidateIntervals(ArrayRef<LiveInterval* const> intervals, in ValidateIntervals()
124 for (LiveInterval* start_interval : intervals) { in ValidateIntervals()
138 for (LiveInterval* start_interval : intervals) { in ValidateIntervals()
140 LiveInterval* current = it.CurrentInterval(); in ValidateIntervals()
188 for (LiveInterval* interval : intervals) { in ValidateIntervals()
215 LiveInterval* RegisterAllocator::Split(LiveInterval* interval, size_t position) { in Split()
[all …]
Dregister_allocator_graph_color.cc163 static float ComputeSpillWeight(LiveInterval* interval, const SsaLivenessAnalysis& liveness) { in ComputeSpillWeight()
220 InterferenceNode(LiveInterval* interval, in InterferenceNode()
277 LiveInterval* GetInterval() const { in GetInterval()
374 LiveInterval* const interval_;
457 void BuildInterferenceGraph(const ScopedArenaVector<LiveInterval*>& intervals,
531 ScopedArenaHashMap<LiveInterval*, InterferenceNode*> interval_node_map_;
567 static bool IsCoreInterval(LiveInterval* interval) { in IsCoreInterval()
601 LiveInterval* interval = LiveInterval::MakeFixedInterval(allocator_, i, DataType::Type::kInt32); in RegisterAllocatorGraphColor()
612 LiveInterval* interval = in RegisterAllocatorGraphColor()
613 LiveInterval::MakeFixedInterval(allocator_, i, DataType::Type::kFloat32); in RegisterAllocatorGraphColor()
[all …]
Dregister_allocation_resolver.h31 class LiveInterval; variable
51 ArrayRef<LiveInterval* const> temp_intervals);
61 void ConnectSiblings(LiveInterval* interval);
64 void ConnectSplitSiblings(LiveInterval* interval, HBasicBlock* from, HBasicBlock* to) const;
Dssa_liveness_analysis.cc59 LiveInterval::MakeInterval(allocator_, current->GetType(), current)); in NumberInstructions()
77 LiveInterval::MakeInterval(allocator_, current->GetType(), current)); in NumberInstructions()
232 LiveInterval* interval = current->GetLiveInterval(); in ComputeLiveRanges()
296 void LiveInterval::DumpWithContext(std::ostream& stream, in DumpWithContext()
321 int LiveInterval::FindFirstRegisterHint(size_t* free_until, in FindFirstRegisterHint()
347 LiveInterval* existing = GetParent()->GetSiblingAt(position); in FindFirstRegisterHint()
418 int LiveInterval::FindHintAtDefinition() const { in FindHintAtDefinition()
425 LiveInterval* input_interval = inputs[i]->GetLiveInterval()->GetSiblingAt(end - 1); in FindHintAtDefinition()
441 LiveInterval* input_interval = in FindHintAtDefinition()
457 bool LiveInterval::SameRegisterKind(Location other) const { in SameRegisterKind()
[all …]
Dssa_liveness_analysis.h101 friend class LiveInterval; variable
264 class LiveInterval : public ArenaObject<kArenaAllocSsaLiveness> {
266 static LiveInterval* MakeInterval(ScopedArenaAllocator* allocator,
269 return new (allocator) LiveInterval(allocator, type, instruction);
272 static LiveInterval* MakeFixedInterval(ScopedArenaAllocator* allocator, in MakeFixedInterval()
275 return new (allocator) LiveInterval(allocator, type, nullptr, true, reg, false); in MakeFixedInterval()
278 static LiveInterval* MakeTempInterval(ScopedArenaAllocator* allocator, DataType::Type type) { in MakeTempInterval()
279 return new (allocator) LiveInterval(allocator, type, nullptr, false, kNoRegister, true); in MakeTempInterval()
466 LiveInterval* GetParent() const { return parent_; } in GetParent()
506 size_t FirstIntersectionWith(LiveInterval* current) const { in FirstIntersectionWith()
[all …]
Dregister_allocation_resolver.cc39 ArrayRef<LiveInterval* const> temp_intervals) { in Resolve()
60 LiveInterval* current = instruction->GetLiveInterval(); in Resolve()
160 LiveInterval* interval = liveness_.GetInstructionFromSsaIndex(idx)->GetLiveInterval(); in Resolve()
161 LiveInterval* sibling = interval->GetSiblingAt(block->GetLifetimeStart()); in Resolve()
173 LiveInterval* interval = liveness_.GetInstructionFromSsaIndex(idx)->GetLiveInterval(); in Resolve()
202 for (LiveInterval* temp : temp_intervals) { in Resolve()
235 for (LiveInterval* current = instruction->GetLiveInterval(); in UpdateSafepointLiveRegisters()
298 void RegisterAllocationResolver::ConnectSiblings(LiveInterval* interval) { in ConnectSiblings()
299 LiveInterval* current = interval; in ConnectSiblings()
376 LiveInterval* next_sibling = current->GetNextSibling(); in ConnectSiblings()
[all …]
Dlive_ranges_test.cc72 LiveInterval* interval = liveness.GetInstructionFromSsaIndex(0)->GetLiveInterval(); in TEST_F()
118 LiveInterval* interval = liveness.GetInstructionFromSsaIndex(0)->GetLiveInterval(); in TEST_F()
168 LiveInterval* interval = liveness.GetInstructionFromSsaIndex(1)->GetLiveInterval(); in TEST_F()
245 LiveInterval* interval = graph->GetIntConstant(0)->GetLiveInterval(); in TEST_F()
323 LiveInterval* interval = constant->GetLiveInterval(); in TEST_F()
398 LiveInterval* interval = liveness.GetInstructionFromSsaIndex(0)->GetLiveInterval(); in TEST_F()
Dregister_allocator_test.cc62 bool ValidateIntervals(const ScopedArenaVector<LiveInterval*>& intervals, in ValidateIntervals()
64 return RegisterAllocator::ValidateIntervals(ArrayRef<LiveInterval* const>(intervals), in ValidateIntervals()
104 ScopedArenaVector<LiveInterval*> intervals(GetScopedAllocator()->Adapter()); in TEST_F()
340 LiveInterval* phi_interval = phi->GetLiveInterval(); in Loop3()
341 LiveInterval* loop_update = phi->InputAt(1)->GetLiveInterval(); in Loop3()
371 LiveInterval* interval = first_xor->GetLiveInterval(); in TEST_F()
384 LiveInterval* new_interval = interval->SplitAt(last_xor->GetLifetimePosition() - 1); in TEST_F()
449 LiveInterval* unhandled = graph->GetEntryBlock()->GetFirstInstruction()->GetLiveInterval(); in TEST_F()
465 LiveInterval* interval = in TEST_F()
466 LiveInterval::MakeFixedInterval(GetScopedAllocator(), 0, DataType::Type::kInt32); in TEST_F()
[all …]
Doptimizing_unit_test.h57 LiveInterval* BuildInterval(const size_t ranges[][2],
62 LiveInterval* interval =
63 LiveInterval::MakeInterval(allocator, DataType::Type::kInt32, defined_by);
Dgraph_visualizer.cc603 LiveInterval* interval = instruction->GetLiveInterval(); in PrintInstruction()
Dnodes.h68 class LiveInterval; variable
2301 LiveInterval* GetLiveInterval() const { return live_interval_; } in GetLiveInterval()
2302 void SetLiveInterval(LiveInterval* interval) { live_interval_ = interval; } in SetLiveInterval()
2480 LiveInterval* live_interval_;