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