[ARM] Rejig MVE load store tests. NFC
[llvm-core.git] / lib / Transforms / Utils / StripNonLineTableDebugInfo.cpp
blob97a4533fabe5a69a74db4a6e1e767de9eac038f5
1 //===- StripNonLineTableDebugInfo.cpp -- Strip parts of Debug Info --------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 #include "llvm/IR/DebugInfo.h"
10 #include "llvm/Pass.h"
11 #include "llvm/Transforms/Utils.h"
12 using namespace llvm;
14 namespace {
16 /// This pass strips all debug info that is not related line tables.
17 /// The result will be the same as if the program where compiled with
18 /// -gline-tables-only.
19 struct StripNonLineTableDebugInfo : public ModulePass {
20 static char ID; // Pass identification, replacement for typeid
21 StripNonLineTableDebugInfo() : ModulePass(ID) {
22 initializeStripNonLineTableDebugInfoPass(*PassRegistry::getPassRegistry());
25 void getAnalysisUsage(AnalysisUsage &AU) const override {
26 AU.setPreservesAll();
29 bool runOnModule(Module &M) override {
30 return llvm::stripNonLineTableDebugInfo(M);
35 char StripNonLineTableDebugInfo::ID = 0;
36 INITIALIZE_PASS(StripNonLineTableDebugInfo, "strip-nonlinetable-debuginfo",
37 "Strip all debug info except linetables", false, false)
39 ModulePass *llvm::createStripNonLineTableDebugInfoPass() {
40 return new StripNonLineTableDebugInfo();