| //===- MBlazeRelocations.h - MBlaze Code Relocations ------------*- C++ -*-===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file defines the MBlaze target-specific relocation types. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef MBLAZERELOCATIONS_H |
| #define MBLAZERELOCATIONS_H |
| |
| #include "llvm/CodeGen/MachineRelocation.h" |
| |
| namespace llvm { |
| namespace MBlaze { |
| enum RelocationType { |
| /// reloc_pcrel_word - PC relative relocation, add the relocated value to |
| /// the value already in memory, after we adjust it for where the PC is. |
| reloc_pcrel_word = 0, |
| |
| /// reloc_picrel_word - PIC base relative relocation, add the relocated |
| /// value to the value already in memory, after we adjust it for where the |
| /// PIC base is. |
| reloc_picrel_word = 1, |
| |
| /// reloc_absolute_word - absolute relocation, just add the relocated |
| /// value to the value already in memory. |
| reloc_absolute_word = 2, |
| |
| /// reloc_absolute_word_sext - absolute relocation, just add the relocated |
| /// value to the value already in memory. In object files, it represents a |
| /// value which must be sign-extended when resolving the relocation. |
| reloc_absolute_word_sext = 3, |
| |
| /// reloc_absolute_dword - absolute relocation, just add the relocated |
| /// value to the value already in memory. |
| reloc_absolute_dword = 4 |
| }; |
| } |
| } |
| |
| #endif |