diff options
| author | 2017-06-28 16:02:59 +0000 | |
|---|---|---|
| committer | 2017-06-28 16:02:59 +0000 | |
| commit | a6d098c3f4da902d6607972fcadaf57760d76d63 (patch) | |
| tree | 3d0a0590183765deacb3ed812b4f4fe5b3e78cf1 /compiler/optimizing/loop_optimization.h | |
| parent | 0ca1ae25d33dc8b92d9eecd585657f74cbb313e9 (diff) | |
| parent | 14a68b4aa9620e4fd58907255b049fb5c18bd1ec (diff) | |
Merge "Unrolling and dynamic loop peeling framework in vectorizer."
Diffstat (limited to 'compiler/optimizing/loop_optimization.h')
| -rw-r--r-- | compiler/optimizing/loop_optimization.h | 28 | 
1 files changed, 20 insertions, 8 deletions
| diff --git a/compiler/optimizing/loop_optimization.h b/compiler/optimizing/loop_optimization.h index cc6343aeb5..de4bd85fc8 100644 --- a/compiler/optimizing/loop_optimization.h +++ b/compiler/optimizing/loop_optimization.h @@ -116,14 +116,15 @@ class HLoopOptimization : public HOptimization {    void OptimizeInnerLoop(LoopNode* node);    // Vectorization analysis and synthesis. -  bool CanVectorize(LoopNode* node, HBasicBlock* block, int64_t trip_count); +  bool ShouldVectorize(LoopNode* node, HBasicBlock* block, int64_t trip_count);    void Vectorize(LoopNode* node, HBasicBlock* block, HBasicBlock* exit, int64_t trip_count);    void GenerateNewLoop(LoopNode* node,                         HBasicBlock* block,                         HBasicBlock* new_preheader,                         HInstruction* lo,                         HInstruction* hi, -                       HInstruction* step); +                       HInstruction* step, +                       uint32_t unroll);    bool VectorizeDef(LoopNode* node, HInstruction* instruction, bool generate_code);    bool VectorizeUse(LoopNode* node,                      HInstruction* instruction, @@ -133,10 +134,11 @@ class HLoopOptimization : public HOptimization {    bool TrySetVectorType(Primitive::Type type, /*out*/ uint64_t* restrictions);    bool TrySetVectorLength(uint32_t length);    void GenerateVecInv(HInstruction* org, Primitive::Type type); -  void GenerateVecSub(HInstruction* org, HInstruction* off); +  void GenerateVecSub(HInstruction* org, HInstruction* offset);    void GenerateVecMem(HInstruction* org,                        HInstruction* opa,                        HInstruction* opb, +                      HInstruction* offset,                        Primitive::Type type);    void GenerateVecOp(HInstruction* org,                       HInstruction* opa, @@ -151,6 +153,11 @@ class HLoopOptimization : public HOptimization {                                  Primitive::Type type,                                  uint64_t restrictions); +  // Vectorization heuristics. +  bool IsVectorizationProfitable(int64_t trip_count); +  void SetPeelingCandidate(int64_t trip_count); +  uint32_t GetUnrollingFactor(HBasicBlock* block, int64_t trip_count); +    // Helpers.    bool TrySetPhiInduction(HPhi* phi, bool restrict_uses);    bool TrySetSimpleLoopHeader(HBasicBlock* block); @@ -208,20 +215,25 @@ class HLoopOptimization : public HOptimization {    // Contents reside in phase-local heap memory.    ArenaSet<ArrayReference>* vector_refs_; +  // Dynamic loop peeling candidate for alignment. +  const ArrayReference* vector_peeling_candidate_; + +  // Dynamic data dependence test of the form a != b. +  HInstruction* vector_runtime_test_a_; +  HInstruction* vector_runtime_test_b_; +    // Mapping used during vectorization synthesis for both the scalar peeling/cleanup -  // loop (simd_ is false) and the actual vector loop (simd_ is true). The data +  // loop (mode is kSequential) and the actual vector loop (mode is kVector). The data    // structure maps original instructions into the new instructions.    // Contents reside in phase-local heap memory.    ArenaSafeMap<HInstruction*, HInstruction*>* vector_map_;    // Temporary vectorization bookkeeping. +  VectorMode vector_mode_;  // synthesis mode    HBasicBlock* vector_preheader_;  // preheader of the new loop    HBasicBlock* vector_header_;  // header of the new loop    HBasicBlock* vector_body_;  // body of the new loop -  HInstruction* vector_runtime_test_a_; -  HInstruction* vector_runtime_test_b_;  // defines a != b runtime test -  HPhi* vector_phi_;  // the Phi representing the normalized loop index -  VectorMode vector_mode_;  // selects synthesis mode +  HInstruction* vector_index_;  // normalized index of the new loop    friend class LoopOptimizationTest; |