2011-05-15 14:42:22 +00:00
|
|
|
//===-- llvm/Support/Win64EH.h ---Win64 EH Constants-------------*- 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 constants and structures used for implementing
|
|
|
|
// exception handling on Win64 platforms. For more information, see
|
|
|
|
// http://msdn.microsoft.com/en-us/library/1eyas8tf.aspx
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_SUPPORT_WIN64EH_H
|
|
|
|
#define LLVM_SUPPORT_WIN64EH_H
|
|
|
|
|
2011-05-22 00:05:26 +00:00
|
|
|
#include "llvm/Support/DataTypes.h"
|
2012-12-05 20:12:13 +00:00
|
|
|
#include "llvm/Support/Endian.h"
|
2011-05-22 00:05:26 +00:00
|
|
|
|
2011-05-15 14:42:22 +00:00
|
|
|
namespace llvm {
|
|
|
|
namespace Win64EH {
|
|
|
|
|
|
|
|
/// UnwindOpcodes - Enumeration whose values specify a single operation in
|
|
|
|
/// the prolog of a function.
|
|
|
|
enum UnwindOpcodes {
|
|
|
|
UOP_PushNonVol = 0,
|
|
|
|
UOP_AllocLarge,
|
|
|
|
UOP_AllocSmall,
|
|
|
|
UOP_SetFPReg,
|
|
|
|
UOP_SaveNonVol,
|
|
|
|
UOP_SaveNonVolBig,
|
2011-05-26 05:24:15 +00:00
|
|
|
UOP_SaveXMM128 = 8,
|
2011-05-15 14:42:22 +00:00
|
|
|
UOP_SaveXMM128Big,
|
|
|
|
UOP_PushMachFrame
|
|
|
|
};
|
|
|
|
|
|
|
|
/// UnwindCode - This union describes a single operation in a function prolog,
|
|
|
|
/// or part thereof.
|
|
|
|
union UnwindCode {
|
|
|
|
struct {
|
2012-12-05 20:12:13 +00:00
|
|
|
support::ulittle8_t CodeOffset;
|
|
|
|
support::ulittle8_t UnwindOpAndOpInfo;
|
2011-05-19 02:47:23 +00:00
|
|
|
} u;
|
2012-12-05 20:12:13 +00:00
|
|
|
support::ulittle16_t FrameOffset;
|
|
|
|
|
|
|
|
uint8_t getUnwindOp() const {
|
|
|
|
return u.UnwindOpAndOpInfo & 0x0F;
|
|
|
|
}
|
|
|
|
uint8_t getOpInfo() const {
|
|
|
|
return (u.UnwindOpAndOpInfo >> 4) & 0x0F;
|
|
|
|
}
|
2011-05-15 14:42:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
/// UNW_ExceptionHandler - Specifies that this function has an exception
|
|
|
|
/// handler.
|
|
|
|
UNW_ExceptionHandler = 0x01,
|
|
|
|
/// UNW_TerminateHandler - Specifies that this function has a termination
|
|
|
|
/// handler.
|
|
|
|
UNW_TerminateHandler = 0x02,
|
|
|
|
/// UNW_ChainInfo - Specifies that this UnwindInfo structure is chained to
|
|
|
|
/// another one.
|
|
|
|
UNW_ChainInfo = 0x04
|
|
|
|
};
|
|
|
|
|
2011-05-19 02:47:23 +00:00
|
|
|
/// RuntimeFunction - An entry in the table of functions with unwind info.
|
|
|
|
struct RuntimeFunction {
|
2012-12-05 20:12:13 +00:00
|
|
|
support::ulittle32_t StartAddress;
|
|
|
|
support::ulittle32_t EndAddress;
|
|
|
|
support::ulittle32_t UnwindInfoOffset;
|
2011-05-19 02:47:23 +00:00
|
|
|
};
|
|
|
|
|
2011-05-15 14:42:22 +00:00
|
|
|
/// UnwindInfo - An entry in the exception table.
|
|
|
|
struct UnwindInfo {
|
2012-12-05 20:12:13 +00:00
|
|
|
support::ulittle8_t VersionAndFlags;
|
|
|
|
support::ulittle8_t PrologSize;
|
|
|
|
support::ulittle8_t NumCodes;
|
|
|
|
support::ulittle8_t FrameRegisterAndOffset;
|
|
|
|
UnwindCode UnwindCodes[1];
|
2011-05-19 02:47:23 +00:00
|
|
|
|
2012-12-05 20:12:13 +00:00
|
|
|
uint8_t getVersion() const {
|
|
|
|
return VersionAndFlags & 0x07;
|
2011-05-19 02:47:23 +00:00
|
|
|
}
|
2012-12-05 20:12:13 +00:00
|
|
|
uint8_t getFlags() const {
|
|
|
|
return (VersionAndFlags >> 3) & 0x1f;
|
2011-05-19 02:47:23 +00:00
|
|
|
}
|
2012-12-05 20:12:13 +00:00
|
|
|
uint8_t getFrameRegister() const {
|
|
|
|
return FrameRegisterAndOffset & 0x0f;
|
2011-05-19 02:47:23 +00:00
|
|
|
}
|
2012-12-05 20:12:13 +00:00
|
|
|
uint8_t getFrameOffset() const {
|
|
|
|
return (FrameRegisterAndOffset >> 4) & 0x0f;
|
|
|
|
}
|
|
|
|
|
|
|
|
// The data after unwindCodes depends on flags.
|
|
|
|
// If UNW_ExceptionHandler or UNW_TerminateHandler is set then follows
|
|
|
|
// the address of the language-specific exception handler.
|
|
|
|
// If UNW_ChainInfo is set then follows a RuntimeFunction which defines
|
|
|
|
// the chained unwind info.
|
|
|
|
// For more information please see MSDN at:
|
|
|
|
// http://msdn.microsoft.com/en-us/library/ddssxxy8.aspx
|
|
|
|
|
|
|
|
/// \brief Return pointer to language specific data part of UnwindInfo.
|
|
|
|
void *getLanguageSpecificData() {
|
|
|
|
return reinterpret_cast<void *>(&UnwindCodes[(NumCodes+1) & ~1]);
|
2011-05-19 02:47:23 +00:00
|
|
|
}
|
2012-12-05 20:12:13 +00:00
|
|
|
|
|
|
|
/// \brief Return image-relativ offset of language-specific exception handler.
|
|
|
|
uint32_t getLanguageSpecificHandlerOffset() {
|
|
|
|
return *reinterpret_cast<uint32_t *>(getLanguageSpecificData());
|
|
|
|
}
|
|
|
|
|
|
|
|
/// \brief Set image-relativ offset of language-specific exception handler.
|
|
|
|
void setLanguageSpecificHandlerOffset(uint32_t offset) {
|
|
|
|
*reinterpret_cast<uint32_t *>(getLanguageSpecificData()) = offset;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// \brief Return pointer to exception-specific data.
|
2011-05-19 02:47:23 +00:00
|
|
|
void *getExceptionData() {
|
2012-12-05 20:12:13 +00:00
|
|
|
return reinterpret_cast<void *>(reinterpret_cast<uint32_t *>(
|
2011-05-19 02:47:23 +00:00
|
|
|
getLanguageSpecificData())+1);
|
|
|
|
}
|
2012-12-05 20:12:13 +00:00
|
|
|
|
|
|
|
/// \brief Return pointer to chained unwind info.
|
|
|
|
RuntimeFunction *getChainedFunctionEntry() {
|
|
|
|
return reinterpret_cast<RuntimeFunction *>(getLanguageSpecificData());
|
|
|
|
}
|
2011-05-15 14:42:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // End of namespace Win64EH
|
|
|
|
} // End of namespace llvm
|
|
|
|
|
|
|
|
#endif
|