xref: /freebsd/contrib/llvm-project/lldb/docs/man/lldb.rst (revision da759cfa320d5076b075d15ff3f00ab3ba5634fd)
1:orphan:
2
3lldb -- The Debugger
4====================
5
6.. program:: lldb
7
8SYNOPSIS
9--------
10
11| :program:`lldb` [*options*] *executable*
12
13DESCRIPTION
14-----------
15
16:program:`lldb` is a next generation, high-performance debugger. It is built as
17a set of reusable components which highly leverage existing libraries in the
18larger LLVM Project, such as the Clang expression parser and LLVM disassembler.
19
20:program:`lldb` is the default debugger in Xcode on macOS and supports
21debugging C, Objective-C and C++ on the desktop and iOS devices and simulator.
22
23All of the code in the LLDB project is available under the Apache 2.0 License
24with LLVM exceptions.
25
26ATTACHING
27---------
28
29.. option:: --attach-name <name>
30
31 Tells the debugger to attach to a process with the given name.
32
33.. option:: --attach-pid <pid>
34
35 Tells the debugger to attach to a process with the given pid.
36
37.. option:: -n <value>
38
39 Alias for --attach-name
40
41.. option:: -p <value>
42
43 Alias for --attach-pid
44
45.. option:: --wait-for
46
47 Tells the debugger to wait for a process with the given pid or name to launch before attaching.
48
49.. option:: -w
50
51 Alias for --wait-for
52
53COMMANDS
54--------
55
56.. option:: --batch
57
58 Tells the debugger to run the commands from -s, -S, -o & -O, and then quit.
59
60.. option:: -b
61
62 Alias for --batch
63
64.. option:: -K <value>
65
66 Alias for --source-on-crash
67
68.. option:: -k <value>
69
70 Alias for --one-line-on-crash
71
72.. option:: --local-lldbinit
73
74 Allow the debugger to parse the .lldbinit files in the current working directory, unless --no-lldbinit is passed.
75
76.. option:: --no-lldbinit
77
78 Do not automatically parse any '.lldbinit' files.
79
80.. option:: --one-line-before-file <command>
81
82 Tells the debugger to execute this one-line lldb command before any file provided on the command line has been loaded.
83
84.. option::  --one-line-on-crash <command>
85
86 When in batch mode, tells the debugger to run this one-line lldb command if the target crashes.
87
88.. option:: --one-line <command>
89
90 Tells the debugger to execute this one-line lldb command after any file provided on the command line has been loaded.
91
92.. option:: -O <value>
93
94 Alias for --one-line-before-file
95
96.. option:: -o <value>
97
98 Alias for --one-line
99
100.. option:: -Q
101
102 Alias for --source-quietly
103
104.. option:: --source-before-file <file>
105
106 Tells the debugger to read in and execute the lldb commands in the given file, before any file has been loaded.
107
108.. option:: --source-on-crash <file>
109
110 When in batch mode, tells the debugger to source this file of lldb commands if the target crashes.
111
112.. option:: --source-quietly
113
114 Tells the debugger to execute this one-line lldb command before any file has been loaded.
115
116.. option:: --source <file>
117
118 Tells the debugger to read in and execute the lldb commands in the given file, after any file has been loaded.
119
120.. option:: -S <value>
121
122 Alias for --source-before-file
123
124.. option:: -s <value>
125
126 Alias for --source
127
128.. option:: -x
129
130 Alias for --no-lldbinit
131
132OPTIONS
133-------
134
135.. option:: --arch <architecture>
136
137 Tells the debugger to use the specified architecture when starting and running the program.
138
139.. option:: -a <value>
140
141 Alias for --arch
142
143.. option:: --capture-path <filename>
144
145 Tells the debugger to use the given filename for the reproducer.
146
147.. option:: --capture
148
149 Tells the debugger to capture a reproducer.
150
151.. option:: --core <filename>
152
153 Tells the debugger to use the full path to <filename> as the core file.
154
155.. option:: -c <value>
156
157 Alias for --core
158
159.. option:: --debug
160
161 Tells the debugger to print out extra information for debugging itself.
162
163.. option:: -d
164
165 Alias for --debug
166
167.. option:: --editor
168
169 Tells the debugger to open source files using the host's "external editor" mechanism.
170
171.. option:: -e
172
173 Alias for --editor
174
175.. option:: --file <filename>
176
177 Tells the debugger to use the file <filename> as the program to be debugged.
178
179.. option:: -f <value>
180
181 Alias for --file
182
183.. option:: --help
184
185 Prints out the usage information for the LLDB debugger.
186
187.. option:: -h
188
189 Alias for --help
190
191.. option:: --no-use-colors
192
193 Do not use colors.
194
195.. option:: --replay <filename>
196
197 Tells the debugger to replay a reproducer from <filename>.
198
199.. option:: --version
200
201 Prints out the current version number of the LLDB debugger.
202
203.. option:: -v
204
205 Alias for --version
206
207.. option:: -X
208
209 Alias for --no-use-color
210
211REPL
212----
213
214.. option:: -r=<flags>
215
216 Alias for --repl=<flags>
217
218.. option:: --repl-language <language>
219
220 Chooses the language for the REPL.
221
222.. option:: --repl=<flags>
223
224 Runs lldb in REPL mode with a stub process with the given flags.
225
226.. option:: -R <value>
227
228 Alias for --repl-language
229
230SCRIPTING
231---------
232
233.. option:: -l <value>
234
235 Alias for --script-language
236
237.. option:: --python-path
238
239 Prints out the path to the lldb.py file for this version of lldb.
240
241.. option:: -P
242
243 Alias for --python-path
244
245.. option:: --script-language <language>
246
247 Tells the debugger to use the specified scripting language for user-defined scripts.
248
249EXAMPLES
250--------
251
252The debugger can be started in several modes.
253
254Passing an executable as a positional argument prepares :program:`lldb` to
255debug the given executable. Arguments passed after -- are considered arguments
256to the debugged executable.
257
258  lldb --arch x86_64 /path/to/program -- --arch arvm7
259
260Passing one of the attach options causes :program:`lldb` to immediately attach
261to the given process.
262
263  lldb -p <pid>
264  lldb -n <process-name>
265
266Passing --repl starts :program:`lldb` in REPL mode.
267
268  lldb -r
269
270Passing --core causes :program:`lldb` to debug the core file.
271
272  lldb -c /path/to/core
273
274Command options can be combined with these modes and cause :program:`lldb` to
275run the specified commands before or after events, like loading the file or
276crashing, in the order provided on the command line.
277
278  lldb -O 'settings set stop-disassembly-count 20' -o 'run' -o 'bt'
279  lldb -S /source/before/file -s /source/after/file
280  lldb -K /source/before/crash -k /source/after/crash
281
282Note: In REPL mode no file is loaded, so commands specified to run after
283loading the file (via -o or -s) will be ignored.
284
285USING LLDB
286----------
287
288In :program:`lldb` there is a help command which can be used to find
289descriptions and examples of all :program:`lldb` commands.  To get help on
290"breakpoint set" you would type "help breakpoint set".
291
292There is also an apropos command which will search the help text of all
293commands for a given term ‐‐ this is useful for locating a command by topic.
294For instance, "apropos breakpoint" will list any command that has the word
295"breakpoint" in its help text.
296
297CONFIGURATION FILES
298-------------------
299
300:program:`lldb` reads things like settings, aliases and commands from the
301.lldbinit file. It will first look for ~/.lldbinit and load that first.
302Secondly, it will look for an .lldbinit file in the current working directory.
303For security reasons, :program:`lldb` will print a warning and not source this
304file by default. This behavior can be changed by changing the
305target.load-cwd-lldbinit setting.
306
307To always load the .lldbinit file in the current working directory, add the
308following command to ~/.lldbinit:
309
310  settings set target.load-cwd-lldbinit true
311
312To never load the .lldbinit file in the current working directory and silence
313the warning, add the following command to ~/.lldbinit:
314
315  settings set target.load-cwd-lldbinit false
316
317SEE ALSO
318--------
319
320The LLDB project page https://lldb.llvm.org has many different resources
321for :program:`lldb` users ‐‐ the gdb/lldb command equivalence page
322https://lldb.llvm.org/use/map.html can be especially helpful for users
323coming from gdb.
324