diff options
author | Shalini Salomi Bodapati <shalini.salomi.bodapati@intel.com> | 2019-07-10 16:09:41 +0530 |
---|---|---|
committer | Vladimir Marko <vmarko@google.com> | 2019-07-17 11:12:22 +0000 |
commit | b45a435e25d69592f27084a615b351760f040875 (patch) | |
tree | 6920830856dbe3cceb648b365b0d057ea3ea93ec /compiler/optimizing/loop_optimization.cc | |
parent | 5132e0d1433b0962f9609dbbd68427e1fb5a4b9d (diff) |
Add AVX support for packed mul/div instructions.
This is a follow up for the below patch:
https://android-review.googlesource.com/c/platform/build/+/830841
Test: ./test.py --host --64, test-art-host-gtest
Change-Id: Id2aa473035556ee230e66addeb69707df8530e75
Signed-off-by: Shalini Salomi Bodapati <shalini.salomi.bodapati@intel.com>
Diffstat (limited to 'compiler/optimizing/loop_optimization.cc')
-rw-r--r-- | compiler/optimizing/loop_optimization.cc | 27 |
1 files changed, 0 insertions, 27 deletions
diff --git a/compiler/optimizing/loop_optimization.cc b/compiler/optimizing/loop_optimization.cc index c6e7560aed..99141279bc 100644 --- a/compiler/optimizing/loop_optimization.cc +++ b/compiler/optimizing/loop_optimization.cc @@ -353,9 +353,6 @@ static bool HasReductionFormat(HInstruction* reduction, HInstruction* phi) { static HVecReduce::ReductionKind GetReductionKind(HVecOperation* reduction) { if (reduction->IsVecAdd() || reduction->IsVecSub() || - #if defined(ART_ENABLE_CODEGEN_x86) || defined(ART_ENABLE_CODEGEN_x86_64) - reduction->IsVecAvxSub() || reduction->IsVecAvxAdd() || - #endif reduction->IsVecSADAccumulate() || reduction->IsVecDotProd()) { return HVecReduce::kSum; @@ -1943,34 +1940,10 @@ void HLoopOptimization::GenerateVecOp(HInstruction* org, new (global_allocator_) HVecCnv(global_allocator_, opa, type, vector_length_, dex_pc), new (global_allocator_) HTypeConversion(org_type, opa, dex_pc)); case HInstruction::kAdd: - #if defined(ART_ENABLE_CODEGEN_x86) || defined(ART_ENABLE_CODEGEN_x86_64) - if ((compiler_options_->GetInstructionSet() == InstructionSet::kX86 || - compiler_options_->GetInstructionSet() == InstructionSet::kX86_64) && - compiler_options_->GetInstructionSetFeatures()->AsX86InstructionSetFeatures() - ->HasAVX2()) { - GENERATE_VEC( - new (global_allocator_) HVecAvxAdd( - global_allocator_, opa, opb, type, vector_length_, dex_pc), - new (global_allocator_) HAdd(org_type, opa, opb, dex_pc)); - UNREACHABLE(); // GENERATE_VEC ends with a "break". - } - #endif GENERATE_VEC( new (global_allocator_) HVecAdd(global_allocator_, opa, opb, type, vector_length_, dex_pc), new (global_allocator_) HAdd(org_type, opa, opb, dex_pc)); case HInstruction::kSub: - #if defined(ART_ENABLE_CODEGEN_x86) || defined(ART_ENABLE_CODEGEN_x86_64) - if ((compiler_options_->GetInstructionSet() == InstructionSet::kX86 || - compiler_options_->GetInstructionSet() == InstructionSet::kX86_64) && - compiler_options_->GetInstructionSetFeatures()->AsX86InstructionSetFeatures() - ->HasAVX2()) { - GENERATE_VEC( - new (global_allocator_) HVecAvxSub( - global_allocator_, opa, opb, type, vector_length_, dex_pc), - new (global_allocator_) HSub(org_type, opa, opb, dex_pc)); - UNREACHABLE(); // GENERATE_VEC ends with a "break". - } - #endif GENERATE_VEC( new (global_allocator_) HVecSub(global_allocator_, opa, opb, type, vector_length_, dex_pc), new (global_allocator_) HSub(org_type, opa, opb, dex_pc)); |