All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.bugvm.llvm.PassManager Maven / Gradle / Ivy

/*
 * Copyright (C) 2013 RoboVM AB
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
package com.bugvm.llvm;

import com.bugvm.llvm.binding.LLVM;
import com.bugvm.llvm.binding.PassManagerRef;

/**
 * 
 */
public class PassManager implements AutoCloseable {
    protected PassManagerRef ref;

    public PassManager() {
        ref = LLVM.CreatePassManager();
        if (ref == null) {
            throw new LlvmException("Failed to create PassManager");
        }
    }

    protected final void checkDisposed() {
        if (ref == null) {
            throw new LlvmException("Already disposed");
        }
    }

    public synchronized void dispose() {
        checkDisposed();
        LLVM.DisposePassManager(ref);
        ref = null;
    }

    @Override
    public void close() {
        dispose();
    }

    public void addAggressiveDCEPass() {
        checkDisposed();
        LLVM.AddAggressiveDCEPass(ref);
    }
    public void addAlwaysInlinerPass() {
        checkDisposed();
        LLVM.AddAlwaysInlinerPass(ref);
    }
    public void addArgumentPromotionPass() {
        checkDisposed();
        LLVM.AddArgumentPromotionPass(ref);
    }
    public void addBasicAliasAnalysisPass() {
        checkDisposed();
        LLVM.AddBasicAliasAnalysisPass(ref);
    }
    public void addBBVectorizePass() {
        checkDisposed();
        LLVM.AddBBVectorizePass(ref);
    }
    public void addCFGSimplificationPass() {
        checkDisposed();
        LLVM.AddCFGSimplificationPass(ref);
    }
    public void addConstantMergePass() {
        checkDisposed();
        LLVM.AddConstantMergePass(ref);
    }
    public void addConstantPropagationPass() {
        checkDisposed();
        LLVM.AddConstantPropagationPass(ref);
    }
    public void addCorrelatedValuePropagationPass() {
        checkDisposed();
        LLVM.AddCorrelatedValuePropagationPass(ref);
    }
    public void addDeadArgEliminationPass() {
        checkDisposed();
        LLVM.AddDeadArgEliminationPass(ref);
    }
    public void addDeadStoreEliminationPass() {
        checkDisposed();
        LLVM.AddDeadStoreEliminationPass(ref);
    }
    public void addDemoteMemoryToRegisterPass() {
        checkDisposed();
        LLVM.AddDemoteMemoryToRegisterPass(ref);
    }
    public void addEarlyCSEPass() {
        checkDisposed();
        LLVM.AddEarlyCSEPass(ref);
    }
    public void addFunctionAttrsPass() {
        checkDisposed();
        LLVM.AddFunctionAttrsPass(ref);
    }
    public void addFunctionInliningPass() {
        checkDisposed();
        LLVM.AddFunctionInliningPass(ref);
    }
    public void addGlobalDCEPass() {
        checkDisposed();
        LLVM.AddGlobalDCEPass(ref);
    }
    public void addGlobalOptimizerPass() {
        checkDisposed();
        LLVM.AddGlobalOptimizerPass(ref);
    }
    public void addGVNPass() {
        checkDisposed();
        LLVM.AddGVNPass(ref);
    }
    public void addIndVarSimplifyPass() {
        checkDisposed();
        LLVM.AddIndVarSimplifyPass(ref);
    }
    public void addInstructionCombiningPass() {
        checkDisposed();
        LLVM.AddInstructionCombiningPass(ref);
    }
    public void addInternalizePass(boolean allButMain) {
        checkDisposed();
        LLVM.AddInternalizePass(ref, allButMain ? 1 : 0);
    }
    public void addIPConstantPropagationPass() {
        checkDisposed();
        LLVM.AddIPConstantPropagationPass(ref);
    }
    public void addIPSCCPPass() {
        checkDisposed();
        LLVM.AddIPSCCPPass(ref);
    }
    public void addJumpThreadingPass() {
        checkDisposed();
        LLVM.AddJumpThreadingPass(ref);
    }
    public void addLICMPass() {
        checkDisposed();
        LLVM.AddLICMPass(ref);
    }
    public void addLoopDeletionPass() {
        checkDisposed();
        LLVM.AddLoopDeletionPass(ref);
    }
    public void addLoopIdiomPass() {
        checkDisposed();
        LLVM.AddLoopIdiomPass(ref);
    }
    public void addLoopRotatePass() {
        checkDisposed();
        LLVM.AddLoopRotatePass(ref);
    }
    public void addLoopUnrollPass() {
        checkDisposed();
        LLVM.AddLoopUnrollPass(ref);
    }
    public void addLoopUnswitchPass() {
        checkDisposed();
        LLVM.AddLoopUnswitchPass(ref);
    }
    public void addLoopVectorizePass() {
        checkDisposed();
        LLVM.AddLoopVectorizePass(ref);
    }
    public void addLowerExpectIntrinsicPass() {
        checkDisposed();
        LLVM.AddLowerExpectIntrinsicPass(ref);
    }
    public void addMemCpyOptPass() {
        checkDisposed();
        LLVM.AddMemCpyOptPass(ref);
    }
    public void addPromoteMemoryToRegisterPass() {
        checkDisposed();
        LLVM.AddPromoteMemoryToRegisterPass(ref);
    }
    public void addPruneEHPass() {
        checkDisposed();
        LLVM.AddPruneEHPass(ref);
    }
    public void addReassociatePass() {
        checkDisposed();
        LLVM.AddReassociatePass(ref);
    }
    public void addScalarReplAggregatesPass() {
        checkDisposed();
        LLVM.AddScalarReplAggregatesPass(ref);
    }
    public void addScalarReplAggregatesPassSSA() {
        checkDisposed();
        LLVM.AddScalarReplAggregatesPassSSA(ref);
    }
    public void addScalarReplAggregatesPassWithThreshold(int threshold) {
        checkDisposed();
        LLVM.AddScalarReplAggregatesPassWithThreshold(ref, threshold);
    }
    public void addSCCPPass() {
        checkDisposed();
        LLVM.AddSCCPPass(ref);
    }
    public void addSimplifyLibCallsPass() {
        checkDisposed();
        LLVM.AddSimplifyLibCallsPass(ref);
    }
    public void addSLPVectorizePass() {
        checkDisposed();
        LLVM.AddSLPVectorizePass(ref);
    }
    public void addStripDeadPrototypesPass() {
        checkDisposed();
        LLVM.AddStripDeadPrototypesPass(ref);
    }
    public void addStripSymbolsPass() {
        checkDisposed();
        LLVM.AddStripSymbolsPass(ref);
    }
    public void addTailCallEliminationPass() {
        checkDisposed();
        LLVM.AddTailCallEliminationPass(ref);
    }
    public void addTypeBasedAliasAnalysisPass() {
        checkDisposed();
        LLVM.AddTypeBasedAliasAnalysisPass(ref);
    }
    public void addVerifierPass() {
        checkDisposed();
        LLVM.AddVerifierPass(ref);
    }
    
    public void run(Module module) {
        checkDisposed();
        LLVM.RunPassManager(ref, module.getRef());
    }

    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((ref == null) ? 0 : ref.hashCode());
        return result;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) {
            return true;
        }
        if (obj == null) {
            return false;
        }
        if (getClass() != obj.getClass()) {
            return false;
        }
        PassManager other = (PassManager) obj;
        if (ref == null) {
            if (other.ref != null) {
                return false;
            }
        } else if (!ref.equals(other.ref)) {
            return false;
        }
        return true;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy