aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/SparcV9/SparcV9Relocations.h
blob: 895bbedf2f272f70cc4141a3af2ed15d31655d9b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
//===- SparcV9Relocations.h - SparcV9 Code Relocations ----------*- C++ -*-===//
// 
//                     The LLVM Compiler Infrastructure
//
// This file was developed by the LLVM research group and is distributed under
// the University of Illinois Open Source License. See LICENSE.TXT for details.
// 
//===----------------------------------------------------------------------===//
//
// This file defines the SparcV9 target-specific relocation types.
//
//===----------------------------------------------------------------------===//

#ifndef SPARCV9RELOCATIONS_H
#define SPARCV9RELOCATIONS_H

#include "llvm/CodeGen/MachineRelocation.h"

namespace llvm {
  namespace V9 {
    enum RelocationType {
      // reloc_pcrel_call - PC relative relocation, shifted right by two bits,
      // inserted into a 30 bit field.  This is used to relocate direct call
      // instructions.
      reloc_pcrel_call = 0,

      // reloc_sethi_hh - Absolute relocation, for 'sethi %hh(G),reg' operation.
      reloc_sethi_hh = 1,

      // reloc_sethi_lm - Absolute relocation, for 'sethi %lm(G),reg' operation.
      reloc_sethi_lm = 2,

      // reloc_or_hm - Absolute relocation, for 'or reg,%hm(G),reg' operation.
      reloc_or_hm = 3,

      // reloc_or_lo - Absolute relocation, for 'or reg,%lo(G),reg' operation.
      reloc_or_lo = 4,
    };
  }
}

#endif