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 Andric void 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 Andric void LLVMInitializeVectorization(LLVMPassRegistryRef R) {
33*0b57cec5SDimitry Andric   initializeVectorization(*unwrap(R));
34*0b57cec5SDimitry Andric }
35*0b57cec5SDimitry Andric 
LLVMAddLoopVectorizePass(LLVMPassManagerRef PM)36*0b57cec5SDimitry Andric void LLVMAddLoopVectorizePass(LLVMPassManagerRef PM) {
37*0b57cec5SDimitry Andric   unwrap(PM)->add(createLoopVectorizePass());
38*0b57cec5SDimitry Andric }
39*0b57cec5SDimitry Andric 
LLVMAddSLPVectorizePass(LLVMPassManagerRef PM)40*0b57cec5SDimitry Andric void LLVMAddSLPVectorizePass(LLVMPassManagerRef PM) {
41*0b57cec5SDimitry Andric   unwrap(PM)->add(createSLPVectorizerPass());
42*0b57cec5SDimitry Andric }
43