//===-- PPCFixupKinds.h - PPC Specific Fixup Entries ------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_TARGET_POWERPC_MCTARGETDESC_PPCFIXUPKINDS_H #define LLVM_LIB_TARGET_POWERPC_MCTARGETDESC_PPCFIXUPKINDS_H #include "llvm/MC/MCFixup.h" #undef PPC namespace llvm { namespace PPC { enum Fixups { // fixup_ppc_br24 - 24-bit PC relative relocation for direct branches like 'b' // and 'bl'. fixup_ppc_br24 = FirstTargetFixupKind, /// fixup_ppc_brcond14 - 14-bit PC relative relocation for conditional /// branches. fixup_ppc_brcond14, /// fixup_ppc_br24abs - 24-bit absolute relocation for direct branches /// like 'ba' and 'bla'. fixup_ppc_br24abs, /// fixup_ppc_brcond14abs - 14-bit absolute relocation for conditional /// branches. fixup_ppc_brcond14abs, /// fixup_ppc_half16 - A 16-bit fixup corresponding to lo16(_foo) /// or ha16(_foo) for instrs like 'li' or 'addis'. fixup_ppc_half16, /// fixup_ppc_half16ds - A 14-bit fixup corresponding to lo16(_foo) with /// implied 2 zero bits for instrs like 'std'. fixup_ppc_half16ds, /// fixup_ppc_nofixup - Not a true fixup, but ties a symbol to a call /// to __tls_get_addr for the TLS general and local dynamic models, /// or inserts the thread-pointer register number. fixup_ppc_nofixup, // Marker LastTargetFixupKind, NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind }; } } #endif