subsequent changes are easier to review. About to fix some layering issues, and wanted to separate out the necessary churn. Also comment and sink the include of "Windows.h" in three .inc files to match the usage in Memory.inc. llvm-svn: 198685
44 lines
1.4 KiB
C++
44 lines
1.4 KiB
C++
//===-- ARMMachORelocationInfo.cpp ----------------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "MCTargetDesc/ARMMCTargetDesc.h"
|
|
#include "ARMMCExpr.h"
|
|
#include "llvm-c/Disassembler.h"
|
|
#include "llvm/MC/MCContext.h"
|
|
#include "llvm/MC/MCExpr.h"
|
|
#include "llvm/MC/MCRelocationInfo.h"
|
|
|
|
using namespace llvm;
|
|
using namespace object;
|
|
|
|
namespace {
|
|
class ARMMachORelocationInfo : public MCRelocationInfo {
|
|
public:
|
|
ARMMachORelocationInfo(MCContext &Ctx) : MCRelocationInfo(Ctx) {}
|
|
|
|
const MCExpr *createExprForCAPIVariantKind(const MCExpr *SubExpr,
|
|
unsigned VariantKind) {
|
|
switch(VariantKind) {
|
|
case LLVMDisassembler_VariantKind_ARM_HI16:
|
|
return ARMMCExpr::CreateUpper16(SubExpr, Ctx);
|
|
case LLVMDisassembler_VariantKind_ARM_LO16:
|
|
return ARMMCExpr::CreateLower16(SubExpr, Ctx);
|
|
default:
|
|
return MCRelocationInfo::createExprForCAPIVariantKind(SubExpr,
|
|
VariantKind);
|
|
}
|
|
}
|
|
};
|
|
} // End unnamed namespace
|
|
|
|
/// createARMMachORelocationInfo - Construct an ARM Mach-O RelocationInfo.
|
|
MCRelocationInfo *llvm::createARMMachORelocationInfo(MCContext &Ctx) {
|
|
return new ARMMachORelocationInfo(Ctx);
|
|
}
|