博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LLDB TO GDB COMMAND MAP LLDB TO GDB COMMAND MAP[转]
阅读量:6150 次
发布时间:2019-06-21

本文共 9554 字,大约阅读时间需要 31 分钟。

Below is a table of LLDB commands with the GDB counterparts. The built in GDB compatability aliases in GDB are also listed.

EXECUTION COMMANDS

LLDB

GDB

Launch a process no arguments.

(lldb) process launch

(lldb) run

(lldb) r

(gdb) run

(gdb) r

Launch a process with arguments <args>.

(lldb) process launch -- <args>

(lldb) r <args>

(gdb) run <args>

(gdb) r <args>

Launch a process for with arguments a.out 1 2 3 without having to supply the args every time.

% lldb -- a.out 1 2 3

(lldb) run

...

(lldb) run

...

% gdb --args a.out 1 2 3

(gdb) run

...

(gdb) run

...

Launch a process with arguments in new terminal window (Mac OS X only).

(lldb) process launch --tty -- <args>

(lldb) pro la -t -- <args>

Launch a process with arguments in existing terminal /dev/ttys006 (Mac OS X only).

(lldb) process launch --tty=/dev/ttys006 -- <args>

(lldb) pro la -t/dev/ttys006 -- <args>

Attach to a process with process ID 123.

(lldb) process attach --pid 123

(lldb) attach -p 123

(gdb) attach 123

Attach to a process named "a.out".

(lldb) process attach --name a.out

(lldb) pro at -n a.out

(gdb) attach a.out

Wait for a process named "a.out" to launch and attach.

(lldb) process attach --name a.out --waitfor

(lldb) pro at -n a.out -w

(gdb) attach -waitfor a.out

Do a source level single step in the currently selected thread.

(lldb) thread step-in

(lldb) step

(lldb) s

(gdb) step

(gdb) s

Do a source level single step over in the currently selected thread.

(lldb) thread step-over

(lldb) next

(lldb) n

(gdb) next

(gdb) n

Do an instruction level single step in the currently selected thread.

(lldb) thread step-inst

(lldb) si

(gdb) stepi

(gdb) si

Do an instruction level single step over in the currently selected thread.

(lldb) thread step-inst-over

(lldb) ni

(gdb) nexti

(gdb) ni

Step out of the currently selected frame.

(lldb) thread step-out

(lldb) finish

(gdb) finish

Backtrace and disassemble every time you stop.

(lldb) target stop-hook add

Enter your stop hook command(s). Type 'DONE' to end.

> bt

> disassemble --pc

> DONE

Stop hook #1 added.

BREAKPOINT COMMANDS

LLDB

GDB

Set a breakpoint at all functions named main.

(lldb) breakpoint set --name main

(lldb) br s -n main

(lldb) b main

(gdb) break main

Set a breakpoint in file test.c at line 12.

(lldb) breakpoint set --file test.c --line 12

(lldb) br s -f test.c -l 12

(lldb) b test.c:12

(gdb) break test.c:12

Set a breakpoint at all C++ methods whose basename is main.

(lldb) breakpoint set --method main

(lldb) br s -M main

(gdb) break main

(Hope that there are no C funtions namedmain).

Set a breakpoint at and object C function: -[NSString stringWithFormat:].

(lldb) breakpoint set --name "-[NSString stringWithFormat:]"

(lldb) b -[NSString stringWithFormat:]

(gdb) break -[NSString stringWithFormat:]

Set a breakpoint at all Objective C methods whose selector is count.

(lldb) breakpoint set --selector count

(lldb) br s -S count

(gdb) break count

(Hope that there are no C or C++ funtions named count).

List all breakpoints.

(lldb) breakpoint list

(lldb) br l

(gdb) info break

Delete a breakpoint.

(lldb) breakpoint delete 1

(lldb) br del 1

(gdb) delete 1

EXAMINING VARIABLES

LLDB

GDB

Show the arguments and local variables for the current frame.

(lldb) frame variable

(gdb) info args

and

(gdb) info locals

Show the local variables for the current frame.

(lldb) frame variable --no-args

(lldb) fr v -a

(gdb) info locals

