2009-05-15 09:12:28 +08:00
|
|
|
//===-- DwarfException.h - Dwarf Exception Framework -----------*- C++ -*--===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file contains support for writing dwarf exception info into asm files.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2009-07-18 04:32:07 +08:00
|
|
|
#ifndef LLVM_CODEGEN_ASMPRINTER_DWARFEXCEPTION_H
|
|
|
|
#define LLVM_CODEGEN_ASMPRINTER_DWARFEXCEPTION_H
|
2009-05-15 09:12:28 +08:00
|
|
|
|
2013-12-03 23:10:23 +08:00
|
|
|
#include "AsmPrinterHandler.h"
|
2009-05-15 09:12:28 +08:00
|
|
|
#include "llvm/ADT/DenseMap.h"
|
2011-05-11 02:39:09 +08:00
|
|
|
#include "llvm/CodeGen/AsmPrinter.h"
|
2010-04-05 13:28:23 +08:00
|
|
|
#include <vector>
|
2009-05-15 09:12:28 +08:00
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
|
2010-04-05 13:28:23 +08:00
|
|
|
template <typename T> class SmallVectorImpl;
|
2009-05-15 09:12:28 +08:00
|
|
|
struct LandingPadInfo;
|
|
|
|
class MachineModuleInfo;
|
2010-04-05 13:28:23 +08:00
|
|
|
class MachineInstr;
|
|
|
|
class MachineFunction;
|
2009-08-23 04:48:53 +08:00
|
|
|
class MCAsmInfo;
|
2009-11-17 09:23:53 +08:00
|
|
|
class MCExpr;
|
2010-04-05 13:28:23 +08:00
|
|
|
class MCSymbol;
|
|
|
|
class Function;
|
2013-10-08 21:08:17 +08:00
|
|
|
class ARMTargetStreamer;
|
2010-04-05 13:28:23 +08:00
|
|
|
class AsmPrinter;
|
2009-05-15 09:12:28 +08:00
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
/// DwarfException - Emits Dwarf exception handling directives.
|
|
|
|
///
|
2013-12-03 23:10:23 +08:00
|
|
|
class DwarfException : public AsmPrinterHandler {
|
2011-01-15 05:57:45 +08:00
|
|
|
protected:
|
2010-04-05 08:26:50 +08:00
|
|
|
/// Asm - Target of Dwarf emission.
|
|
|
|
AsmPrinter *Asm;
|
2010-04-05 13:31:04 +08:00
|
|
|
|
2010-04-05 08:26:50 +08:00
|
|
|
/// MMI - Collected machine module information.
|
|
|
|
MachineModuleInfo *MMI;
|
|
|
|
|
2009-05-15 09:12:28 +08:00
|
|
|
/// SharedTypeIds - How many leading type ids two landing pads have in common.
|
|
|
|
static unsigned SharedTypeIds(const LandingPadInfo *L,
|
|
|
|
const LandingPadInfo *R);
|
|
|
|
|
|
|
|
/// PadLT - Order landing pads lexicographically by type id.
|
|
|
|
static bool PadLT(const LandingPadInfo *L, const LandingPadInfo *R);
|
|
|
|
|
|
|
|
/// PadRange - Structure holding a try-range and the associated landing pad.
|
|
|
|
struct PadRange {
|
|
|
|
// The index of the landing pad.
|
|
|
|
unsigned PadIndex;
|
|
|
|
// The index of the begin and end labels in the landing pad's label lists.
|
|
|
|
unsigned RangeIndex;
|
|
|
|
};
|
|
|
|
|
2010-03-14 09:41:15 +08:00
|
|
|
typedef DenseMap<MCSymbol *, PadRange> RangeMapType;
|
2009-05-15 09:12:28 +08:00
|
|
|
|
2009-07-29 07:22:13 +08:00
|
|
|
/// ActionEntry - Structure describing an entry in the actions table.
|
|
|
|
struct ActionEntry {
|
|
|
|
int ValueForTypeID; // The value to write - may not be equal to the type id.
|
|
|
|
int NextAction;
|
2010-02-11 05:41:57 +08:00
|
|
|
unsigned Previous;
|
2009-07-29 07:22:13 +08:00
|
|
|
};
|
|
|
|
|
2009-05-15 09:12:28 +08:00
|
|
|
/// CallSiteEntry - Structure describing an entry in the call-site table.
|
|
|
|
struct CallSiteEntry {
|
|
|
|
// The 'try-range' is BeginLabel .. EndLabel.
|
2010-03-14 09:41:15 +08:00
|
|
|
MCSymbol *BeginLabel; // zero indicates the start of the function.
|
|
|
|
MCSymbol *EndLabel; // zero indicates the end of the function.
|
2009-07-29 07:22:13 +08:00
|
|
|
|
2009-05-15 09:12:28 +08:00
|
|
|
// The landing pad starts at PadLabel.
|
2010-03-14 09:41:15 +08:00
|
|
|
MCSymbol *PadLabel; // zero indicates that there is no landing pad.
|
2009-05-15 09:12:28 +08:00
|
|
|
unsigned Action;
|
|
|
|
};
|
|
|
|
|
2009-07-29 07:23:00 +08:00
|
|
|
/// ComputeActionsTable - Compute the actions table and gather the first
|
|
|
|
/// action index for each landing pad site.
|
2009-07-29 08:31:35 +08:00
|
|
|
unsigned ComputeActionsTable(const SmallVectorImpl<const LandingPadInfo*>&LPs,
|
2009-07-29 07:22:13 +08:00
|
|
|
SmallVectorImpl<ActionEntry> &Actions,
|
|
|
|
SmallVectorImpl<unsigned> &FirstActions);
|
2009-07-29 08:31:35 +08:00
|
|
|
|
2009-11-13 05:59:20 +08:00
|
|
|
/// CallToNoUnwindFunction - Return `true' if this is a call to a function
|
|
|
|
/// marked `nounwind'. Return `false' otherwise.
|
|
|
|
bool CallToNoUnwindFunction(const MachineInstr *MI);
|
|
|
|
|
2009-07-29 08:31:35 +08:00
|
|
|
/// ComputeCallSiteTable - Compute the call-site table. The entry for an
|
|
|
|
/// invoke has a try-range containing the call, a non-zero landing pad and an
|
|
|
|
/// appropriate action. The entry for an ordinary call has a try-range
|
|
|
|
/// containing the call and zero for the landing pad and the action. Calls
|
|
|
|
/// marked 'nounwind' have no entry and must not be contained in the try-range
|
|
|
|
/// of any entry - they form gaps in the table. Entries must be ordered by
|
|
|
|
/// try-range address.
|
|
|
|
void ComputeCallSiteTable(SmallVectorImpl<CallSiteEntry> &CallSites,
|
|
|
|
const RangeMapType &PadMap,
|
|
|
|
const SmallVectorImpl<const LandingPadInfo *> &LPs,
|
|
|
|
const SmallVectorImpl<unsigned> &FirstActions);
|
2012-09-05 14:28:26 +08:00
|
|
|
|
|
|
|
/// EmitExceptionTable - Emit landing pads and actions.
|
|
|
|
///
|
|
|
|
/// The general organization of the table is complex, but the basic concepts
|
|
|
|
/// are easy. First there is a header which describes the location and
|
|
|
|
/// organization of the three components that follow.
|
|
|
|
/// 1. The landing pad site information describes the range of code covered
|
|
|
|
/// by the try. In our case it's an accumulation of the ranges covered
|
|
|
|
/// by the invokes in the try. There is also a reference to the landing
|
|
|
|
/// pad that handles the exception once processed. Finally an index into
|
|
|
|
/// the actions table.
|
|
|
|
/// 2. The action table, in our case, is composed of pairs of type ids
|
|
|
|
/// and next action offset. Starting with the action index from the
|
|
|
|
/// landing pad site, each type Id is checked for a match to the current
|
|
|
|
/// exception. If it matches then the exception and type id are passed
|
|
|
|
/// on to the landing pad. Otherwise the next action is looked up. This
|
|
|
|
/// chain is terminated with a next action of zero. If no type id is
|
|
|
|
/// found the frame is unwound and handling continues.
|
|
|
|
/// 3. Type id table contains references to all the C++ typeinfo for all
|
|
|
|
/// catches in the function. This tables is reversed indexed base 1.
|
2009-05-15 09:12:28 +08:00
|
|
|
void EmitExceptionTable();
|
|
|
|
|
2012-11-20 05:06:26 +08:00
|
|
|
virtual void EmitTypeInfos(unsigned TTypeEncoding);
|
|
|
|
|
2009-05-15 09:12:28 +08:00
|
|
|
public:
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
|
|
// Main entry points.
|
|
|
|
//
|
2010-04-04 15:48:20 +08:00
|
|
|
DwarfException(AsmPrinter *A);
|
2011-01-15 05:57:45 +08:00
|
|
|
virtual ~DwarfException();
|
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// endModule - Emit all exception information that should come after the
|
2011-01-15 05:57:45 +08:00
|
|
|
/// content.
|
2013-11-26 21:34:55 +08:00
|
|
|
virtual void endModule();
|
2011-01-15 05:57:45 +08:00
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// beginFunction - Gather pre-function exception information. Assumes being
|
2011-01-15 05:57:45 +08:00
|
|
|
/// emitted immediately after the function entry point.
|
2013-11-26 21:34:55 +08:00
|
|
|
virtual void beginFunction(const MachineFunction *MF);
|
2011-01-15 05:57:45 +08:00
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// endFunction - Gather and emit post-function exception information.
|
2013-12-03 23:10:23 +08:00
|
|
|
virtual void endFunction(const MachineFunction *);
|
|
|
|
|
|
|
|
// We don't need these.
|
|
|
|
virtual void setSymbolSize(const MCSymbol *Sym, uint64_t Size) {}
|
|
|
|
virtual void beginInstruction(const MachineInstr *MI) {}
|
|
|
|
virtual void endInstruction() {}
|
2011-01-15 05:57:45 +08:00
|
|
|
};
|
|
|
|
|
2013-09-12 02:05:11 +08:00
|
|
|
class DwarfCFIException : public DwarfException {
|
2011-04-29 22:48:51 +08:00
|
|
|
/// shouldEmitPersonality - Per-function flag to indicate if .cfi_personality
|
|
|
|
/// should be emitted.
|
|
|
|
bool shouldEmitPersonality;
|
|
|
|
|
|
|
|
/// shouldEmitLSDA - Per-function flag to indicate if .cfi_lsda
|
|
|
|
/// should be emitted.
|
|
|
|
bool shouldEmitLSDA;
|
2011-01-15 05:57:53 +08:00
|
|
|
|
|
|
|
/// shouldEmitMoves - Per-function flag to indicate if frame moves info
|
|
|
|
/// should be emitted.
|
|
|
|
bool shouldEmitMoves;
|
|
|
|
|
2011-05-11 02:39:09 +08:00
|
|
|
AsmPrinter::CFIMoveType moveTypeModule;
|
|
|
|
|
2011-01-15 05:57:53 +08:00
|
|
|
public:
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
|
|
// Main entry points.
|
|
|
|
//
|
|
|
|
DwarfCFIException(AsmPrinter *A);
|
|
|
|
virtual ~DwarfCFIException();
|
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// endModule - Emit all exception information that should come after the
|
2011-01-15 05:57:53 +08:00
|
|
|
/// content.
|
2013-11-26 21:34:55 +08:00
|
|
|
virtual void endModule();
|
2009-05-15 09:12:28 +08:00
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// beginFunction - Gather pre-function exception information. Assumes being
|
2009-05-15 09:12:28 +08:00
|
|
|
/// emitted immediately after the function entry point.
|
2013-11-26 21:34:55 +08:00
|
|
|
virtual void beginFunction(const MachineFunction *MF);
|
2009-05-15 09:12:28 +08:00
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// endFunction - Gather and emit post-function exception information.
|
2013-12-03 23:10:23 +08:00
|
|
|
virtual void endFunction(const MachineFunction *);
|
2009-05-15 09:12:28 +08:00
|
|
|
};
|
|
|
|
|
2013-09-12 02:05:11 +08:00
|
|
|
class ARMException : public DwarfException {
|
2012-11-20 05:06:26 +08:00
|
|
|
void EmitTypeInfos(unsigned TTypeEncoding);
|
2013-10-08 21:08:17 +08:00
|
|
|
ARMTargetStreamer &getTargetStreamer();
|
|
|
|
|
2014-02-15 01:19:07 +08:00
|
|
|
/// shouldEmitCFI - Per-function flag to indicate if frame CFI info
|
|
|
|
/// should be emitted.
|
|
|
|
bool shouldEmitCFI;
|
|
|
|
|
2011-03-06 02:43:15 +08:00
|
|
|
public:
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
|
|
// Main entry points.
|
|
|
|
//
|
|
|
|
ARMException(AsmPrinter *A);
|
|
|
|
virtual ~ARMException();
|
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// endModule - Emit all exception information that should come after the
|
2011-03-06 02:43:15 +08:00
|
|
|
/// content.
|
2013-11-26 21:34:55 +08:00
|
|
|
virtual void endModule();
|
2011-03-06 02:43:15 +08:00
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// beginFunction - Gather pre-function exception information. Assumes being
|
2011-03-06 02:43:15 +08:00
|
|
|
/// emitted immediately after the function entry point.
|
2013-11-26 21:34:55 +08:00
|
|
|
virtual void beginFunction(const MachineFunction *MF);
|
2011-03-06 02:43:15 +08:00
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// endFunction - Gather and emit post-function exception information.
|
2013-12-03 23:10:23 +08:00
|
|
|
virtual void endFunction(const MachineFunction *);
|
2011-03-06 02:43:15 +08:00
|
|
|
};
|
|
|
|
|
2013-09-12 02:05:11 +08:00
|
|
|
class Win64Exception : public DwarfException {
|
2011-05-28 07:47:32 +08:00
|
|
|
/// shouldEmitPersonality - Per-function flag to indicate if personality
|
|
|
|
/// info should be emitted.
|
|
|
|
bool shouldEmitPersonality;
|
|
|
|
|
|
|
|
/// shouldEmitLSDA - Per-function flag to indicate if the LSDA
|
|
|
|
/// should be emitted.
|
|
|
|
bool shouldEmitLSDA;
|
|
|
|
|
|
|
|
/// shouldEmitMoves - Per-function flag to indicate if frame moves info
|
|
|
|
/// should be emitted.
|
|
|
|
bool shouldEmitMoves;
|
|
|
|
|
|
|
|
public:
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
|
|
// Main entry points.
|
|
|
|
//
|
|
|
|
Win64Exception(AsmPrinter *A);
|
|
|
|
virtual ~Win64Exception();
|
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// endModule - Emit all exception information that should come after the
|
2011-05-28 07:47:32 +08:00
|
|
|
/// content.
|
2013-11-26 21:34:55 +08:00
|
|
|
virtual void endModule();
|
2011-05-28 07:47:32 +08:00
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// beginFunction - Gather pre-function exception information. Assumes being
|
2011-05-28 07:47:32 +08:00
|
|
|
/// emitted immediately after the function entry point.
|
2013-11-26 21:34:55 +08:00
|
|
|
virtual void beginFunction(const MachineFunction *MF);
|
2011-05-28 07:47:32 +08:00
|
|
|
|
2013-11-26 21:34:55 +08:00
|
|
|
/// endFunction - Gather and emit post-function exception information.
|
2013-12-03 23:10:23 +08:00
|
|
|
virtual void endFunction(const MachineFunction *);
|
2011-05-28 07:47:32 +08:00
|
|
|
};
|
|
|
|
|
2009-05-15 09:12:28 +08:00
|
|
|
} // End of namespace llvm
|
|
|
|
|
|
|
|
#endif
|