mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-04 10:30:01 +00:00
uselistorder: Pull the assembly bit up out of the printer
Pull the `-preserve-ll-uselistorder` bit up through all the callers of `Module::print()`. I converted callers of `operator<<` to `Module::print()` where necessary to pull the bit through. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@234968 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c9d5dea0fe
commit
8b376eb892
@ -642,8 +642,11 @@ public:
|
||||
/// @{
|
||||
|
||||
/// Print the module to an output stream with an optional
|
||||
/// AssemblyAnnotationWriter.
|
||||
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW) const;
|
||||
/// AssemblyAnnotationWriter. If \c ShouldPreserveUseListOrder, then include
|
||||
/// uselistorder directives so that use-lists can be recreated when reading
|
||||
/// the assembly.
|
||||
void print(raw_ostream &OS, AssemblyAnnotationWriter *AAW,
|
||||
bool ShouldPreserveUseListOrder = false) const;
|
||||
|
||||
/// Dump the module to stderr (for debugging).
|
||||
void dump() const;
|
||||
|
@ -3071,11 +3071,11 @@ void Function::print(raw_ostream &ROS, AssemblyAnnotationWriter *AAW) const {
|
||||
W.printFunction(this);
|
||||
}
|
||||
|
||||
void Module::print(raw_ostream &ROS, AssemblyAnnotationWriter *AAW) const {
|
||||
void Module::print(raw_ostream &ROS, AssemblyAnnotationWriter *AAW,
|
||||
bool ShouldPreserveUseListOrder) const {
|
||||
SlotTracker SlotTable(this);
|
||||
formatted_raw_ostream OS(ROS);
|
||||
AssemblyWriter W(OS, SlotTable, this, AAW,
|
||||
shouldPreserveAssemblyUseListOrder());
|
||||
AssemblyWriter W(OS, SlotTable, this, AAW, ShouldPreserveUseListOrder);
|
||||
W.printModule(this);
|
||||
}
|
||||
|
||||
|
@ -15,6 +15,7 @@
|
||||
#include "llvm/IR/Function.h"
|
||||
#include "llvm/IR/Module.h"
|
||||
#include "llvm/IR/PassManager.h"
|
||||
#include "llvm/IR/UseListOrder.h"
|
||||
#include "llvm/Pass.h"
|
||||
#include "llvm/Support/Debug.h"
|
||||
#include "llvm/Support/raw_ostream.h"
|
||||
@ -25,7 +26,8 @@ PrintModulePass::PrintModulePass(raw_ostream &OS, const std::string &Banner)
|
||||
: OS(OS), Banner(Banner) {}
|
||||
|
||||
PreservedAnalyses PrintModulePass::run(Module &M) {
|
||||
OS << Banner << M;
|
||||
OS << Banner;
|
||||
M.print(OS, nullptr, shouldPreserveAssemblyUseListOrder());
|
||||
return PreservedAnalyses::all();
|
||||
}
|
||||
|
||||
|
@ -25,6 +25,7 @@
|
||||
#include "llvm/IR/IntrinsicInst.h"
|
||||
#include "llvm/IR/Module.h"
|
||||
#include "llvm/IR/Type.h"
|
||||
#include "llvm/IR/UseListOrder.h"
|
||||
#include "llvm/Support/CommandLine.h"
|
||||
#include "llvm/Support/DataStream.h"
|
||||
#include "llvm/Support/FileSystem.h"
|
||||
@ -189,7 +190,7 @@ int main(int argc, char **argv) {
|
||||
|
||||
// All that llvm-dis does is write the assembly to a file.
|
||||
if (!DontPrint)
|
||||
M->print(Out->os(), Annotator.get());
|
||||
M->print(Out->os(), Annotator.get(), shouldPreserveAssemblyUseListOrder());
|
||||
|
||||
// Declare success.
|
||||
Out->keep();
|
||||
|
@ -150,7 +150,7 @@ int main(int argc, char **argv) {
|
||||
|
||||
if (Verbose) errs() << "Writing bitcode...\n";
|
||||
if (OutputAssembly) {
|
||||
Out.os() << *Composite;
|
||||
Composite->print(Out.os(), nullptr, shouldPreserveAssemblyUseListOrder());
|
||||
} else if (Force || !CheckBitcodeOutputToConsole(Out.os(), true))
|
||||
WriteBitcodeToFile(Composite.get(), Out.os(),
|
||||
shouldPreserveBitcodeUseListOrder());
|
||||
|
@ -144,7 +144,7 @@ bool TempFile::writeAssembly(const Module &M) const {
|
||||
return true;
|
||||
}
|
||||
|
||||
OS << M;
|
||||
M.print(OS, nullptr, /* ShouldPreserveUseListOrder */ true);
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -540,14 +540,8 @@ int main(int argc, char **argv) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
outs() << "*** verify-uselistorder ***\n";
|
||||
// Can't verify if order isn't preserved.
|
||||
if (!shouldPreserveAssemblyUseListOrder()) {
|
||||
errs() << "warning: forcing -preserve-ll-uselistorder\n";
|
||||
setPreserveAssemblyUseListOrder(true);
|
||||
}
|
||||
|
||||
// Verify the use lists now and after reversing them.
|
||||
outs() << "*** verify-uselistorder ***\n";
|
||||
verifyUseListOrder(*M);
|
||||
outs() << "reverse\n";
|
||||
reverseUseLists(*M);
|
||||
|
Loading…
x
Reference in New Issue
Block a user