Show the contents of local variable "bar".

(lldb) frame variable bar 

(lldb) fr v bar 

(lldb) p bar 

(gdb) p bar

Show the contents of local variable "bar" formatted as hex.

(lldb) frame variable --format x bar 

(lldb) fr v -f x bar 

(gdb) p/x bar

Show the contents of global variable "baz".

(lldb) target variable baz 

(lldb) ta v baz 

(gdb) p baz

Show the global/static variables defined in the current source file.

(lldb) target variable 

(lldb) ta v 

n/a

Display a the variable "argc" and "argv" every time you stop.

(lldb) target stop-hook add --one-liner "frame variable argc argv"

(lldb) ta st a -o "fr v argc argv"

(lldb) display argc

(lldb) display argv

(gdb) display argc

(gdb) display argv

Display a the variable "argc" and "argv" only when you stop in the function named main.

(lldb) target stop-hook add --name main --one-liner "frame variable argc argv"

(lldb) ta st a -n main -o "fr v argc argv"

Display the variable "*this" only when you stop in c class named MyClass.

(lldb) target stop-hook add --classname MyClass --one-liner "frame variable *this"

(lldb) ta st a -c MyClass -o "fr v *this"

EXAMINING THREAD STATE

LLDB

GDB

Show the stack backtrace for the current thread.

(lldb) thread backtrace

(lldb) bt

(gdb) bt

Show the stack backtraces for all threads.

(lldb) thread backtrace all

(lldb) bt all

(gdb) thread apply all bt

Select a different stack frame by index for the current thread.

(lldb) frame select 12

(gdb) frame 12

Select the stack frame that called the current stack frame.

(lldb) up

(lldb) frame select --relative=1

(gdb) up

Select the stack frame that is called by the current stack frame.

(lldb) down

(lldb) frame select --relative=-1

(lldb) fr s -r-1

(gdb) down

Select a different stack frame using a relative offset.

(lldb) frame select --relative 2

(lldb) fr s -r2

(lldb) frame select --relative -3

(lldb) fr s -r-3

(gdb) up 2

(gdb) down 3

Show the general purpose registers for the current thread.

(lldb) register read

(gdb) info registers

Show the general purpose registers for the current thread formatted as signed decimal. LLDB tries to use the same format characters as printf(3) when possible. Type "help format" to see the full list of format specifiers.

(lldb) register read --format i

(lldb) re r -f i

LLDB now supports the GDB shorthand format syntax but there can't be space after the command:

(lldb) register read/d

Show all registers in all register sets for the current thread.

(lldb) register read --all

(lldb) re r -a

(gdb) info all-registers

Show the values for the registers named "rax", "rsp" and "rbp" in the current thread.

(lldb) register read rax rsp rbp

(gdb) info all-registers rax rsp rbp

Show the values for the register named "rax" in the current thread formatted as binary.

(lldb) register read --format binary rax

(lldb) re r -f b rax

LLDB now supports the GDB shorthand format syntax but there can't be space after the command:

(lldb) register read/t rax

(lldb) p/t $rax

(gdb) p/t $rax

Read memory from address 0xbffff3c0 and show 4 hex uint32_t values.

(lldb) memory read --size 4 --format x --count 4 0xbffff3c0

(lldb) me r -s4 -fx -c4 0xbffff3c0

(lldb) x -s4 -fx -c4 0xbffff3c0

LLDB now supports the GDB shorthand format syntax but there can't be space after the command:

(lldb) memory read/4xw 0xbffff3c0

(lldb) x/4xw 0xbffff3c0

(lldb) memory read --gdb-format 4xw 0xbffff3c0

(gdb) x/4xw 0xbffff3c0

Read memory starting at the expression "argv[0]".

(lldb) memory read `argv[0]`

NOTE: any command can inline a scalar expression result (as long as the target is stopped) using backticks around any expression:

(lldb) memory read --size `sizeof(int)` `argv[0]`

(gdb) x argv[0]

Read 512 bytes of memory from address 0xbffff3c0 and save results to a local file as text.

(lldb) memory read --outfile /tmp/mem.txt --count 512 0xbffff3c0

