Index: llvm/lib/Transforms/Vectorize/LoadStoreVectorizer.cpp =================================================================== --- llvm/lib/Transforms/Vectorize/LoadStoreVectorizer.cpp +++ llvm/lib/Transforms/Vectorize/LoadStoreVectorizer.cpp @@ -187,7 +187,7 @@ /// Check if this load/store access is misaligned accesses. bool accessIsMisaligned(unsigned SzInBytes, unsigned AddressSpace, - Align Alignment); + Align Alignment, unsigned &Fast); }; class LoadStoreVectorizerLegacyPass : public FunctionPass { @@ -1078,8 +1078,14 @@ InstructionsProcessed->insert(Chain.begin(), Chain.end()); // If the store is going to be misaligned, don't vectorize it. - if (accessIsMisaligned(SzInBytes, AS, Alignment)) { + unsigned Fast; + if (accessIsMisaligned(SzInBytes, AS, Alignment, Fast)) { if (S0->getPointerAddressSpace() != DL.getAllocaAddrSpace()) { + unsigned FastBefore; + accessIsMisaligned(EltSzInBytes, AS, Alignment, FastBefore); + if (FastBefore > Fast) + return false; + auto Chains = splitOddVectorElts(Chain, Sz); bool Vectorized = false; Vectorized |= vectorizeStoreChain(Chains.first, InstructionsProcessed); @@ -1231,8 +1237,14 @@ InstructionsProcessed->insert(Chain.begin(), Chain.end()); // If the load is going to be misaligned, don't vectorize it. - if (accessIsMisaligned(SzInBytes, AS, Alignment)) { + unsigned Fast; + if (accessIsMisaligned(SzInBytes, AS, Alignment, Fast)) { if (L0->getPointerAddressSpace() != DL.getAllocaAddrSpace()) { + unsigned FastBefore; + accessIsMisaligned(EltSzInBytes, AS, Alignment, FastBefore); + if (FastBefore > Fast) + return false; + auto Chains = splitOddVectorElts(Chain, Sz); bool Vectorized = false; Vectorized |= vectorizeLoadChain(Chains.first, InstructionsProcessed); @@ -1316,7 +1328,8 @@ } bool Vectorizer::accessIsMisaligned(unsigned SzInBytes, unsigned AddressSpace, - Align Alignment) { + Align Alignment, unsigned &Fast) { + Fast = 0; if (Alignment.value() % SzInBytes == 0) return false;