labath added a reviewer: amccarth.
labath added a comment.

I take it that D63166 <https://reviews.llvm.org/D63166> is a prerequisite for 
this patch. Is that all, or is there something else that we ought to look at 
first?

Overall, this patch is slightly larger that would be ideal for a proper review, 
though I appreciate the difficulty in bootstrapping something like this. 
However, given that the register context gunk is actually a significant portion 
of this patch (though that's not your fault), maybe you could just restrict 
this patch to a single architecture, and do others as follow-ups? This would 
let the overall structure of the code stand out more prominently.

In D63165#1539118 <https://reviews.llvm.org/D63165#1539118>, @amccarth wrote:

> Sorry for the stupid question, but ...
>
> What exactly is meant here by "Native"?  How is a NativeProcessWindows 
> different from ProcessWindows?


The Native*** classes are meant to be used from lldb-server. They look somewhat 
similar to their non-native counterpart because they still do debugging, but 
they're a lot dumber, because they only deal with basic process control, and 
none of the fancy symbolic stuff that you'd need debug info for.



================
Comment at: source/Plugins/Process/Windows/Common/NativeProcessWindows.cpp:352
+
+  // The very first one shall always be the matin thread.
+  assert(m_threads.empty());
----------------
s/matin/main


================
Comment at: 
source/Plugins/Process/Windows/Common/NativeProcessWindows.cpp:529-530
+  ProcessAttachInfo attach_info;
+  attach_info.SetProcessID(pid);
+  attach_info.SetArchitecture(process_info.GetArchitecture());
+
----------------
Fetching the architecture this way looks like it could be racy if the pid is 
recycled before you get a chance to attach to the process (can that happen?). 
Is there a way to fetch the architecture *after* you perform the attach 
operation.


================
Comment at: source/Plugins/Process/Windows/Common/NativeProcessWindows.cpp:536
+
+  error = process_up->DoAttachToProcessWithID(pid, attach_info);
+  if (error.Fail())
----------------
passing attach_info seems pretty redundant, as at this point the process should 
already be know the pid and the architecture (they were passed in the 
constructor). In fact, I think you should just delete 
`DoAttachToProcessWithID`, do that work in the constructor, and use the 
`ErrorAsOutParameter` pattern to return the error from there. (The 
Factory::Attach pattern was trying to avoid/discourage the use fallible 
constructors, but that's hard to avoid when you need to instantiate another 
object and set up callbacks. In that case, a fallible constructor is better 
over a separate function, as this way at least the initialization happens in a 
single step.)


================
Comment at: source/Plugins/Process/Windows/Common/NativeProcessWindows.h:16
+#include "IDebugDelegate.h"
+#include "ProcessDebugger.h"
+
----------------
amccarth wrote:
> Where is ProcessDebugger.h?  Should that be part of this patch?
I guess that's introduced in D63166


================
Comment at: 
source/Plugins/Process/Windows/Common/NativeRegisterContextWindows.h:31
+protected:
+  Status ReadAllRegisterValues(lldb::DataBufferSP &data_sp,
+                               const size_t data_size);
----------------
Is this overriding something? Can you please use `override` to indicate that 
(throughout this patch)?


================
Comment at: 
source/Plugins/Process/Windows/Common/NativeRegisterContextWindows_x86_64.cpp:13
+#include "NativeRegisterContextWindows_wow64.h"
+
+#include "NativeThreadWindows.h"
----------------
The empty lines here look completely random. I'd just delete all of the empty 
lines and let clang-format sort/group the includes for you.


Repository:
  rLLDB LLDB

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

https://reviews.llvm.org/D63165



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

Reply via email to