(lldb) me r -o/tmp/mem.txt -c512 0xbffff3c0

(lldb) x/512bx -o/tmp/mem.txt 0xbffff3c0

(gdb) set logging on

(gdb) set logging file /tmp/mem.txt

(gdb) x/512bx 0xbffff3c0

(gdb) set logging off

Save binary memory data starting at 0x1000 and ending at 0x2000 to a file.

(lldb) memory read --outfile /tmp/mem.bin --binary 0x1000 0x1200

(lldb) me r -o /tmp/mem.bin -b 0x1000 0x1200

Disassemble the current function for the current frame.

(lldb) disassemble --frame

(lldb) di -f

(gdb) disassemble

Disassemble any functions named main.

(lldb) disassemble --name main

(lldb) di -n main

(gdb) disassemble main

Disassemble an address range.

(lldb) disassemble --start-address 0x1eb8 --end-address 0x1ec3

(lldb) di -s 0x1eb8 -e 0x1ec3

(gdb) disassemble 0x1eb8 0x1ec3

Disassemble 20 instructions from a given address.

(lldb) disassemble --start-address 0x1eb8 --count 20

(lldb) di -s 0x1eb8 -c 20

(gdb) x/20i 0x1eb8

Show mixed source and disassembly for the current function for the current frame.

(lldb) disassemble --frame --mixed

(lldb) di -f -m

n/a

Disassemble the current function for the current frame and show the opcode bytes.

(lldb) disassemble --frame --bytes

(lldb) di -f -b

n/a

Disassemble the current source line for the current frame.

(lldb) disassemble --line

(lldb) di -l

n/a

EXECUTABLE AND SHARED LIBRARY QUERY COMMANDS

LLDB

GDB

List the main executable and all dependent shared libraries.

(lldb) image list

(gdb) info shared

Lookup information for a raw address in the executable or any shared libraries.

(lldb) image lookup --address 0x1ec4

(lldb) im loo -a 0x1ec4

(gdb) info symbol 0x1ec4

Lookup information for an address in a.out only.

(lldb) image lookup --address 0x1ec4 a.out

(lldb) im loo -a 0x1ec4 a.out

Lookup information for for a type Point by name.

(lldb) image lookup --type Point

(lldb) im loo -t Point

(lldb) ptype Point

Dump all sections from the main executable and any shared libraries.

(lldb) image dump sections

(gdb) maintenance info sections

Dump all sections in the a.out module.

(lldb) image dump sections a.out

Dump all symbols from the main executable and any shared libraries.

(lldb) image dump symtab

Dump all symbols in a.out and liba.so.

(lldb) image dump symtab a.out liba.so

欢迎加群互相学习,共同进步。QQ群:iOS: 58099570 | Android: 330987132 | Go:217696290 | Python:336880185 | 做人要厚道,转载请注明出处!http://www.cnblogs.com/sunshine-anycall/archive/2012/02/19/2357801.html
你可能感兴趣的文章
移动端响应式
查看>>
python实现牛顿法求解求解最小值(包括拟牛顿法)【最优化课程笔记】
查看>>
js中var、let、const的区别
查看>>
腾讯云加入LoRa联盟成为发起成员,加速推动物联网到智联网的进化
查看>>
从Python2到Python3:超百万行代码迁移实践
查看>>
Windows Server已可安装Docker,Azure开始支持Mesosphere
查看>>
简洁优雅地实现夜间模式
查看>>
react学习总结
查看>>
微软正式发布PowerShell Core 6.0
查看>>
Amazon发布新的会话管理器
查看>>
InfoQ趋势报告:DevOps 和云计算
查看>>
舍弃Python,为什么知乎选用Go重构推荐系统?
查看>>
在soapui上踩过的坑
查看>>
MySQL的字符集和字符编码笔记
查看>>
ntpd同步时间
查看>>
must implement java.io.Serializable hessian
查看>>
Microsoft Licenses Flash Lite for Windows Mobile Users
查看>>
HDOJ 2020 绝对值排序
查看>>
HDOJ/HDU 2560 Buildings(嗯~水题)
查看>>
Maven编译时跳过Test
查看>>