One Hat Cyber Team
Your IP :
216.73.216.115
Server IP :
194.44.31.54
Server :
Linux zen.imath.kiev.ua 4.18.0-553.77.1.el8_10.x86_64 #1 SMP Fri Oct 3 14:30:23 UTC 2025 x86_64
Server Software :
Apache/2.4.37 (Rocky Linux) OpenSSL/1.1.1k
PHP Version :
5.6.40
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
usr
/
include
/
llvm
/
CodeGen
/
View File Name :
MIRPrinter.h
//===- MIRPrinter.h - MIR serialization format printer ----------*- C++ -*-===// // // 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 declares the functions that print out the LLVM IR and the machine // functions using the MIR serialization format. // //===----------------------------------------------------------------------===// #ifndef LLVM_CODEGEN_MIRPRINTER_H #define LLVM_CODEGEN_MIRPRINTER_H #include "llvm/CodeGen/MachinePassManager.h" #include "llvm/Support/raw_ostream.h" namespace llvm { class MachineBasicBlock; class MachineFunction; class Module; template <typename T> class SmallVectorImpl; class PrintMIRPreparePass : public PassInfoMixin<PrintMIRPreparePass> { raw_ostream &OS; public: PrintMIRPreparePass(raw_ostream &OS = errs()) : OS(OS) {} PreservedAnalyses run(Module &M, ModuleAnalysisManager &MFAM); }; class PrintMIRPass : public PassInfoMixin<PrintMIRPass> { raw_ostream &OS; public: PrintMIRPass(raw_ostream &OS = errs()) : OS(OS) {} PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM); }; /// Print LLVM IR using the MIR serialization format to the given output stream. void printMIR(raw_ostream &OS, const Module &M); /// Print a machine function using the MIR serialization format to the given /// output stream. void printMIR(raw_ostream &OS, const MachineFunction &MF); /// Determine a possible list of successors of a basic block based on the /// basic block machine operand being used inside the block. This should give /// you the correct list of successor blocks in most cases except for things /// like jump tables where the basic block references can't easily be found. /// The MIRPRinter will skip printing successors if they match the result of /// this function and the parser will use this function to construct a list if /// it is missing. void guessSuccessors(const MachineBasicBlock &MBB, SmallVectorImpl<MachineBasicBlock*> &Result, bool &IsFallthrough); } // end namespace llvm #endif