| //===-- WinException.h - Windows Exception Handling ----------*- 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 contains support for writing windows exception info into asm files. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef LLVM_LIB_CODEGEN_ASMPRINTER_WIN64EXCEPTION_H |
| #define LLVM_LIB_CODEGEN_ASMPRINTER_WIN64EXCEPTION_H |
| |
| #include "EHStreamer.h" |
| |
| namespace llvm { |
| class Function; |
| class GlobalValue; |
| class MachineFunction; |
| class MCExpr; |
| class MCSection; |
| class Value; |
| struct WinEHFuncInfo; |
| |
| class LLVM_LIBRARY_VISIBILITY WinException : public EHStreamer { |
| /// Per-function flag to indicate if personality info should be emitted. |
| bool shouldEmitPersonality = false; |
| |
| /// Per-function flag to indicate if the LSDA should be emitted. |
| bool shouldEmitLSDA = false; |
| |
| /// Per-function flag to indicate if frame moves info should be emitted. |
| bool shouldEmitMoves = false; |
| |
| /// True if this is a 64-bit target and we should use image relative offsets. |
| bool useImageRel32 = false; |
| |
| /// True if we are generating exception handling on Windows for ARM64. |
| bool isAArch64 = false; |
| |
| /// Pointer to the current funclet entry BB. |
| const MachineBasicBlock *CurrentFuncletEntry = nullptr; |
| |
| /// The section of the last funclet start. |
| MCSection *CurrentFuncletTextSection = nullptr; |
| |
| void emitCSpecificHandlerTable(const MachineFunction *MF); |
| |
| void emitSEHActionsForRange(const WinEHFuncInfo &FuncInfo, |
| const MCSymbol *BeginLabel, |
| const MCSymbol *EndLabel, int State); |
| |
| /// Emit the EH table data for 32-bit and 64-bit functions using |
| /// the __CxxFrameHandler3 personality. |
| void emitCXXFrameHandler3Table(const MachineFunction *MF); |
| |
| /// Emit the EH table data for _except_handler3 and _except_handler4 |
| /// personality functions. These are only used on 32-bit and do not use CFI |
| /// tables. |
| void emitExceptHandlerTable(const MachineFunction *MF); |
| |
| void emitCLRExceptionTable(const MachineFunction *MF); |
| |
| void computeIP2StateTable( |
| const MachineFunction *MF, const WinEHFuncInfo &FuncInfo, |
| SmallVectorImpl<std::pair<const MCExpr *, int>> &IPToStateTable); |
| |
| /// Emits the label used with llvm.eh.recoverfp, which is used by |
| /// outlined funclets. |
| void emitEHRegistrationOffsetLabel(const WinEHFuncInfo &FuncInfo, |
| StringRef FLinkageName); |
| |
| const MCExpr *create32bitRef(const MCSymbol *Value); |
| const MCExpr *create32bitRef(const GlobalValue *GV); |
| const MCExpr *getLabel(const MCSymbol *Label); |
| const MCExpr *getOffset(const MCSymbol *OffsetOf, const MCSymbol *OffsetFrom); |
| const MCExpr *getOffsetPlusOne(const MCSymbol *OffsetOf, |
| const MCSymbol *OffsetFrom); |
| |
| /// Gets the offset that we should use in a table for a stack object with the |
| /// given index. For targets using CFI (Win64, etc), this is relative to the |
| /// established SP at the end of the prologue. For targets without CFI (Win32 |
| /// only), it is relative to the frame pointer. |
| int getFrameIndexOffset(int FrameIndex, const WinEHFuncInfo &FuncInfo); |
| |
| void endFuncletImpl(); |
| public: |
| //===--------------------------------------------------------------------===// |
| // Main entry points. |
| // |
| WinException(AsmPrinter *A); |
| ~WinException() override; |
| |
| /// Emit all exception information that should come after the content. |
| void endModule() override; |
| |
| /// Gather pre-function exception information. Assumes being emitted |
| /// immediately after the function entry point. |
| void beginFunction(const MachineFunction *MF) override; |
| |
| void markFunctionEnd() override; |
| |
| /// Gather and emit post-function exception information. |
| void endFunction(const MachineFunction *) override; |
| |
| /// Emit target-specific EH funclet machinery. |
| void beginFunclet(const MachineBasicBlock &MBB, MCSymbol *Sym) override; |
| void endFunclet() override; |
| }; |
| } |
| |
| #endif |
| |