| //===-- 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_PPC_PPCFIXUPKINDS_H |
| #define LLVM_PPC_PPCFIXUPKINDS_H |
| |
| #include "llvm/MC/MCFixup.h" |
| |
| 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_lo16 - A 16-bit fixup corresponding to lo16(_foo) for instrs |
| /// like 'li'. |
| fixup_ppc_lo16, |
| |
| /// fixup_ppc_ha16 - A 16-bit fixup corresponding to ha16(_foo) for instrs |
| /// like 'lis'. |
| fixup_ppc_ha16, |
| |
| /// fixup_ppc_lo14 - A 14-bit fixup corresponding to lo16(_foo) for instrs |
| /// like 'std'. |
| fixup_ppc_lo14, |
| |
| /// fixup_ppc_toc - Insert value of TOC base (.TOC.). |
| fixup_ppc_toc, |
| |
| /// fixup_ppc_toc16 - A 16-bit signed fixup relative to the TOC base. |
| fixup_ppc_toc16, |
| |
| /// fixup_ppc_toc16_ds - A 14-bit signed fixup relative to the TOC base with |
| /// implied 2 zero bits |
| fixup_ppc_toc16_ds, |
| |
| /// fixup_ppc_tlsreg - Insert thread-pointer register number. |
| fixup_ppc_tlsreg, |
| |
| /// 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. |
| fixup_ppc_nofixup, |
| |
| // Marker |
| LastTargetFixupKind, |
| NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind |
| }; |
| } |
| } |
| |
| #endif |