aadsm marked 4 inline comments as done.
aadsm added a comment.

@labath

> Regarding the test, I am wondering whether requiring the /proc/%d/maps and 
> the linker rendezvous structure to match isn't too strict of a requirement. 
> Dynamic linkers (and particularly android dynamic linkers) do a lot of crazy 
> stuff, and trying to assert this invariant exposes us to all kinds of 
> "optimizations" that the linkers do or may do in the future. I'm wondering if 
> it wouldn't be better to just build an executable with one or two dependent 
> libraries, and then just assert that their entries are present in the library 
> list. However, I'm not completely sure on this, so I'd like to hear what you 
> think about that..

Yeah, that was actually my first idea for the test but then realized we already 
had that main.c all set up and ready to use so I decide to use proc maps 
instead. I was not aware that things like that could happen (although I had a 
suspicion this might be brittle) so let me revisit this.



================
Comment at: lldb/include/lldb/Host/common/NativeProcessProtocol.h:37-39
+  lldb::addr_t link_map;
+  lldb::addr_t base_addr;
+  lldb::addr_t ld_addr;
----------------
clayborg wrote:
> These seem very linux specific. Why do we need 3 addresses here? Seems like 
> we should just need one. Or is this the structure of the 
> "xfer:libraries-svr4:read" that is required to be returned? If so, maybe we 
> rename "SharedLibraryInfo" to "SVR4ModuleInfo"?
Yes, that is a good point and yes this is the data the SVR4 returns. Given this 
structure it makes more sense to move this into the NativeProcessLinux instead 
and name it more specifically.


================
Comment at: lldb/include/lldb/Host/common/NativeProcessProtocol.h:40
+  lldb::addr_t ld_addr;
+  bool main;
+  lldb::addr_t next;
----------------
clayborg wrote:
> Why is "main" important? Hopefully the dynamic linker can figure out what is 
> what without needing to know this? Seems verify linux specific. Or is this 
> "xfer:libraries-svr4:read" specific?
It is packet specific yes. And I just realized I'm not putting that info in the 
XML I'm returning, will update.


================
Comment at: lldb/source/Plugins/Process/Linux/NativeProcessLinux.cpp:2191
+  char name_buffer[PATH_MAX];
+  error = ReadMemory(link_map.l_name, &name_buffer, sizeof(name_buffer),
+                     bytes_read);
----------------
clayborg wrote:
> Use ReadCStringFromMemory?
ReadCStringFromMemory doesn't exist here yet. That's on the next diff of this 
stack of diffs.


================
Comment at: lldb/source/Plugins/Process/Linux/NativeProcessLinux.cpp:2247
+    library_list.push_back(info);
+    link_map = info.next;
+  }
----------------
clayborg wrote:
> Seems this we are using "info.next" just because it is a linked list on 
> linux. Can we remove "next" and just add an extra "next" reference parameter 
> to ReadSharedLibraryInfo<T>(link_map, info, next);?
> 
Yes, this is the only reason, sounds good.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D62502/new/

https://reviews.llvm.org/D62502



_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits

Reply via email to