[PATCH] D53261: [BPF] Add BTF generation for BPF target
    Adrian Prantl via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Tue Oct 16 08:45:18 PDT 2018
    
    
  
aprantl added a comment.
Thanks!
================
Comment at: include/llvm/MC/MCBTFContext.h:23
+
+// The .BTF section format is defined at
+//   https://github.com/torvalds/linux/blob/master/include/uapi/linux/btf.h
----------------
```
/// \file
/// ...
```
================
Comment at: include/llvm/MC/MCBTFContext.h:167
+/// The .BTF.ext section header definition
+struct BTFExtHeader {
+  uint16_t Magic;
----------------
do you need any kind of packing attribute here for this to work on all platforms?
================
Comment at: include/llvm/MC/MCBTFContext.h:207
+static const char *const BTFKindStr[] = {
+    "UNKNOWN",    // BTF_KIND_UNKN
+    "INT",        // BTF_KIND_INT
----------------
You might want to look at include/llvm/BinaryFormat/Dwarf.h and include/llvm/BinaryFormat/Dwarf.def for how we usually do enums<->string conversions
================
Comment at: lib/CodeGen/AsmPrinter/Dwarf2BTF.cpp:175
+Die2BTFEntryInt::Die2BTFEntryInt(const DIE &Die) : Die2BTFEntry(Die) {
+  // handle BTF_INT_ENCODING in IntVal
+  auto Encoding = Die2BTFEntry::getBaseTypeEncoding(Die);
----------------
`//  Handle BTF_INT_ENCODING in IntVal.`
================
Comment at: lib/CodeGen/AsmPrinter/Dwarf2BTF.cpp:181
+
+  // handle BTF_INT_OFFSET in IntVal
+  auto V = Die.findAttribute(dwarf::DW_AT_bit_offset);
----------------
ditto...
Repository:
  rL LLVM
https://reviews.llvm.org/D53261
    
    
More information about the llvm-commits
mailing list