LLVM 20.0.0git
SystemZMCFixups.h
Go to the documentation of this file.
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"
14
15namespace llvm {
16namespace SystemZ {
18 // These correspond directly to R_390_* relocations.
24
38
39 // Marker
42};
43
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
static const MCFixupKindInfo MCFixupKindInfos[SystemZ::NumTargetFixupKinds]
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
@ FirstTargetFixupKind
Definition: MCFixup.h:45
Target independent information on a fixup kind.
@ FKF_IsPCRel
Is this fixup kind PCrelative? This is used by the assembler backend to evaluate fixup values in a ta...