| Jia Liu | b22310f | 2012-02-18 12:03:15 +0000 | [diff] [blame] | 1 | //===-- PPCRelocations.h - PPC Code Relocations -----------------*- C++ -*-===// | 
| Misha Brukman | b440243 | 2005-04-21 23:30:14 +0000 | [diff] [blame] | 2 | // | 
| Chris Lattner | 0b4eb3f | 2004-11-23 05:57:38 +0000 | [diff] [blame] | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
| Chris Lattner | f3ebc3f | 2007-12-29 20:36:04 +0000 | [diff] [blame] | 5 | // This file is distributed under the University of Illinois Open Source | 
|  | 6 | // License. See LICENSE.TXT for details. | 
| Misha Brukman | b440243 | 2005-04-21 23:30:14 +0000 | [diff] [blame] | 7 | // | 
| Chris Lattner | 0b4eb3f | 2004-11-23 05:57:38 +0000 | [diff] [blame] | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 | // | 
|  | 10 | // This file defines the PowerPC 32-bit target-specific relocation types. | 
|  | 11 | // | 
|  | 12 | //===----------------------------------------------------------------------===// | 
|  | 13 |  | 
| Jia Liu | b22310f | 2012-02-18 12:03:15 +0000 | [diff] [blame] | 14 | #ifndef PPCRELOCATIONS_H | 
|  | 15 | #define PPCRELOCATIONS_H | 
| Chris Lattner | 0b4eb3f | 2004-11-23 05:57:38 +0000 | [diff] [blame] | 16 |  | 
|  | 17 | #include "llvm/CodeGen/MachineRelocation.h" | 
|  | 18 |  | 
| Jeff Cohen | 33a030e | 2005-07-27 05:53:44 +0000 | [diff] [blame] | 19 | // Hack to rid us of a PPC pre-processor symbol which is erroneously | 
| Reid Spencer | 8086cfa | 2005-06-08 17:44:48 +0000 | [diff] [blame] | 20 | // defined in a PowerPC header file (bug in Linux/PPC) | 
|  | 21 | #ifdef PPC | 
|  | 22 | #undef PPC | 
|  | 23 | #endif | 
|  | 24 |  | 
| Chris Lattner | 0b4eb3f | 2004-11-23 05:57:38 +0000 | [diff] [blame] | 25 | namespace llvm { | 
|  | 26 | namespace PPC { | 
|  | 27 | enum RelocationType { | 
| Nate Begeman | a0d95a8 | 2006-09-10 23:03:44 +0000 | [diff] [blame] | 28 | // reloc_vanilla - A standard relocation, where the address of the | 
|  | 29 | // relocated object completely overwrites the address of the relocation. | 
|  | 30 | reloc_vanilla, | 
|  | 31 |  | 
| Chris Lattner | 0b4eb3f | 2004-11-23 05:57:38 +0000 | [diff] [blame] | 32 | // reloc_pcrel_bx - PC relative relocation, for the b or bl instructions. | 
|  | 33 | reloc_pcrel_bx, | 
|  | 34 |  | 
| Evan Cheng | 78bf107 | 2006-07-27 18:21:10 +0000 | [diff] [blame] | 35 | // reloc_pcrel_bcx - PC relative relocation, for BLT,BLE,BEQ,BGE,BGT,BNE, | 
|  | 36 | // and other bcx instructions. | 
|  | 37 | reloc_pcrel_bcx, | 
|  | 38 |  | 
| Chris Lattner | dd51679 | 2004-11-24 22:30:08 +0000 | [diff] [blame] | 39 | // reloc_absolute_high - Absolute relocation, for the loadhi instruction | 
| Chris Lattner | 0b4eb3f | 2004-11-23 05:57:38 +0000 | [diff] [blame] | 40 | // (which is really addis).  Add the high 16-bits of the specified global | 
| Chris Lattner | dd51679 | 2004-11-24 22:30:08 +0000 | [diff] [blame] | 41 | // address into the low 16-bits of the instruction. | 
|  | 42 | reloc_absolute_high, | 
| Chris Lattner | 0b4eb3f | 2004-11-23 05:57:38 +0000 | [diff] [blame] | 43 |  | 
| Chris Lattner | dd51679 | 2004-11-24 22:30:08 +0000 | [diff] [blame] | 44 | // reloc_absolute_low - Absolute relocation, for the la instruction (which | 
| Chris Lattner | 5b17dee | 2006-07-12 21:23:20 +0000 | [diff] [blame] | 45 | // is really an addi).  Add the low 16-bits of the specified global | 
| Chris Lattner | dd51679 | 2004-11-24 22:30:08 +0000 | [diff] [blame] | 46 | // address into the low 16-bits of the instruction. | 
|  | 47 | reloc_absolute_low, | 
| Chris Lattner | 5b17dee | 2006-07-12 21:23:20 +0000 | [diff] [blame] | 48 |  | 
|  | 49 | // reloc_absolute_low_ix - Absolute relocation for the 64-bit load/store | 
|  | 50 | // instruction which have two implicit zero bits. | 
| Nate Begeman | 69df613 | 2006-09-08 22:42:09 +0000 | [diff] [blame] | 51 | reloc_absolute_low_ix | 
| Chris Lattner | 0b4eb3f | 2004-11-23 05:57:38 +0000 | [diff] [blame] | 52 | }; | 
|  | 53 | } | 
|  | 54 | } | 
|  | 55 |  | 
|  | 56 | #endif |