2018-11-15 20:35:04 +08:00
|
|
|
//===-- MSP430FixupKinds.h - MSP430 Specific Fixup Entries ------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// 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
|
2018-11-15 20:35:04 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_LIB_TARGET_MSP430_MCTARGETDESC_MSP430FIXUPKINDS_H
|
|
|
|
#define LLVM_LIB_TARGET_MSP430_MCTARGETDESC_MSP430FIXUPKINDS_H
|
|
|
|
|
|
|
|
#include "llvm/MC/MCFixup.h"
|
|
|
|
|
|
|
|
#undef MSP430
|
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
namespace MSP430 {
|
|
|
|
|
|
|
|
// This table must be in the same order of
|
|
|
|
// MCFixupKindInfo Infos[MSP430::NumTargetFixupKinds]
|
|
|
|
// in MSP430AsmBackend.cpp.
|
|
|
|
//
|
|
|
|
enum Fixups {
|
|
|
|
// A 32 bit absolute fixup.
|
|
|
|
fixup_32 = FirstTargetFixupKind,
|
|
|
|
// A 10 bit PC relative fixup.
|
|
|
|
fixup_10_pcrel,
|
|
|
|
// A 16 bit absolute fixup.
|
|
|
|
fixup_16,
|
|
|
|
// A 16 bit PC relative fixup.
|
|
|
|
fixup_16_pcrel,
|
|
|
|
// A 16 bit absolute fixup for byte operations.
|
|
|
|
fixup_16_byte,
|
|
|
|
// A 16 bit PC relative fixup for command address.
|
|
|
|
fixup_16_pcrel_byte,
|
|
|
|
// A 10 bit PC relative fixup for complicated polymorphs.
|
|
|
|
fixup_2x_pcrel,
|
|
|
|
// A 16 bit relaxable fixup.
|
|
|
|
fixup_rl_pcrel,
|
|
|
|
// A 8 bit absolute fixup.
|
|
|
|
fixup_8,
|
|
|
|
// A 32 bit symbol difference fixup.
|
|
|
|
fixup_sym_diff,
|
|
|
|
|
|
|
|
// Marker
|
|
|
|
LastTargetFixupKind,
|
|
|
|
NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind
|
|
|
|
};
|
|
|
|
} // end namespace MSP430
|
|
|
|
} // end namespace llvm
|
|
|
|
|
|
|
|
#endif
|