summaryrefslogtreecommitdiff
path: root/compiler/optimizing/loop_optimization.cc
diff options
context:
space:
mode:
authorShalini Salomi Bodapati <shalini.salomi.bodapati@intel.com>2019-07-10 16:09:41 +0530
committerVladimir Marko <vmarko@google.com>2019-07-17 11:12:22 +0000
commitb45a435e25d69592f27084a615b351760f040875 (patch)
tree6920830856dbe3cceb648b365b0d057ea3ea93ec /compiler/optimizing/loop_optimization.cc
parent5132e0d1433b0962f9609dbbd68427e1fb5a4b9d (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.cc27
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));