1 //===-- BPFMCAsmInfo.h - BPF asm properties -------------------*- C++ -*--====//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file contains the declaration of the BPFMCAsmInfo class.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef LLVM_LIB_TARGET_BPF_MCTARGETDESC_BPFMCASMINFO_H
15 #define LLVM_LIB_TARGET_BPF_MCTARGETDESC_BPFMCASMINFO_H
16 
17 #include "llvm/ADT/Triple.h"
18 #include "llvm/MC/MCAsmInfo.h"
19 
20 namespace llvm {
21 class Target;
22 
23 class BPFMCAsmInfo : public MCAsmInfo {
24 public:
BPFMCAsmInfo(const Triple & TT)25   explicit BPFMCAsmInfo(const Triple &TT) {
26     if (TT.getArch() == Triple::bpfeb)
27       IsLittleEndian = false;
28 
29     PrivateGlobalPrefix = ".L";
30     WeakRefDirective = "\t.weak\t";
31 
32     UsesELFSectionDirectiveForBSS = true;
33     HasSingleParameterDotFile = false;
34     HasDotTypeDotSizeDirective = false;
35 
36     SupportsDebugInformation = true;
37     ExceptionsType = ExceptionHandling::DwarfCFI;
38     MinInstAlignment = 8;
39 
40     // the default is 4 and it only affects dwarf elf output
41     // so if not set correctly, the dwarf data will be
42     // messed up in random places by 4 bytes. .debug_line
43     // section will be parsable, but with odd offsets and
44     // line numbers, etc.
45     CodePointerSize = 8;
46   }
47 
setDwarfUsesRelocationsAcrossSections(bool enable)48   void setDwarfUsesRelocationsAcrossSections(bool enable) {
49     DwarfUsesRelocationsAcrossSections = enable;
50   }
51 };
52 }
53 
54 #endif
55