/art/compiler/optimizing/ |
D | register_allocator_linear_scan.h | 33 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 …]
|
D | live_interval_test.cc | 25 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 …]
|
D | register_allocator.h | 32 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);
|
D | register_allocator_graph_color.h | 126 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_;
|
D | register_allocator_linear_scan.cc | 39 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 …]
|
D | register_allocator.cc | 59 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 …]
|
D | register_allocator_graph_color.cc | 163 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 …]
|
D | register_allocation_resolver.h | 31 class LiveInterval; variable 51 ArrayRef<LiveInterval* const> temp_intervals); 61 void ConnectSiblings(LiveInterval* interval); 64 void ConnectSplitSiblings(LiveInterval* interval, HBasicBlock* from, HBasicBlock* to) const;
|
D | ssa_liveness_analysis.cc | 59 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 …]
|
D | ssa_liveness_analysis.h | 101 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 …]
|
D | register_allocation_resolver.cc | 39 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 …]
|
D | live_ranges_test.cc | 72 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()
|
D | register_allocator_test.cc | 62 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 …]
|
D | optimizing_unit_test.h | 57 LiveInterval* BuildInterval(const size_t ranges[][2], 62 LiveInterval* interval = 63 LiveInterval::MakeInterval(allocator, DataType::Type::kInt32, defined_by);
|
D | graph_visualizer.cc | 603 LiveInterval* interval = instruction->GetLiveInterval(); in PrintInstruction()
|
D | nodes.h | 68 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_;
|