1*0b57cec5SDimitry Andric //===-- Vectorize.cpp -----------------------------------------------------===// 2*0b57cec5SDimitry Andric // 3*0b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4*0b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 5*0b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6*0b57cec5SDimitry Andric // 7*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===// 8*0b57cec5SDimitry Andric // 9*0b57cec5SDimitry Andric // This file implements common infrastructure for libLLVMVectorizeOpts.a, which 10*0b57cec5SDimitry Andric // implements several vectorization transformations over the LLVM intermediate 11*0b57cec5SDimitry Andric // representation, including the C bindings for that library. 12*0b57cec5SDimitry Andric // 13*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===// 14*0b57cec5SDimitry Andric 15*0b57cec5SDimitry Andric #include "llvm/Transforms/Vectorize.h" 16*0b57cec5SDimitry Andric #include "llvm-c/Initialization.h" 17*0b57cec5SDimitry Andric #include "llvm-c/Transforms/Vectorize.h" 18*0b57cec5SDimitry Andric #include "llvm/Analysis/Passes.h" 19*0b57cec5SDimitry Andric #include "llvm/IR/LegacyPassManager.h" 20*0b57cec5SDimitry Andric #include "llvm/InitializePasses.h" 21*0b57cec5SDimitry Andric 22*0b57cec5SDimitry Andric using namespace llvm; 23*0b57cec5SDimitry Andric 24*0b57cec5SDimitry Andric /// Initialize all passes linked into the Vectorization library. initializeVectorization(PassRegistry & Registry)25*0b57cec5SDimitry Andricvoid llvm::initializeVectorization(PassRegistry &Registry) { 26*0b57cec5SDimitry Andric initializeLoopVectorizePass(Registry); 27*0b57cec5SDimitry Andric initializeSLPVectorizerPass(Registry); 28*0b57cec5SDimitry Andric initializeLoadStoreVectorizerLegacyPassPass(Registry); 29*0b57cec5SDimitry Andric initializeVectorCombineLegacyPassPass(Registry); 30*0b57cec5SDimitry Andric } 31*0b57cec5SDimitry Andric LLVMInitializeVectorization(LLVMPassRegistryRef R)32*0b57cec5SDimitry Andricvoid LLVMInitializeVectorization(LLVMPassRegistryRef R) { 33*0b57cec5SDimitry Andric initializeVectorization(*unwrap(R)); 34*0b57cec5SDimitry Andric } 35*0b57cec5SDimitry Andric LLVMAddLoopVectorizePass(LLVMPassManagerRef PM)36*0b57cec5SDimitry Andricvoid LLVMAddLoopVectorizePass(LLVMPassManagerRef PM) { 37*0b57cec5SDimitry Andric unwrap(PM)->add(createLoopVectorizePass()); 38*0b57cec5SDimitry Andric } 39*0b57cec5SDimitry Andric LLVMAddSLPVectorizePass(LLVMPassManagerRef PM)40*0b57cec5SDimitry Andricvoid LLVMAddSLPVectorizePass(LLVMPassManagerRef PM) { 41*0b57cec5SDimitry Andric unwrap(PM)->add(createSLPVectorizerPass()); 42*0b57cec5SDimitry Andric } 43