From 4797f783a338bfeb39413350bcc71587d905ac6f Mon Sep 17 00:00:00 2001 From: Matt Arsenault Date: Fri, 1 Jul 2016 03:33:52 +0000 Subject: [PATCH] AMDGPU: Add option to run the load/store vectorizer git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@274329 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/AMDGPU/AMDGPUTargetMachine.cpp | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp b/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp index 74014e505f8..925f879403f 100644 --- a/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp +++ b/lib/Target/AMDGPU/AMDGPUTargetMachine.cpp @@ -39,6 +39,7 @@ #include "llvm/Transforms/IPO.h" #include "llvm/Transforms/Scalar.h" #include "llvm/Transforms/Scalar/GVN.h" +#include "llvm/Transforms/Vectorize.h" using namespace llvm; @@ -59,6 +60,13 @@ static cl::opt EnableR600IfConvert( cl::ReallyHidden, cl::init(true)); +// Option to disable vectorizer for tests. +static cl::opt EnableLoadStoreVectorizer( + "amdgpu-load-store-vectorizer", + cl::desc("Enable load store vectorizer"), + cl::init(false), + cl::Hidden); + extern "C" void LLVMInitializeAMDGPUTarget() { // Register the target RegisterTargetMachine X(TheAMDGPUTarget); @@ -267,6 +275,7 @@ public: void addEarlyCSEOrGVNPass(); void addStraightLineScalarOptimizationPasses(); void addIRPasses() override; + void addCodeGenPrepare() override; bool addPreISel() override; bool addInstSelector() override; bool addGCPasses() override; @@ -392,6 +401,13 @@ void AMDGPUPassConfig::addIRPasses() { addEarlyCSEOrGVNPass(); } +void AMDGPUPassConfig::addCodeGenPrepare() { + TargetPassConfig::addCodeGenPrepare(); + + if (EnableLoadStoreVectorizer) + addPass(createLoadStoreVectorizerPass()); +} + bool AMDGPUPassConfig::addPreISel() { addPass(createFlattenCFGPass()); return false; -- 2.50.0