Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef V8_REGISTER_ALLOCATOR_H_ | 5 #ifndef V8_REGISTER_ALLOCATOR_H_ |
| 6 #define V8_REGISTER_ALLOCATOR_H_ | 6 #define V8_REGISTER_ALLOCATOR_H_ |
| 7 | 7 |
| 8 #include "src/compiler/instruction.h" | 8 #include "src/compiler/instruction.h" |
| 9 #include "src/ostreams.h" | 9 #include "src/ostreams.h" |
| 10 #include "src/zone-containers.h" | 10 #include "src/zone-containers.h" |
| (...skipping 410 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 421 const InstructionOperand& spill_op); | 421 const InstructionOperand& spill_op); |
| 422 void SetUseHints(int register_index); | 422 void SetUseHints(int register_index); |
| 423 void UnsetUseHints() { SetUseHints(kUnassignedRegister); } | 423 void UnsetUseHints() { SetUseHints(kUnassignedRegister); } |
| 424 | 424 |
| 425 struct SpillAtDefinitionList; | 425 struct SpillAtDefinitionList; |
| 426 | 426 |
| 427 SpillAtDefinitionList* spills_at_definition() const { | 427 SpillAtDefinitionList* spills_at_definition() const { |
| 428 return spills_at_definition_; | 428 return spills_at_definition_; |
| 429 } | 429 } |
| 430 | 430 |
| 431 // Used solely by the Greedy Allocator: | |
| 432 unsigned GetSize(); | |
| 433 float weight() const { return weight_; } | |
| 434 void set_weight(float weight) { weight_ = weight; } | |
| 435 | |
| 436 static const int kInvalidSize = -1; | |
| 437 static const float kInvalidWeight; | |
| 438 static const float kMaxWeight; | |
| 439 | |
| 431 private: | 440 private: |
| 432 void set_spill_type(SpillType value) { | 441 void set_spill_type(SpillType value) { |
| 433 bits_ = SpillTypeField::update(bits_, value); | 442 bits_ = SpillTypeField::update(bits_, value); |
| 434 } | 443 } |
| 435 | 444 |
| 436 void set_spilled(bool value) { bits_ = SpilledField::update(bits_, value); } | 445 void set_spilled(bool value) { bits_ = SpilledField::update(bits_, value); } |
| 437 | 446 |
| 438 UseInterval* FirstSearchIntervalForPosition(LifetimePosition position) const; | 447 UseInterval* FirstSearchIntervalForPosition(LifetimePosition position) const; |
| 439 void AdvanceLastProcessedMarker(UseInterval* to_start_of, | 448 void AdvanceLastProcessedMarker(UseInterval* to_start_of, |
| 440 LifetimePosition but_not_past) const; | 449 LifetimePosition but_not_past) const; |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 461 SpillRange* spill_range_; | 470 SpillRange* spill_range_; |
| 462 }; | 471 }; |
| 463 SpillAtDefinitionList* spills_at_definition_; | 472 SpillAtDefinitionList* spills_at_definition_; |
| 464 // This is used as a cache, it doesn't affect correctness. | 473 // This is used as a cache, it doesn't affect correctness. |
| 465 mutable UseInterval* current_interval_; | 474 mutable UseInterval* current_interval_; |
| 466 // This is used as a cache, it doesn't affect correctness. | 475 // This is used as a cache, it doesn't affect correctness. |
| 467 mutable UsePosition* last_processed_use_; | 476 mutable UsePosition* last_processed_use_; |
| 468 // This is used as a cache, it's invalid outside of BuildLiveRanges. | 477 // This is used as a cache, it's invalid outside of BuildLiveRanges. |
| 469 mutable UsePosition* current_hint_position_; | 478 mutable UsePosition* current_hint_position_; |
| 470 | 479 |
| 480 // Used solely by the Greedy Allocator: | |
| 481 int size_; | |
|
titzer
2015/06/29 11:17:57
Can you add a only liner explaining what "size" me
Mircea Trofin
2015/06/29 13:20:16
Done.
| |
| 482 float weight_; | |
|
titzer
2015/06/29 11:17:57
Is this the spill weight or the priority for alloc
Mircea Trofin
2015/06/29 13:20:16
Done.
| |
| 471 DISALLOW_COPY_AND_ASSIGN(LiveRange); | 483 DISALLOW_COPY_AND_ASSIGN(LiveRange); |
| 472 }; | 484 }; |
| 473 | 485 |
| 474 | 486 |
| 475 struct PrintableLiveRange { | 487 struct PrintableLiveRange { |
| 476 const RegisterConfiguration* register_configuration_; | 488 const RegisterConfiguration* register_configuration_; |
| 477 const LiveRange* range_; | 489 const LiveRange* range_; |
| 478 }; | 490 }; |
| 479 | 491 |
| 480 | 492 |
| (...skipping 282 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 763 LifetimePosition end); | 775 LifetimePosition end); |
| 764 | 776 |
| 765 void Spill(LiveRange* range); | 777 void Spill(LiveRange* range); |
| 766 | 778 |
| 767 // If we are trying to spill a range inside the loop try to | 779 // If we are trying to spill a range inside the loop try to |
| 768 // hoist spill position out to the point just before the loop. | 780 // hoist spill position out to the point just before the loop. |
| 769 LifetimePosition FindOptimalSpillingPos(LiveRange* range, | 781 LifetimePosition FindOptimalSpillingPos(LiveRange* range, |
| 770 LifetimePosition pos); | 782 LifetimePosition pos); |
| 771 | 783 |
| 772 const ZoneVector<LiveRange*>& GetFixedRegisters() const; | 784 const ZoneVector<LiveRange*>& GetFixedRegisters() const; |
| 785 const char* RegisterName(int allocation_index) const; | |
| 773 | 786 |
| 774 private: | 787 private: |
| 775 RegisterAllocationData* const data_; | 788 RegisterAllocationData* const data_; |
| 776 const RegisterKind mode_; | 789 const RegisterKind mode_; |
| 777 const int num_registers_; | 790 const int num_registers_; |
| 778 | 791 |
| 779 DISALLOW_COPY_AND_ASSIGN(RegisterAllocator); | 792 DISALLOW_COPY_AND_ASSIGN(RegisterAllocator); |
| 780 }; | 793 }; |
| 781 | 794 |
| 782 | 795 |
| 783 class LinearScanAllocator final : public RegisterAllocator { | 796 class LinearScanAllocator final : public RegisterAllocator { |
| 784 public: | 797 public: |
| 785 LinearScanAllocator(RegisterAllocationData* data, RegisterKind kind, | 798 LinearScanAllocator(RegisterAllocationData* data, RegisterKind kind, |
| 786 Zone* local_zone); | 799 Zone* local_zone); |
| 787 | 800 |
| 788 // Phase 4: compute register assignments. | 801 // Phase 4: compute register assignments. |
| 789 void AllocateRegisters(); | 802 void AllocateRegisters(); |
| 790 | 803 |
| 791 private: | 804 private: |
| 792 const char* RegisterName(int allocation_index) const; | |
| 793 | |
| 794 ZoneVector<LiveRange*>& unhandled_live_ranges() { | 805 ZoneVector<LiveRange*>& unhandled_live_ranges() { |
| 795 return unhandled_live_ranges_; | 806 return unhandled_live_ranges_; |
| 796 } | 807 } |
| 797 ZoneVector<LiveRange*>& active_live_ranges() { return active_live_ranges_; } | 808 ZoneVector<LiveRange*>& active_live_ranges() { return active_live_ranges_; } |
| 798 ZoneVector<LiveRange*>& inactive_live_ranges() { | 809 ZoneVector<LiveRange*>& inactive_live_ranges() { |
| 799 return inactive_live_ranges_; | 810 return inactive_live_ranges_; |
| 800 } | 811 } |
| 801 | 812 |
| 802 void SetLiveRangeAssignedRegister(LiveRange* range, int reg); | 813 void SetLiveRangeAssignedRegister(LiveRange* range, int reg); |
| 803 | 814 |
| (...skipping 116 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 920 RegisterAllocationData* const data_; | 931 RegisterAllocationData* const data_; |
| 921 | 932 |
| 922 DISALLOW_COPY_AND_ASSIGN(LiveRangeConnector); | 933 DISALLOW_COPY_AND_ASSIGN(LiveRangeConnector); |
| 923 }; | 934 }; |
| 924 | 935 |
| 925 } // namespace compiler | 936 } // namespace compiler |
| 926 } // namespace internal | 937 } // namespace internal |
| 927 } // namespace v8 | 938 } // namespace v8 |
| 928 | 939 |
| 929 #endif // V8_REGISTER_ALLOCATOR_H_ | 940 #endif // V8_REGISTER_ALLOCATOR_H_ |
| OLD | NEW |