Skip to content
This repository has been archived by the owner on Jun 14, 2024. It is now read-only.

Updating remote process capture FAQ #44

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
100 changes: 96 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -101,17 +101,50 @@ Try clang instead of gcc (fingers crossed). See [clang comparison](http://clang.

#### How do I attach to a running process?

To be able to attach, the "attacher" needs to have special permissions. The
easiest method is to run a debug server as 'sudo' and connect to it.
See the question below.
To be able to attach a running process, the lldb process needs to have a
special capability to enable usage of the [*ptrace*] system call. [For security
reasons], this system call is restricted to the children processes of the
process doing the capture, which is the default way that `lldb` (or any debugger) works.

But you can enable capturing of a running process by globally disabling scoping of
the ptrace system call:

```
sysct -w kernel.yama.ptrace_scope=0
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

sysctl (l missing)

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👌

```

But don't forget to set it back to `1` when you're done to keep your system safe.

You'd have two other ways to attach to a running process, but because *lldb.vim*
uses python bindings and not the `lldb` executable, those can only work with `lldb-server`.
So please read [the following FAQ entry on how to run a remote server][remote-debug].

Instead of disabling `ptrace` scoping globally, you can as well disable it just for
the `lldb-server` executable (on debian, you'll need `libcap2-bin` installed):
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just stating "you'll need libcap2" is enough, I think. Anyway, libcap2 is a prerequisite for coreutils, so it's very unlikely to not have it installed.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👌


```
sudo setcap cap_sys_ptrace=eip /usr/bin/lldb-server
```

To revert the setting:

```
sudo setcap -r /usr/bin/lldb-server
```

Another way would be to run `lldb-server` as root, as bypassing `ptrace` scoping is
amongst the root privileges.

[*ptrace*]:https://en.wikipedia.org/wiki/Ptrace
[For security reasons]:http://askubuntu.com/a/153970/583565

#### Remote debugging does not work!!

I haven't been able to get `gdbserver`, `lldb-gdbserver` or `lldb-server gdbserver`
to work properly with the python API. But the following works; run:

```
# use sudo if you want to attach to a running process
# use sudo if you want to attach to a running process or setcap
$ lldb-server platform --listen localhost:2345

# in older versions of lldb, use this instead
Expand All @@ -128,3 +161,62 @@ on port 2345. Now, from the client (the plugin), run:
```

For more info on this, see [Remote Debugging](http://lldb.llvm.org/remote.html).

#### How to debug an interactive commandline process?

You'll need to make it possible to capture a remote process with `lldb`, see the above
two answers for more details.

If you choose to disable globally `ptrace` scoping, you can run the following command
to open a new terminal buffer with your interactive command line program (once your
debugging session is started):

```
:1wincmd w | vsplit | term ./debugee -args | exec(":LL process attach -p " . b:terminal_job_pid)
```

Then you can setup breakpoints, watchpoints… and start the execution with `:LL continue`.
(don't forget to change `debugee` with your program name).

If you prefer to use a debugging server instead, you can add the following viml function
in your `vimrc`:

```
function! LLSpawn(target)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Instead of starting lldb-server here, I think it would be cleaner to let them start it elsewhere, and make this function take a port number as argument.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

made both work

Copy link
Collaborator

@critiqjo critiqjo Jan 8, 2017

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

made both work

That wasn't my intention. I primarily wanted to make the snippet short. If FAQ is too long, people will be even more reluctant to read it. Besides, it still has syntax errors.

I'll fix them and merge it when I get free. Probably after a month.

if !exists('g:lldb#remote_server')
if !system('pgrep "lldb-server"')
!lldb-server --listen localhost:42042&
# or
# !sudo lldb-server --listen localhost:42042&
sleep 1
echomsg 'lldb-server started...'
else
echoerr 'lldb-server already running!'
endif
LL platform select remote-linux
LL platform connect connect://localhost:42042
let g:lldb#remote_server = 1
endif
1wincmd w
vsplit
exe ":term ". a:target
exe ":LL process attach -p " . b:terminal_job_pid
2wincmd w
endfunction
```

then once your debugging session has been started, you can run:

```
call LLSpawn('./debuggee --args')
```

which will start an `lldb-server` as suggested in the [former FAQ entry][remote-debug], start the
*debuggee* process and attach it. If you choose to start the process as root, just
prefix the `lldb-server` call with `sudo`, otherwise you need to disable `ptrace`
scoping in any way suggested [above][attach-process].

[attach-process]:https://github.com/guyzmo/lldb.nvim/blob/patch-1/README.md#how-do-I-attach-to-a-running-process
[remote-debug]:https://github.com/guyzmo/lldb.nvim/blob/patch-1/README.md#remote-debugging-does-not-work
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Wrong links! Just the id part should work:

[attach-process]: #how-do-I-attach-to-a-running-process
[remote-debug]: #remote-debugging-does-not-work

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👌