1 //===-- SystemZMCFixups.h - SystemZ-specific fixup entries ------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef LLVM_LIB_TARGET_SYSTEMZ_MCTARGETDESC_SYSTEMZMCFIXUPS_H
10 #define LLVM_LIB_TARGET_SYSTEMZ_MCTARGETDESC_SYSTEMZMCFIXUPS_H
11 
12 #include "llvm/MC/MCFixup.h"
13 #include "llvm/MC/MCFixupKindInfo.h"
14 
15 namespace llvm {
16 namespace SystemZ {
17 enum FixupKind {
18   // These correspond directly to R_390_* relocations.
19   FK_390_PC12DBL = FirstTargetFixupKind,
20   FK_390_PC16DBL,
21   FK_390_PC24DBL,
22   FK_390_PC32DBL,
23   FK_390_TLS_CALL,
24 
25   FK_390_S8Imm,
26   FK_390_S16Imm,
27   FK_390_S20Imm,
28   FK_390_S32Imm,
29   FK_390_U1Imm,
30   FK_390_U2Imm,
31   FK_390_U3Imm,
32   FK_390_U4Imm,
33   FK_390_U8Imm,
34   FK_390_U12Imm,
35   FK_390_U16Imm,
36   FK_390_U32Imm,
37   FK_390_U48Imm,
38 
39   // Marker
40   LastTargetFixupKind,
41   NumTargetFixupKinds = LastTargetFixupKind - FirstTargetFixupKind
42 };
43 
44 const static MCFixupKindInfo MCFixupKindInfos[SystemZ::NumTargetFixupKinds] = {
45     {"FK_390_PC12DBL", 4, 12, MCFixupKindInfo::FKF_IsPCRel},
46     {"FK_390_PC16DBL", 0, 16, MCFixupKindInfo::FKF_IsPCRel},
47     {"FK_390_PC24DBL", 0, 24, MCFixupKindInfo::FKF_IsPCRel},
48     {"FK_390_PC32DBL", 0, 32, MCFixupKindInfo::FKF_IsPCRel},
49     {"FK_390_TLS_CALL", 0, 0, 0},
50     {"FK_390_S8Imm", 0, 8, 0},
51     {"FK_390_S16Imm", 0, 16, 0},
52     {"FK_390_S20Imm", 4, 20, 0},
53     {"FK_390_S32Imm", 0, 32, 0},
54     {"FK_390_U1Imm", 0, 1, 0},
55     {"FK_390_U2Imm", 0, 2, 0},
56     {"FK_390_U3Imm", 0, 3, 0},
57     {"FK_390_U4Imm", 0, 4, 0},
58     {"FK_390_U8Imm", 0, 8, 0},
59     {"FK_390_U12Imm", 4, 12, 0},
60     {"FK_390_U16Imm", 0, 16, 0},
61     {"FK_390_U32Imm", 0, 32, 0},
62     {"FK_390_U48Imm", 0, 48, 0},
63 };
64 } // end namespace SystemZ
65 } // end namespace llvm
66 
67 #endif
68