1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-26 04:32:44 +01:00
llvm-mirror/tools/llvm-reduce/deltas/ReduceAliases.cpp
Florian Hahn b3730ed205 [llvm-reduce] Add reduction for aliases.
This patch adds a new reduction pass that tries to remove aliases.
It runs early, as most of those likely can be removed up-front in
practice.

This substantially improves llvm-reduce for IR generated by the swift
compiler, which can generate a lot of aliases which lead to lots of
invalid reductions.

Reviewed By: lebedev.ri

Differential Revision: https://reviews.llvm.org/D90260
2020-10-28 13:11:19 +00:00

54 lines
1.8 KiB
C++

//===- ReduceAliases.cpp - Specialized Delta Pass -------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// This file implements a function which calls the Generic Delta pass in order
// to reduce aliases in the provided Module.
//
//===----------------------------------------------------------------------===//
#include "ReduceAliases.h"
#include "Delta.h"
#include "llvm/IR/Constants.h"
#include "llvm/IR/GlobalValue.h"
using namespace llvm;
/// Removes all aliases aren't inside any of the
/// desired Chunks.
static void extractAliasesFromModule(const std::vector<Chunk> &ChunksToKeep,
Module *Program) {
Oracle O(ChunksToKeep);
for (auto &GA : make_early_inc_range(Program->aliases())) {
if (!O.shouldKeep()) {
GA.replaceAllUsesWith(GA.getAliasee());
GA.eraseFromParent();
}
}
}
/// Counts the amount of aliases and prints their respective name & index.
static int countAliases(Module *Program) {
// TODO: Silence index with --quiet flag
errs() << "----------------------------\n";
errs() << "Aliases Index Reference:\n";
int Count = 0;
for (auto &GA : Program->aliases())
errs() << "\t" << ++Count << ": " << GA.getName() << "\n";
errs() << "----------------------------\n";
return Count;
}
void llvm::reduceAliasesDeltaPass(TestRunner &Test) {
errs() << "*** Reducing Aliases ...\n";
int Functions = countAliases(Test.getProgram());
runDeltaPass(Test, Functions, extractAliasesFromModule);
errs() << "----------------------------\n";
}