[Lldb-commits] [PATCH] D53436: [LLDB] - Implement the support for	the .debug_loclists section.
    George Rimar via Phabricator via lldb-commits 
    lldb-commits at lists.llvm.org
       
    Fri Oct 19 07:32:00 PDT 2018
    
    
  
grimar added a comment.
Since .debug_loclists contains locations descriptions for objects
that can change location during lifetime, I do not see a way to
write the test without relying on a compiler that has support for
DWARF5. We should compile and run executable to test that location
was calculated properly I believe. Other our tests for DWARF5 sections
recently implemented used YAML and never run any executables.
So, the test case is not included.
At the same time I was able to test it with the following code and invocation:
(trunk clang + https://reviews.llvm.org/D53365 applied):
  ~/LLVM/build/bin/clang -gdwarf-5 test.cc  -o test_v5-fuse-ld=lld -fno-rtti
  struct A { 
    int x = 0; 
    virtual void foo(); 
  };
  
  void baz(struct A a) { 
   a.foo();
  }
  
  void A::foo() { int x = 0; ++x; }
  
  int main() {
    A objA;
    objA.x = 3;
    baz(objA);
    return 0;
  }
After executing the following commands, the location of `a` is properly evaluated:
  (lldb) target create "test_v5"
  Current executable set to 'test_v5' (x86_64).
  (lldb) b baz
  Breakpoint 1: where = test_v5`baz(A) + 4 at test.cc:9:6, address = 0x00000000002010e4
  (lldb) run
  Process 115974 launched: '/home/umb/tests_2018/110_lldbloclists/test_v5' (x86_64)
  Process 115974 stopped
  * thread #1, name = 'test_v5', stop reason = breakpoint 1.1
      frame #0: 0x00000000002010e4 test_v5`baz(a=(x = 3)) at test.cc:9:6
     6    };
     7   
     8    void baz(struct A a) {
  -> 9       a.foo();
     10   }
Without this patch output will be:
  ...
  frame #0: 0x00000000002010e4 test_v5`baz(a=<unavailable>) at test.cc:9:6
  ...
https://reviews.llvm.org/D53436
    
    
More information about the lldb-commits
mailing list