AsmPrinter.h revision 014700c1a8cba203fd21ff129426ba8a426ab244
1a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner//===-- llvm/CodeGen/AsmPrinter.h - AsmPrinter Framework --------*- C++ -*-===// 2ea61c358720aa6c7a159d51658b34276316aa841Misha Brukman// 3a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner// The LLVM Compiler Infrastructure 4a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner// 57ed47a13356daed2a34cd2209a31f92552e3bdd8Chris Lattner// This file is distributed under the University of Illinois Open Source 67ed47a13356daed2a34cd2209a31f92552e3bdd8Chris Lattner// License. See LICENSE.TXT for details. 7ea61c358720aa6c7a159d51658b34276316aa841Misha Brukman// 8a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner//===----------------------------------------------------------------------===// 9a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner// 10563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey// This file contains a class to be used as the base class for target specific 11563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey// asm writers. This class primarily handles common functionality used by 12563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey// all asm writers. 13a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner// 14a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner//===----------------------------------------------------------------------===// 15a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 16a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner#ifndef LLVM_CODEGEN_ASMPRINTER_H 17a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner#define LLVM_CODEGEN_ASMPRINTER_H 18a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 1998a366d547772010e94609e4584489b3e5ce0043Bill Wendling#include "llvm/ADT/DenseMap.h" 20a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner#include "llvm/CodeGen/MachineFunctionPass.h" 21190f3ba2aa58dc2e73a5f90dff15015a1ffa226bChris Lattner#include "llvm/Support/DataTypes.h" 2298a366d547772010e94609e4584489b3e5ce0043Bill Wendling#include "llvm/Target/TargetMachine.h" 2315404d060ba8b604c03b9223a0f2e2abcd0fddedRafael Espindola#include <set> 24a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 25a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattnernamespace llvm { 265eca075b74d62c621b160aa216b4cd50829a2cc7Gordon Henriksen class GCStrategy; 27a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner class Constant; 28c884db47f1a1d5449b749e6528292451e49025e4Jeff Cohen class ConstantArray; 2900d448a341175556ebd86af68219f5b90b7145a3Dan Gohman class ConstantInt; 3000d448a341175556ebd86af68219f5b90b7145a3Dan Gohman class ConstantStruct; 3100d448a341175556ebd86af68219f5b90b7145a3Dan Gohman class ConstantVector; 32c317a60c2714a5b90700a11ba646285cb754a5d3Gordon Henriksen class GCMetadataPrinter; 33ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner class GlobalVariable; 342d2cec1e9e93a388bd8448f4bad661ac89a49de3Evan Cheng class MachineConstantPoolEntry; 35d6594ae54cfde4db4d30272192645c0a45fb9902Evan Cheng class MachineConstantPoolValue; 360de1fc4f416b3e94749ca84cdaede55b040a8b60Chris Lattner class MachineModuleInfo; 37014700c1a8cba203fd21ff129426ba8a426ab244David Greene class MCInst; 38c48c550e1322aebfbe35c7570891619db43bdb9bDevang Patel class DwarfWriter; 39563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey class Mangler; 40b5a32e2e8ce2f3de3a340c5a2dfcd3a159968466Anton Korobeynikov class Section; 41563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey class TargetAsmInfo; 4284bc5427d6883f73cfeae3da640acd011d35c006Chris Lattner class Type; 43cb3718832375a581c5ea23f15918f3ea447a446cOwen Anderson class raw_ostream; 44a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 45563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey /// AsmPrinter - This class is intended to be used as a driving class for all 46563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey /// asm writers. 47a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner class AsmPrinter : public MachineFunctionPass { 481997473cf72957d0e70322e2fe6fe2ab141c58a6Devang Patel static char ID; 49794fd75c67a2cdc128d67342c6d88a504d186896Devang Patel 50347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// FunctionNumber - This provides a unique ID for each function emitted in 51347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// this translation unit. It is autoincremented by SetupMachineFunction, 52347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// and can be accessed with getFunctionNumber() and 53347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// IncrementFunctionNumber(). 54347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// 55347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng unsigned FunctionNumber; 56347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng 57c317a60c2714a5b90700a11ba646285cb754a5d3Gordon Henriksen // GCMetadataPrinters - The garbage collection metadata printer table. 585eca075b74d62c621b160aa216b4cd50829a2cc7Gordon Henriksen typedef DenseMap<GCStrategy*,GCMetadataPrinter*> gcp_map_type; 59c317a60c2714a5b90700a11ba646285cb754a5d3Gordon Henriksen typedef gcp_map_type::iterator gcp_iterator; 60c317a60c2714a5b90700a11ba646285cb754a5d3Gordon Henriksen gcp_map_type GCMetadataPrinters; 61c317a60c2714a5b90700a11ba646285cb754a5d3Gordon Henriksen 6215404d060ba8b604c03b9223a0f2e2abcd0fddedRafael Espindola protected: 630de1fc4f416b3e94749ca84cdaede55b040a8b60Chris Lattner /// MMI - If available, this is a pointer to the current MachineModuleInfo. 640de1fc4f416b3e94749ca84cdaede55b040a8b60Chris Lattner MachineModuleInfo *MMI; 650de1fc4f416b3e94749ca84cdaede55b040a8b60Chris Lattner 660de1fc4f416b3e94749ca84cdaede55b040a8b60Chris Lattner /// DW - If available, this is a pointer to the current dwarf writer. 67cb819f13d785ff6efcacfbd7d0fa9f3f67e5494dBill Wendling DwarfWriter *DW; 68014700c1a8cba203fd21ff129426ba8a426ab244David Greene 69b2efb853f00d45b1c8d57f92acd0028fbdeffda6Jim Laskey public: 70a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// Output stream on which we're printing assembly code. 71a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// 72cb3718832375a581c5ea23f15918f3ea447a446cOwen Anderson raw_ostream &O; 73a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 74a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// Target machine description. 75a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// 76a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner TargetMachine &TM; 77563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey 78563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey /// Target Asm Printer information. 79563321a2582851c653d0863e8e0bba3d483734f9Jim Laskey /// 80a0f3d17daac73c9c71aad497b298cbe82848f726Jim Laskey const TargetAsmInfo *TAI; 81a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 82da47e6e0d003c873da960361549e57ee4617c301Evan Cheng /// Target Register Information. 83da47e6e0d003c873da960361549e57ee4617c301Evan Cheng /// 84da47e6e0d003c873da960361549e57ee4617c301Evan Cheng const TargetRegisterInfo *TRI; 85da47e6e0d003c873da960361549e57ee4617c301Evan Cheng 8657f0db833dc30404f1f5d28b23df326e520698ecBill Wendling /// The current machine function. 8757f0db833dc30404f1f5d28b23df326e520698ecBill Wendling const MachineFunction *MF; 8857f0db833dc30404f1f5d28b23df326e520698ecBill Wendling 89a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// Name-mangler for global names. 90a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// 91a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner Mangler *Mang; 92a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 93a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// Cache of mangled name for current function. This is recalculated at the 94a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// beginning of each call to runOnMachineFunction(). 95a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// 96a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner std::string CurrentFnName; 9797e32e3239c0f065698f8c004b2b3009162f5ed6Chris Lattner 9889d67faf30ed1a8b5364f53c9a0f5e07a9a0719cJim Laskey /// CurrentSection - The current section we are emitting to. This is 9989d67faf30ed1a8b5364f53c9a0f5e07a9a0719cJim Laskey /// controlled and used by the SwitchSection method. 10089d67faf30ed1a8b5364f53c9a0f5e07a9a0719cJim Laskey std::string CurrentSection; 101d7ca416d6c9ae1966e0df8193112e3c5f430a053Anton Korobeynikov const Section* CurrentSection_; 102fb8075d03f5c87bd57dcc9c5f2304f6b13c55aadEvan Cheng 103fb8075d03f5c87bd57dcc9c5f2304f6b13c55aadEvan Cheng /// IsInTextSection - True if the current section we are emitting to is a 104fb8075d03f5c87bd57dcc9c5f2304f6b13c55aadEvan Cheng /// text section. 105fb8075d03f5c87bd57dcc9c5f2304f6b13c55aadEvan Cheng bool IsInTextSection; 10642bf74be1402df7409efbea089310d4c276fde37Evan Cheng 10742bf74be1402df7409efbea089310d4c276fde37Evan Cheng /// VerboseAsm - Emit comments in assembly output if this is true. 10842bf74be1402df7409efbea089310d4c276fde37Evan Cheng /// 10942bf74be1402df7409efbea089310d4c276fde37Evan Cheng bool VerboseAsm; 11042bf74be1402df7409efbea089310d4c276fde37Evan Cheng 111bd58edf59128d2acb5ae48c76ef8a108fd587db2Owen Anderson /// Private state for PrintSpecial() 112bd58edf59128d2acb5ae48c76ef8a108fd587db2Owen Anderson // Assign a unique ID to this machine instruction. 113bd58edf59128d2acb5ae48c76ef8a108fd587db2Owen Anderson mutable const MachineInstr *LastMI; 114bd58edf59128d2acb5ae48c76ef8a108fd587db2Owen Anderson mutable const Function *LastFn; 115bd58edf59128d2acb5ae48c76ef8a108fd587db2Owen Anderson mutable unsigned Counter; 116a8dbf36f3f88917b101d7ab9d253ba2fe6e396b4Owen Anderson 117a8dbf36f3f88917b101d7ab9d253ba2fe6e396b4Owen Anderson // Private state for processDebugLock() 118a8dbf36f3f88917b101d7ab9d253ba2fe6e396b4Owen Anderson mutable DebugLocTuple PrevDLT; 119bd58edf59128d2acb5ae48c76ef8a108fd587db2Owen Anderson 120b2efb853f00d45b1c8d57f92acd0028fbdeffda6Jim Laskey protected: 121be8cc2a3dedeb7685f07e68cdc4b9502eb97eb2bBill Wendling explicit AsmPrinter(raw_ostream &o, TargetMachine &TM, 1225bcc8bd0c60cfe583ee47852950aad9e532c932eDaniel Dunbar const TargetAsmInfo *T, bool V); 123ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner 124a7cea6f599418a579ab5ce66413fba7efa8bf581Jim Laskey public: 125c317a60c2714a5b90700a11ba646285cb754a5d3Gordon Henriksen virtual ~AsmPrinter(); 12642bf74be1402df7409efbea089310d4c276fde37Evan Cheng 12742bf74be1402df7409efbea089310d4c276fde37Evan Cheng /// isVerbose - Return true if assembly output should contain comments. 12842bf74be1402df7409efbea089310d4c276fde37Evan Cheng /// 12942bf74be1402df7409efbea089310d4c276fde37Evan Cheng bool isVerbose() const { return VerboseAsm; } 13042bf74be1402df7409efbea089310d4c276fde37Evan Cheng 131f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// SwitchToTextSection - Switch to the specified section of the executable 132f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// if we are not already in it! If GV is non-null and if the global has an 133e2b1f1188fd8c28977b5cf2a6842fc7bbb008713Chris Lattner /// explicitly requested section, we switch to the section indicated for the 134e2b1f1188fd8c28977b5cf2a6842fc7bbb008713Chris Lattner /// global instead of NewSection. 135e2b1f1188fd8c28977b5cf2a6842fc7bbb008713Chris Lattner /// 136e2b1f1188fd8c28977b5cf2a6842fc7bbb008713Chris Lattner /// If the new section is an empty string, this method forgets what the 137e2b1f1188fd8c28977b5cf2a6842fc7bbb008713Chris Lattner /// current section is, but does not emit a .section directive. 138e2b1f1188fd8c28977b5cf2a6842fc7bbb008713Chris Lattner /// 139f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// This method is used when about to emit executable code. 140f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// 1415bcc8bd0c60cfe583ee47852950aad9e532c932eDaniel Dunbar void SwitchToTextSection(const char *NewSection, 1425bcc8bd0c60cfe583ee47852950aad9e532c932eDaniel Dunbar const GlobalValue *GV = NULL); 143d5ab7e1c54c961b447395f17b569acdf18776c5aChris Lattner 144f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// SwitchToDataSection - Switch to the specified section of the executable 145f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// if we are not already in it! If GV is non-null and if the global has an 146f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// explicitly requested section, we switch to the section indicated for the 147f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// global instead of NewSection. 148f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// 149f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// If the new section is an empty string, this method forgets what the 150f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// current section is, but does not emit a .section directive. 151f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// 152f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// This method is used when about to emit data. For most assemblers, this 153f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// is the same as the SwitchToTextSection method, but not all assemblers 154f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// are the same. 155f668ffc4c2cf3da8ef0948b316d971c4b41b0e05Chris Lattner /// 1565bcc8bd0c60cfe583ee47852950aad9e532c932eDaniel Dunbar void SwitchToDataSection(const char *NewSection, 1575bcc8bd0c60cfe583ee47852950aad9e532c932eDaniel Dunbar const GlobalValue *GV = NULL); 158b5a32e2e8ce2f3de3a340c5a2dfcd3a159968466Anton Korobeynikov 159b5a32e2e8ce2f3de3a340c5a2dfcd3a159968466Anton Korobeynikov /// SwitchToSection - Switch to the specified section of the executable if 160b5a32e2e8ce2f3de3a340c5a2dfcd3a159968466Anton Korobeynikov /// we are not already in it! 161b5a32e2e8ce2f3de3a340c5a2dfcd3a159968466Anton Korobeynikov void SwitchToSection(const Section* NS); 162b5a32e2e8ce2f3de3a340c5a2dfcd3a159968466Anton Korobeynikov 163a1a19f803c8fef05db627a8b73c909a50306e9d6Jim Laskey /// getGlobalLinkName - Returns the asm/link name of of the specified 164a1a19f803c8fef05db627a8b73c909a50306e9d6Jim Laskey /// global variable. Should be overridden by each target asm printer to 165a1a19f803c8fef05db627a8b73c909a50306e9d6Jim Laskey /// generate the appropriate value. 1667d16e85bfc2c6423c81ce87a177bf3b1b1012a04Bill Wendling virtual const std::string &getGlobalLinkName(const GlobalVariable *GV, 1677d16e85bfc2c6423c81ce87a177bf3b1b1012a04Bill Wendling std::string &LinkName) const; 168a1a19f803c8fef05db627a8b73c909a50306e9d6Jim Laskey 169bda9b0ec7bd6974cebf751ecd23c5434b34054e9Jim Laskey /// EmitExternalGlobal - Emit the external reference to a global variable. 170bda9b0ec7bd6974cebf751ecd23c5434b34054e9Jim Laskey /// Should be overridden if an indirect reference should be used. 171bda9b0ec7bd6974cebf751ecd23c5434b34054e9Jim Laskey virtual void EmitExternalGlobal(const GlobalVariable *GV); 172bda9b0ec7bd6974cebf751ecd23c5434b34054e9Jim Laskey 1736e19896999f9297db38e1a1a66d9bef0e2f09776Bill Wendling /// getCurrentFunctionEHName - Called to return (and cache) the 1746e19896999f9297db38e1a1a66d9bef0e2f09776Bill Wendling /// CurrentFnEHName. 1756e19896999f9297db38e1a1a66d9bef0e2f09776Bill Wendling /// 1767d16e85bfc2c6423c81ce87a177bf3b1b1012a04Bill Wendling const std::string &getCurrentFunctionEHName(const MachineFunction *MF, 1777d16e85bfc2c6423c81ce87a177bf3b1b1012a04Bill Wendling std::string &FuncEHName) const; 1786e19896999f9297db38e1a1a66d9bef0e2f09776Bill Wendling 179a7cea6f599418a579ab5ce66413fba7efa8bf581Jim Laskey protected: 180ce2247755e56f99a2377b64a1a9d393726582b85Gordon Henriksen /// getAnalysisUsage - Record analysis usage. 181ce2247755e56f99a2377b64a1a9d393726582b85Gordon Henriksen /// 182ce2247755e56f99a2377b64a1a9d393726582b85Gordon Henriksen void getAnalysisUsage(AnalysisUsage &AU) const; 183ce2247755e56f99a2377b64a1a9d393726582b85Gordon Henriksen 184a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// doInitialization - Set up the AsmPrinter when we are working on a new 185a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// module. If your pass overrides this, it must make sure to explicitly 186a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// call this implementation. 187a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner bool doInitialization(Module &M); 188a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 189a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// doFinalization - Shut down the asmprinter. If you override this in your 190a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// pass, you must make sure to call it explicitly. 191a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner bool doFinalization(Module &M); 1923ce9b67e0c0f171c6d09c19407930ce6989f1b9dChris Lattner 1933ce9b67e0c0f171c6d09c19407930ce6989f1b9dChris Lattner /// PrintSpecial - Print information related to the specified machine instr 1943ce9b67e0c0f171c6d09c19407930ce6989f1b9dChris Lattner /// that is independent of the operand, and may be independent of the instr 1953ce9b67e0c0f171c6d09c19407930ce6989f1b9dChris Lattner /// itself. This can be useful for portably encoding the comment character 1963ce9b67e0c0f171c6d09c19407930ce6989f1b9dChris Lattner /// or other bits of target-specific knowledge into the asmstrings. The 1973ce9b67e0c0f171c6d09c19407930ce6989f1b9dChris Lattner /// syntax used is ${:comment}. Targets can override this to add support 1983ce9b67e0c0f171c6d09c19407930ce6989f1b9dChris Lattner /// for their own strange codes. 1993e0cc2634e861b789850b5103efcc8898bf14c4cChris Lattner virtual void PrintSpecial(const MachineInstr *MI, const char *Code) const; 20047cf4eda9faa3c0b063337d0eb4ea83aba8cb329Chris Lattner 20147cf4eda9faa3c0b063337d0eb4ea83aba8cb329Chris Lattner /// PrintAsmOperand - Print the specified operand of MI, an INLINEASM 20247cf4eda9faa3c0b063337d0eb4ea83aba8cb329Chris Lattner /// instruction, using the specified assembler variant. Targets should 203b44b5094110508e2381615b15077b388364f7e8aChris Lattner /// override this to format as appropriate. This method can return true if 20447cf4eda9faa3c0b063337d0eb4ea83aba8cb329Chris Lattner /// the operand is erroneous. 20547cf4eda9faa3c0b063337d0eb4ea83aba8cb329Chris Lattner virtual bool PrintAsmOperand(const MachineInstr *MI, unsigned OpNo, 206f483e58212d018f8b2ec760f59089e72defab5cfChris Lattner unsigned AsmVariant, const char *ExtraCode); 207b2efb853f00d45b1c8d57f92acd0028fbdeffda6Jim Laskey 208b44b5094110508e2381615b15077b388364f7e8aChris Lattner /// PrintAsmMemoryOperand - Print the specified operand of MI, an INLINEASM 209b44b5094110508e2381615b15077b388364f7e8aChris Lattner /// instruction, using the specified assembler variant as an address. 210b44b5094110508e2381615b15077b388364f7e8aChris Lattner /// Targets should override this to format as appropriate. This method can 211b44b5094110508e2381615b15077b388364f7e8aChris Lattner /// return true if the operand is erroneous. 212b44b5094110508e2381615b15077b388364f7e8aChris Lattner virtual bool PrintAsmMemoryOperand(const MachineInstr *MI, unsigned OpNo, 213b44b5094110508e2381615b15077b388364f7e8aChris Lattner unsigned AsmVariant, 214b44b5094110508e2381615b15077b388364f7e8aChris Lattner const char *ExtraCode); 215b44b5094110508e2381615b15077b388364f7e8aChris Lattner 2166fe3acce749ee2b3714009064626f6c53b06dfb4Chris Lattner /// SetupMachineFunction - This should be called when a new MachineFunction 217a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// is being processed from runOnMachineFunction. 2186fe3acce749ee2b3714009064626f6c53b06dfb4Chris Lattner void SetupMachineFunction(MachineFunction &MF); 21997e32e3239c0f065698f8c004b2b3009162f5ed6Chris Lattner 220347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// getFunctionNumber - Return a unique ID for the current function. 221347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// 222347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng unsigned getFunctionNumber() const { return FunctionNumber; } 223347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng 224347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// IncrementFunctionNumber - Increase Function Number. AsmPrinters should 225347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// not normally call this, as the counter is automatically bumped by 226347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng /// SetupMachineFunction. 227347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng void IncrementFunctionNumber() { FunctionNumber++; } 228347d39f1fd8ad825a7ec5b8a3dce816723a56d42Evan Cheng 229ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner /// EmitConstantPool - Print to the current output stream assembly 230ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner /// representations of the constants in the constant pool MCP. This is 231ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner /// used to print out constants which have been "spilled to memory" by 232ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner /// the code generator. 233ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner /// 2342d2cec1e9e93a388bd8448f4bad661ac89a49de3Evan Cheng void EmitConstantPool(MachineConstantPool *MCP); 235a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 23637efe6764568a3829fee26aba532283131d1a104Nate Begeman /// EmitJumpTableInfo - Print assembly representations of the jump tables 23737efe6764568a3829fee26aba532283131d1a104Nate Begeman /// used by the current function to the current output stream. 23837efe6764568a3829fee26aba532283131d1a104Nate Begeman /// 2391da31ee472b9615d7329c656e2cc17c419ed7c95Chris Lattner void EmitJumpTableInfo(MachineJumpTableInfo *MJTI, MachineFunction &MF); 24037efe6764568a3829fee26aba532283131d1a104Nate Begeman 241ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner /// EmitSpecialLLVMGlobal - Check to see if the specified global is a 242ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner /// special global used by LLVM. If so, emit it and return true, otherwise 243ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner /// do nothing and return false. 244ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner bool EmitSpecialLLVMGlobal(const GlobalVariable *GV); 245a1a19f803c8fef05db627a8b73c909a50306e9d6Jim Laskey 246f9e56198a39a08272c072211722b3c97ef88853cJim Laskey public: 247f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey //===------------------------------------------------------------------===// 248f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// LEB 128 number encoding. 249f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 250f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// PrintULEB128 - Print a series of hexidecimal values(separated by commas) 251f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// representing an unsigned leb128 value. 252f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void PrintULEB128(unsigned Value) const; 253f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 254f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// PrintSLEB128 - Print a series of hexidecimal values(separated by commas) 255f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// representing a signed leb128 value. 256f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void PrintSLEB128(int Value) const; 257f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 258f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey //===------------------------------------------------------------------===// 259f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey // Emission and print routines 260f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey // 261f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 262f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// PrintHex - Print a value as a hexidecimal value. 263f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// 264f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void PrintHex(int Value) const; 265f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 266f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// EOL - Print a newline character to asm stream. If a comment is present 267f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// then it will be printed first. Comments should not contain '\n'. 268bda9b0ec7bd6974cebf751ecd23c5434b34054e9Jim Laskey void EOL() const; 269f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void EOL(const std::string &Comment) const; 27025995093e785f4794b3590f3df70fbfe834a00a1Owen Anderson void EOL(const char* Comment) const; 271f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 272f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// EmitULEB128Bytes - Emit an assembler byte data directive to compose an 273f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// unsigned leb128 value. 274f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void EmitULEB128Bytes(unsigned Value) const; 275f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 276f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// EmitSLEB128Bytes - print an assembler byte data directive to compose a 277f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// signed leb128 value. 278f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void EmitSLEB128Bytes(int Value) const; 279f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 280f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// EmitInt8 - Emit a byte directive and value. 281f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// 282f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void EmitInt8(int Value) const; 283f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 284f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// EmitInt16 - Emit a short directive and value. 285f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// 286f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void EmitInt16(int Value) const; 287f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 288f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// EmitInt32 - Emit a long directive and value. 289f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// 290f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void EmitInt32(int Value) const; 291f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 292f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// EmitInt64 - Emit a long long directive and value. 293f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// 294f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void EmitInt64(uint64_t Value) const; 295f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 296f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// EmitString - Emit a string with quotes and a null terminator. 297f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey /// Special characters are emitted properly. 298181b6c9cb5def44658d15848e34c5c45d973f065Reid Spencer /// @verbatim (Eg. '\t') @endverbatim 299f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey void EmitString(const std::string &String) const; 300f34be827ac3bb257939e31575fcfc9ef27b94306Bill Wendling void EmitString(const char *String, unsigned Size) const; 301f34be827ac3bb257939e31575fcfc9ef27b94306Bill Wendling 302189f80dc253664627253b2d2cb07d0714feb12baDan Gohman /// EmitFile - Emit a .file directive. 303189f80dc253664627253b2d2cb07d0714feb12baDan Gohman void EmitFile(unsigned Number, const std::string &Name) const; 304189f80dc253664627253b2d2cb07d0714feb12baDan Gohman 305f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey //===------------------------------------------------------------------===// 306f1cdea1d021068f5c9e118d68321ce28fcea63faJim Laskey 3076fe3acce749ee2b3714009064626f6c53b06dfb4Chris Lattner /// EmitAlignment - Emit an alignment directive to the specified power of 308bfddc2030a7e67b9e0c42276525d6932375ff261Chris Lattner /// two boundary. For example, if you pass in 3 here, you will get an 8 309a1ab72daadbdc5b499ce7e7e97c4b80efad46736Chris Lattner /// byte alignment. If a global value is specified, and if that global has 3103a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// an explicit alignment requested, it will unconditionally override the 3113a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// alignment request. However, if ForcedAlignBits is specified, this value 3123a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// has final say: the ultimate alignment will be the max of ForcedAlignBits 31305548eb174dd694b651de334b73197a62e5071f1Evan Cheng /// and the alignment computed with NumBits and the global. If UseFillExpr 31405548eb174dd694b651de334b73197a62e5071f1Evan Cheng /// is true, it also emits an optional second value FillValue which the 31505548eb174dd694b651de334b73197a62e5071f1Evan Cheng /// assembler uses to fill gaps to match alignment for text sections if the 31605548eb174dd694b651de334b73197a62e5071f1Evan Cheng /// has specified a non-zero fill value. 3173a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// 3183a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// The algorithm is: 3193a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// Align = NumBits; 3203a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// if (GV && GV->hasalignment) Align = GV->getalignment(); 3213a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// Align = std::max(Align, ForcedAlignBits); 3223a4205367dc845d4cd804b47e061f8281777c9daChris Lattner /// 3233a4205367dc845d4cd804b47e061f8281777c9daChris Lattner void EmitAlignment(unsigned NumBits, const GlobalValue *GV = 0, 32405548eb174dd694b651de334b73197a62e5071f1Evan Cheng unsigned ForcedAlignBits = 0, 32505548eb174dd694b651de334b73197a62e5071f1Evan Cheng bool UseFillExpr = true) const; 326bfddc2030a7e67b9e0c42276525d6932375ff261Chris Lattner 3271b08bbca5592351a940bcd164bdec724ee954326Evan Cheng /// printLabel - This method prints a local label used by debug and 3281b08bbca5592351a940bcd164bdec724ee954326Evan Cheng /// exception handling tables. 3291b08bbca5592351a940bcd164bdec724ee954326Evan Cheng void printLabel(const MachineInstr *MI) const; 3301b08bbca5592351a940bcd164bdec724ee954326Evan Cheng void printLabel(unsigned Id) const; 3311b08bbca5592351a940bcd164bdec724ee954326Evan Cheng 332a844bdeab31ef04221e7ef59a8467893584cc14dEvan Cheng /// printDeclare - This method prints a local variable declaration used by 333a844bdeab31ef04221e7ef59a8467893584cc14dEvan Cheng /// debug tables. 334a844bdeab31ef04221e7ef59a8467893584cc14dEvan Cheng void printDeclare(const MachineInstr *MI) const; 335a844bdeab31ef04221e7ef59a8467893584cc14dEvan Cheng 336014700c1a8cba203fd21ff129426ba8a426ab244David Greene /// postInstructionAction - Handling printing of items after the 337014700c1a8cba203fd21ff129426ba8a426ab244David Greene /// instruction iteself has been printed (e.g. comments) 338014700c1a8cba203fd21ff129426ba8a426ab244David Greene void postInstructionAction(const MachineInstr &MI) const { 339014700c1a8cba203fd21ff129426ba8a426ab244David Greene postInstructionActionImpl(MI); 340014700c1a8cba203fd21ff129426ba8a426ab244David Greene EmitComments(MI); 341014700c1a8cba203fd21ff129426ba8a426ab244David Greene } 342014700c1a8cba203fd21ff129426ba8a426ab244David Greene void postInstructionAction(const MCInst &MI) const { 343014700c1a8cba203fd21ff129426ba8a426ab244David Greene postInstructionActionImpl(MI); 344014700c1a8cba203fd21ff129426ba8a426ab244David Greene EmitComments(MI); 345014700c1a8cba203fd21ff129426ba8a426ab244David Greene } 346014700c1a8cba203fd21ff129426ba8a426ab244David Greene 347f9e56198a39a08272c072211722b3c97ef88853cJim Laskey protected: 3486fe3acce749ee2b3714009064626f6c53b06dfb4Chris Lattner /// EmitZeros - Emit a block of zeros. 34930bad4af40d0126f888f601fb46d01e2b39dbc43Chris Lattner /// 350c8d7bc850ddf5a5df503a173b0bc0f8c03ffec96Sanjiv Gupta void EmitZeros(uint64_t NumZeros, unsigned AddrSpace = 0) const; 351c884db47f1a1d5449b749e6528292451e49025e4Jeff Cohen 352c884db47f1a1d5449b749e6528292451e49025e4Jeff Cohen /// EmitString - Emit a zero-byte-terminated string constant. 353c884db47f1a1d5449b749e6528292451e49025e4Jeff Cohen /// 354c884db47f1a1d5449b749e6528292451e49025e4Jeff Cohen virtual void EmitString(const ConstantArray *CVA) const; 35530bad4af40d0126f888f601fb46d01e2b39dbc43Chris Lattner 3566fe3acce749ee2b3714009064626f6c53b06dfb4Chris Lattner /// EmitConstantValueOnly - Print out the specified constant, without a 357a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner /// storage class. Only constants of first-class type are allowed here. 358a10f15949d6ca25eb67514cce69d42626efa6380Sanjiv Gupta void EmitConstantValueOnly(const Constant *CV); 35946d6126e669ab83383d47fb465d2a7d0c60169e5Chris Lattner 3606fe3acce749ee2b3714009064626f6c53b06dfb4Chris Lattner /// EmitGlobalConstant - Print a general LLVM constant to the .s file. 361c8d7bc850ddf5a5df503a173b0bc0f8c03ffec96Sanjiv Gupta void EmitGlobalConstant(const Constant* CV, unsigned AddrSpace = 0); 362d6594ae54cfde4db4d30272192645c0a45fb9902Evan Cheng 363d6594ae54cfde4db4d30272192645c0a45fb9902Evan Cheng virtual void EmitMachineConstantPoolValue(MachineConstantPoolValue *MCPV); 364cd76240f3d0f6c5f8c80e4762a8fe3a4de22e059Argyrios Kyrtzidis 365cd76240f3d0f6c5f8c80e4762a8fe3a4de22e059Argyrios Kyrtzidis /// processDebugLoc - Processes the debug information of each machine 366cd76240f3d0f6c5f8c80e4762a8fe3a4de22e059Argyrios Kyrtzidis /// instruction's DebugLoc. 367cd76240f3d0f6c5f8c80e4762a8fe3a4de22e059Argyrios Kyrtzidis void processDebugLoc(DebugLoc DL); 368ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner 369e736ed19478f05811f08a56706e07fa4ab865401Chris Lattner /// printInlineAsm - This method formats and prints the specified machine 370e736ed19478f05811f08a56706e07fa4ab865401Chris Lattner /// instruction that is an inline asm. 371e736ed19478f05811f08a56706e07fa4ab865401Chris Lattner void printInlineAsm(const MachineInstr *MI) const; 372da47e6e0d003c873da960361549e57ee4617c301Evan Cheng 373da47e6e0d003c873da960361549e57ee4617c301Evan Cheng /// printImplicitDef - This method prints the specified machine instruction 374da47e6e0d003c873da960361549e57ee4617c301Evan Cheng /// that is an implicit def. 375da47e6e0d003c873da960361549e57ee4617c301Evan Cheng virtual void printImplicitDef(const MachineInstr *MI) const; 37637efe6764568a3829fee26aba532283131d1a104Nate Begeman 37737efe6764568a3829fee26aba532283131d1a104Nate Begeman /// printBasicBlockLabel - This method prints the label for the specified 37837efe6764568a3829fee26aba532283131d1a104Nate Begeman /// MachineBasicBlock 379cdf38c4edb892c356cfaa3c09c57728bc8d6bfd0Nate Begeman virtual void printBasicBlockLabel(const MachineBasicBlock *MBB, 380fb8075d03f5c87bd57dcc9c5f2304f6b13c55aadEvan Cheng bool printAlign = false, 381cdf38c4edb892c356cfaa3c09c57728bc8d6bfd0Nate Begeman bool printColon = false, 382cdf38c4edb892c356cfaa3c09c57728bc8d6bfd0Nate Begeman bool printComment = true) const; 38352a51e38dc312aa262b0d771419afe1785f3cb22Nate Begeman 384cc41586b9d79532172b37e1f44a9077da4b73fc9Evan Cheng /// printPICJumpTableSetLabel - This method prints a set label for the 385cc41586b9d79532172b37e1f44a9077da4b73fc9Evan Cheng /// specified MachineBasicBlock for a jumptable entry. 386cc41586b9d79532172b37e1f44a9077da4b73fc9Evan Cheng virtual void printPICJumpTableSetLabel(unsigned uid, 387cc41586b9d79532172b37e1f44a9077da4b73fc9Evan Cheng const MachineBasicBlock *MBB) const; 388cc41586b9d79532172b37e1f44a9077da4b73fc9Evan Cheng virtual void printPICJumpTableSetLabel(unsigned uid, unsigned uid2, 389cc41586b9d79532172b37e1f44a9077da4b73fc9Evan Cheng const MachineBasicBlock *MBB) const; 3909de1934099f4eedaeb2f3a023411b2cd3e0e1eaeAnton Korobeynikov virtual void printPICJumpTableEntry(const MachineJumpTableInfo *MJTI, 3919de1934099f4eedaeb2f3a023411b2cd3e0e1eaeAnton Korobeynikov const MachineBasicBlock *MBB, 3929de1934099f4eedaeb2f3a023411b2cd3e0e1eaeAnton Korobeynikov unsigned uid) const; 3939de1934099f4eedaeb2f3a023411b2cd3e0e1eaeAnton Korobeynikov 394d6594ae54cfde4db4d30272192645c0a45fb9902Evan Cheng /// printDataDirective - This method prints the asm directive for the 395d6594ae54cfde4db4d30272192645c0a45fb9902Evan Cheng /// specified type. 396c8d7bc850ddf5a5df503a173b0bc0f8c03ffec96Sanjiv Gupta void printDataDirective(const Type *type, unsigned AddrSpace = 0); 397d6594ae54cfde4db4d30272192645c0a45fb9902Evan Cheng 398c215b3ef5d9627f5fb6fe9034e46bc29ae592916Dale Johannesen /// printSuffixedName - This prints a name with preceding 399c215b3ef5d9627f5fb6fe9034e46bc29ae592916Dale Johannesen /// getPrivateGlobalPrefix and the specified suffix, handling quoted names 400c215b3ef5d9627f5fb6fe9034e46bc29ae592916Dale Johannesen /// correctly. 401ab8faba2fb17e540751adf75161a25b18c94b818Evan Cheng void printSuffixedName(const char *Name, const char *Suffix, 402ab8faba2fb17e540751adf75161a25b18c94b818Evan Cheng const char *Prefix = 0); 403ab8faba2fb17e540751adf75161a25b18c94b818Evan Cheng void printSuffixedName(const std::string &Name, const char* Suffix); 404c215b3ef5d9627f5fb6fe9034e46bc29ae592916Dale Johannesen 405f5b6a47bb57fb5ffc734416d4d5d993e1a06273bAnton Korobeynikov /// printVisibility - This prints visibility information about symbol, if 406f5b6a47bb57fb5ffc734416d4d5d993e1a06273bAnton Korobeynikov /// this is suported by the target. 407f5b6a47bb57fb5ffc734416d4d5d993e1a06273bAnton Korobeynikov void printVisibility(const std::string& Name, unsigned Visibility) const; 408f5b6a47bb57fb5ffc734416d4d5d993e1a06273bAnton Korobeynikov 4097751ad92daeea5a3502fbc266ae814baec5c03e6Anton Korobeynikov /// printOffset - This is just convenient handler for printing offsets. 4107751ad92daeea5a3502fbc266ae814baec5c03e6Anton Korobeynikov void printOffset(int64_t Offset) const; 411014700c1a8cba203fd21ff129426ba8a426ab244David Greene 412ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner private: 41361e6093dc8d92def3dfe0b379df83f70b0558247Dale Johannesen const GlobalValue *findGlobalValue(const Constant* CV); 414cb05af852f1d346ac07b84c74a930a5cdbd6d427Chris Lattner void EmitLLVMUsedList(Constant *List); 415ed13893ff729bc3b91697f6d80a3ba303782efccChris Lattner void EmitXXStructorList(Constant *List); 416c8d7bc850ddf5a5df503a173b0bc0f8c03ffec96Sanjiv Gupta void EmitGlobalConstantStruct(const ConstantStruct* CVS, 417c8d7bc850ddf5a5df503a173b0bc0f8c03ffec96Sanjiv Gupta unsigned AddrSpace); 418d3d965714b89c5d5aeb65fb5ce06e081f0b3c049Sanjiv Gupta void EmitGlobalConstantArray(const ConstantArray* CVA, unsigned AddrSpace); 41900d448a341175556ebd86af68219f5b90b7145a3Dan Gohman void EmitGlobalConstantVector(const ConstantVector* CP); 420c8d7bc850ddf5a5df503a173b0bc0f8c03ffec96Sanjiv Gupta void EmitGlobalConstantFP(const ConstantFP* CFP, unsigned AddrSpace); 421c8d7bc850ddf5a5df503a173b0bc0f8c03ffec96Sanjiv Gupta void EmitGlobalConstantLargeInt(const ConstantInt* CI, unsigned AddrSpace); 4225eca075b74d62c621b160aa216b4cd50829a2cc7Gordon Henriksen GCMetadataPrinter *GetOrCreateGCPrinter(GCStrategy *C); 423014700c1a8cba203fd21ff129426ba8a426ab244David Greene 424014700c1a8cba203fd21ff129426ba8a426ab244David Greene /// EmitComments - Pretty-print comments for instructions 425014700c1a8cba203fd21ff129426ba8a426ab244David Greene void EmitComments(const MachineInstr &MI) const; 426014700c1a8cba203fd21ff129426ba8a426ab244David Greene /// EmitComments - Pretty-print comments for instructions 427014700c1a8cba203fd21ff129426ba8a426ab244David Greene void EmitComments(const MCInst &MI) const; 428014700c1a8cba203fd21ff129426ba8a426ab244David Greene 429014700c1a8cba203fd21ff129426ba8a426ab244David Greene virtual void postInstructionActionImpl(const MachineInstr &MI) const {} 430014700c1a8cba203fd21ff129426ba8a426ab244David Greene virtual void postInstructionActionImpl(const MCInst &MI) const {} 431a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner }; 432a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner} 433a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner 434a80ba71efe5be5012128e2db0dd29b024e00105aChris Lattner#endif 435