debugger.debuggercontroller module¶
|
DebugBreakpoint represents a breakpoint in the target. |
DebugFrame represents a frame in the stack trace. |
|
DebugModule represents a module in the target. |
|
DebugProcess represents a process in the target. |
|
DebugRegister represents a register in the target. |
|
|
DebugRegisters represents all registers of the target. |
DebugThread represents a thread in the target. |
|
|
The |
DebuggerEvent is the event object that a debugger event callback receives |
|
|
DebuggerEventData is the collection of all possible data associated with the debugger events |
|
|
ErrorEventData is the data associated with a ErrorEvent |
|
|
ModuleNameAndOffset represents an address that is relative to the start of module. |
|
StdOutMessageEventData is the data associated with a StdOutMessageEvent |
|
TargetExitedEventData is the data associated with a TargetExitedEvent |
|
TargetStoppedEventData is the data associated with a TargetStoppedEvent |
- class DebugBreakpoint(module, offset, address, enabled)[source]¶
Bases:
object
DebugBreakpoint represents a breakpoint in the target. It has the following fields:
module
: the name of the module for which the breakpoint is inoffset
: the offset of the breakpoint to the start of the moduleaddress
: the absolute address of the breakpointenabled
: not used
- class DebugFrame(index, pc, sp, fp, func_name, func_start, module)[source]¶
Bases:
object
DebugFrame represents a frame in the stack trace. It has the following fields:
index
: the index of the framepc
: the program counter of the framesp
: the stack pointer of the framefp
: the frame pointer of the framefunc_name
: the function name which the pc is infunc_start
: the start of the functionmodule
: the module of the pc
- class DebugModule(name, short_name, address, size, loaded)[source]¶
Bases:
object
DebugModule represents a module in the target. It has the following fields:
name
: the path of the moduleshort_name
: the name of the moduleaddress
: the base load address of the modulesize
: the size of the moduleloaded
: not used
- class DebugProcess(pid, name)[source]¶
Bases:
object
DebugProcess represents a process in the target. It has the following fields:
pid
: the ID of the processname
: the name of the process
- class DebugRegister(name, value, width, index, hint)[source]¶
Bases:
object
DebugRegister represents a register in the target. It has the following fields:
name
: the name of the registervalue
: the value of the registerwidth
: the width of the register, in bits. E.g.,rax
register is 64-bits wideindex
: the index of the register. This is reported by the DebugAdapter and should remain unchangedhint
: a string that shows the content of the memory pointed to by the register. It is empty if the register value do not point to a valid (mapped) memory region
- class DebugRegisters(handle)[source]¶
Bases:
object
DebugRegisters represents all registers of the target.
- class DebugThread(tid, rip)[source]¶
Bases:
object
DebugThread represents a thread in the target. It has the following fields:
tid
: the ID of the thread. On different systems, this may be either the system thread ID, or a sequential index starting from zero.rip
: the current address (instruction pointer) of the thread
In the future, we should provide both the internal thread ID and the system thread ID.
- class DebuggerController(bv: BinaryView)[source]¶
Bases:
object
The
DebuggerController
object is the core of the debugger. Most debugger operations can be performed on it. It takes in aBinaryView
and creates a debugger for it. If a debugger is already existing for the very same BinaryView object, the debugger is returned.Most operations of the debugger are performed on this class. For example, we can launch the debugger as follows:
>>> bv = load("test/binaries/helloworld") >>> dbg = DebuggerController(bv) >>> dbg.launch() True
When the
launch()
returns True, it means the debugger has launched the target successfully. The target breaks at the entry point of the binary. Now we can perform other control operations on it, e.g., resume the target by callinggo()
.>>> dbg.go() <DebugStopReason.ProcessExited: 2>
Since there are no other breakpoints in the target, the process executes and then exits.
All target control functions, e.g.,
go()
,step_into()
, etc, are blocking. They will not return until the target breaks. In the future, we will switch to an asynchronous communication model where these functions return before the operation is performed.Starting from 4.1.5542-dev (0ad6b08b), the debugger no longer involves two binary views during debugging. Instead, it always uses the incoming binary view that is used to create the controller, and memory regions that are not present in the original binary view are represented using the new MemoryRegion API. The binary view can be accessed by the
data
property.- Parameters:
bv (BinaryView) –
- add_breakpoint(address)[source]¶
Add a breakpoint
The input can be either an absolute address, or a ModuleNameAndOffset, which specifies a relative address to the start of a module. The latter is useful for ASLR.
- Parameters:
address – the address of breakpoint to add
- attach() bool [source]¶
Attach to a running process
The PID of the target process must be set via DebuggerState.pid_attach
- Return type:
- attach_and_wait() DebugStopReason [source]¶
Attach to a running process and wait until all debugger events are processed
The PID of the target process must be set via DebuggerState.pid_attach
- Return type:
- connect() bool [source]¶
Connect to a remote target (process)
The host and port of the remote target must first be specified by setting remote_host and remote_port
- Return type:
- connect_and_wait() DebugStopReason [source]¶
Connect to a remote target (process) and wait for all debugger events to be processed
The host and port of the remote target must first be specified by setting remote_host and remote_port
- Return type:
- connect_to_debug_server() bool [source]¶
Connect to a debug server.
The host and port of the debug server must first be specified by setting remote_host and remote_port
- Return type:
- delete_breakpoint(address)[source]¶
Delete a breakpoint
The input can be either an absolute address, or a ModuleNameAndOffset, which specifies a relative address to the start of a module. The latter is useful for ASLR.
- Parameters:
address – the address of breakpoint to delete
- destroy()[source]¶
Delete the DebuggerController object. Intended for internal use. Ordinary users do not need to call it.
- execute_backend_command(command: str | bytes) str [source]¶
Execute a backend command and get the output
For LLDB adapter, any LLDB commands can be executed. The returned string is what gets printed if one executes the command in the LLDB prompt.
For DbgEnd adapter, any WinDbg commands can be executed. The returned string is what gets printed if one executes the command in WinDbg.
- frames_of_thread(tid: int) List[DebugFrame] [source]¶
Get the stack frames of the thread specified by
tid
- Parameters:
tid (int) – thread id
- Returns:
list of stack frames
- Return type:
- go() bool [source]¶
Resume the target.
The call is asynchronous and returns before the target stops.
- Returns:
whether the operation is successfully requested
- Return type:
- go_and_wait() DebugStopReason [source]¶
Resume the target.
The call is blocking and only returns when the target stops.
- Returns:
the reason for the stop
- Return type:
- go_reverse() bool [source]¶
Resume the target in reverse.
The call is asynchronous and returns before the target stops.
- Returns:
whether the operation is successfully requested
- Return type:
- go_reverse_and_wait() DebugStopReason [source]¶
Resume the target in reverse.
The call is blocking and only returns when the target stops.
- Returns:
the reason for the stop
- Return type:
- has_breakpoint(address) bool [source]¶
Checks whether a breakpoint exists at the specified address
The input can be either an absolute address, or a ModuleNameAndOffset, which specifies a relative address to the start of a module. The latter is useful for ASLR.
- Parameters:
address – the address of breakpoint to query
- Return type:
- launch_and_wait() DebugStopReason [source]¶
Launch the target and wait for all debugger events to be processed
- Return type:
- launch_or_connect() None [source]¶
Launch or connect to the target. Intended for internal use. Ordinary users do not need to call it.
- Return type:
None
- pause_and_wait() None [source]¶
Pause a running target.
The call is blocking and only returns when the target stops.
- Return type:
None
- quit_and_wait() None [source]¶
Terminate the target, and wait for all callback to be called
- Return type:
None
- read_memory(address: int, size: int) DataBuffer [source]¶
Read memory from the target.
One can also get the
data
BinaryView of the DebuggerController, and use ordinary read methods to read its content.- Parameters:
- Returns:
always returns a DataBuffer. When the operation fails, the size of the DataBuffer is 0x0
- Return type:
- register_event_callback(callback: Callable[[DebuggerEvent], None], name: str | bytes = '') int [source]¶
Register a debugger event callback to receive notification when various events happen.
The callback receives DebuggerEvent object that contains the type of the event and associated data.
- Parameters:
callback (Callable[[DebuggerEvent], None]) – the callback to register
- Returns:
an integer handle to the registered event callback
- Return type:
- remove_event_callback(index: int)[source]¶
Remove the debugger event callback from the DebuggerController
- Parameters:
index (int) –
- restart_and_wait() None [source]¶
Restart a running target.
The call is blocking and only returns when the target stops again after the restart.
- Return type:
None
- run_to(address) bool [source]¶
Resume the target, and wait for it to break at the given address(es).
The address parameter can be either an integer, or a list of integers.
Internally, the debugger places breakpoints on these addresses, resume the target, and wait for the target to break. Then the debugger removes the added breakpoints.
The call is asynchronous and returns before the target stops.
- Returns:
whether the operation is successfully requested
- Return type:
- run_to_and_wait(address) DebugStopReason [source]¶
Resume the target, and wait for it to break at the given address(es).
The address parameter can be either an integer, or a list of integers.
Internally, the debugger places breakpoints on these addresses, resume the target, and wait for the target to break. Then the debugger removes the added breakpoints.
The call is blocking and only returns when the target stops.
- Returns:
the reason for the stop
- Return type:
- set_adapter_property(name: str | bytes, value: Metadata | int | bool | str | bytes | float | List[MetadataValueType] | Tuple[MetadataValueType] | dict) bool [source]¶
- step_into(il: FunctionGraphType = FunctionGraphType.NormalFunctionGraph) bool [source]¶
Perform a step into on the target.
When the next instruction is not a call, execute the next instruction. When the next instruction is a call, follow the call the get into the first instruction of the call.
The operation can be performed on an IL level specified by the
il
parameter, which then either executes the next IL instruction, or follow into the IL function. Note, the underlying operation is still performed at the disassembly level because that is the only thing a debugger understands. The high-level operations are simulated on top of the disassembly and analysis.Some limitations are known with stepping into on IL.
The call is asynchronous and returns before the target stops.
- Parameters:
il (FunctionGraphType) – optional IL level to perform the operation at
- Returns:
whether the operation is successfully requested
- Return type:
- step_into_and_wait(il: FunctionGraphType = FunctionGraphType.NormalFunctionGraph) DebugStopReason [source]¶
Perform a step into on the target in reverse.
When the next instruction is not a call, execute the next instruction. When the next instruction is a call, follow the call the get into the first instruction of the call.
The operation can be performed on an IL level specified by the
il
parameter, which then either executes the next IL instruction, or follow into the IL function. Note, the underlying operation is still performed at the disassembly level because that is the only thing a debugger understands. The high-level operations are simulated on top of the disassembly and analysis.Some limitations are known with stepping into on IL.
The call is blocking and only returns when the target stops.
- Parameters:
il (FunctionGraphType) – optional IL level to perform the operation at
- Returns:
the reason for the stop
- Return type:
- step_into_reverse(il: FunctionGraphType = FunctionGraphType.NormalFunctionGraph) bool [source]¶
Perform a step into on the target in reverse.
When the previous instruction is not a call, step backwards. When the previous instruction is a call, follow the call into the last instruction of the function.
The operation can be performed on an IL level specified by the
il
parameter, which then either executes the next IL instruction, or follow into the IL function. Note, the underlying operation is still performed at the disassembly level because that is the only thing a debugger understands. The high-level operations are simulated on top of the disassembly and analysis.Some limitations are known with stepping into on IL.
The call is asynchronous and returns before the target stops.
- Parameters:
il (FunctionGraphType) – optional IL level to perform the operation at
- Returns:
whether the operation is successfully requested
- Return type:
- step_into_reverse_and_wait(il: FunctionGraphType = FunctionGraphType.NormalFunctionGraph) DebugStopReason [source]¶
Perform a reverse step into on the target.
When the previous instruction is not a call, reverse the program to the previous state. When the previous instruction is a call, follow the call to get into the last instruction of the call.
The operation can be performed on an IL level specified by the
il
parameter, which then either reverses the current IL instruction, or follow into the previous IL function. Note, the underlying operation is still performed at the disassembly level because that is the only thing a debugger understands. The high-level operations are simulated on top of the disassembly and analysis.Some limitations are known with stepping into on IL.
The call is blocking and only returns when the target stops.
- Parameters:
il (FunctionGraphType) – optional IL level to perform the operation at
- Returns:
the reason for the stop
- Return type:
- step_over(il: FunctionGraphType = FunctionGraphType.NormalFunctionGraph) bool [source]¶
Perform a step over on the target.
When the next instruction is not a call, execute the next instruction. When the next instruction is a call, complete the execution of the function and break at next instruction.
The operation can be performed on an IL level specified by the
il
parameter, which then either executes the next IL instruction, or completes the IL function. Note, the underlying operation is still performed at the disassembly level because that is the only thing a debugger understands. The high-level operations are simulated on top of the disassembly and analysis.Some limitations are known with stepping over on IL.
The call is asynchronous and returns before the target stops.
- Parameters:
il (FunctionGraphType) – optional IL level to perform the operation at
- Returns:
whether the operation is successfully requested
- Return type:
- step_over_and_wait(il: FunctionGraphType = FunctionGraphType.NormalFunctionGraph) DebugStopReason [source]¶
Perform a step over on the target.
When the next instruction is not a call, execute the next instruction. When the next instruction is a call, complete the execution of the function and break at next instruction.
The operation can be performed on an IL level specified by the
il
parameter, which then either executes the next IL instruction, or completes the IL function. Note, the underlying operation is still performed at the disassembly level because that is the only thing a debugger understands. The high-level operations are simulated on top of the disassembly and analysis.Some limitations are known with stepping over on IL.
The call is blocking and only returns when the target stops.
- Parameters:
il (FunctionGraphType) – optional IL level to perform the operation at
- Returns:
the reason for the stop
- Return type:
- step_over_reverse(il: FunctionGraphType = FunctionGraphType.NormalFunctionGraph) bool [source]¶
Perform a step over on the target in reverse.
When the previous instruction is not a call, step backwards. When the previous instruction is a call, step back over the call.
The operation can be performed on an IL level specified by the
il
parameter, which then either executes the next IL instruction, or completes the IL function. Note, the underlying operation is still performed at the disassembly level because that is the only thing a debugger understands. The high-level operations are simulated on top of the disassembly and analysis.Some limitations are known with stepping over on IL.
The call is asynchronous and returns before the target stops.
- Parameters:
il (FunctionGraphType) – optional IL level to perform the operation at
- Returns:
whether the operation is successfully requested
- Return type:
- step_over_reverse_and_wait(il: FunctionGraphType = FunctionGraphType.NormalFunctionGraph) DebugStopReason [source]¶
Perform a step over on the target in reverse.
When the next instruction is not a call, execute the next instruction. When the next instruction is a call, complete the execution of the function and break at next instruction.
The operation can be performed on an IL level specified by the
il
parameter, which then either executes the next IL instruction, or completes the IL function. Note, the underlying operation is still performed at the disassembly level because that is the only thing a debugger understands. The high-level operations are simulated on top of the disassembly and analysis.Some limitations are known with stepping over on IL.
The call is blocking and only returns when the target stops.
- Parameters:
il (FunctionGraphType) – optional IL level to perform the operation at
- Returns:
the reason for the stop
- Return type:
- step_return() bool [source]¶
Perform a step return on the target.
Step return completes the execution of the current function and returns to its caller. This operation relies heavily on stack frame analysis, which is done by the DebugAdapters.
If a DebugAdapter does not support (i.e., overload) this function, a fallback handling is provided by the DebuggerController. It checks the MLIL function and put breakpoints on all returning instructions and then resume the target. By the time it breaks, the target is about to return from the current function.
This fallback behavior is slightly different from that offered by the LLDB and DbgEng adapter, which returns from the current function and break afterwards.
The call is asynchronous and returns before the target stops.
- Returns:
whether the operation is successfully requested
- Return type:
- step_return_and_wait() DebugStopReason [source]¶
Perform a step return on the target.
Step return completes the execution of the current function and returns to its caller. This operation relies heavily on stack frame analysis, which is done by the DebugAdapters.
If a DebugAdapter does not support (i.e., overload) this function, a fallback handling is provided by the DebuggerController. It checks the MLIL function and put breakpoints on all returning instructions and then resume the target. By the time it breaks, the target is about to return from the current function.
This fallback behavior is slightly different from that offered by the LLDB and DbgEng adapter, which returns from the current function and break afterwards.
The call is blocking and only returns when the target stops.
- Returns:
the reason for the stop
- Return type:
- step_return_reverse() bool [source]¶
Perform a step return on the target in reverse.
Step return reverses the execution of the current function and returns to its caller. This operation relies heavily on stack frame analysis, which is done by the DebugAdapters.
If a DebugAdapter does not support (i.e., overload) this function, a fallback handling is provided by the DebuggerController. It checks the MLIL function and put breakpoints on all returning instructions and then resume the target. By the time it breaks, the target is about to return from the current function.
This fallback behavior is slightly different from that offered by the LLDB and DbgEng adapter, which returns from the current function and break afterwards.
The call is asynchronous and returns before the target stops.
- Returns:
whether the operation is successfully requested
- Return type:
- write_memory(address: int, buffer) bool [source]¶
Write memory of the target.
One can also get the
data
BinaryView of the DebuggerController, and use ordinary write methods to write its content.
- write_stdin(data: str | bytes) None [source]¶
Write to the stdin of the target. Only works on Linux and macOS.
- property active_thread: DebugThread¶
The active thread of the target. (read/write)
- Getter:
returns the active thread of the target
- Setter:
sets the active thread of the target
- property adapter_type: str¶
The name for the current DebugAdapter. (read/write)
- Getter:
returns the name of the current DebugAdapter
- Setter:
sets the DebugAdapter to use
- property breakpoints: List[DebugBreakpoint]¶
The list of breakpoints
- property cmd_line: str¶
The command line arguments of the target. (read/write)
This can be set before launching the target to specify the command line arguments. The arguments are supplied as a single string. The string is NOT shell expanded, which means the user must properly escape it if needed.
- Getter:
returns the command line arguments
- Setter:
sets the command line arguments
- property connection_status: DebugAdapterConnectionStatus¶
Get the connection status of the debugger
- property data: BinaryView¶
Get the (rebased) BinaryView of the debugger
- property executable_path: str¶
The path of the executable. (read/write)
This can be set before launching the target. Be default, it is the path of the FileMetadata (
bv.file.filename
)- Getter:
returns the executable path
- Setter:
sets the executable path
- property exit_code: int¶
The exit code of the target (read-only)
This is only meaningful after the target has executed and exited.
- property input_file: str¶
The input file used to create the database
This should be set before launching the target. Be default, it is the path of the FileMetadata (
bv.file.filename
)- Getter:
returns the input file path
- Setter:
sets the input file path
- property ip: int¶
The IP (instruction pointer) of the target
For x86_64, it returns the value of
rip
register.For x86, it returns the value of
eip
register.For armv7/aarch64, or any other architecture that is not native to BN, it returns the value of
pc
register.
- property is_first_launch¶
- property is_ttd¶
- property live_view: BinaryView¶
Get the live BinaryView of the debugger
Deprecated since version 4.1.5542: Debugger no longer uses the live view, Use
data
instead
- property modules: List[DebugModule]¶
The modules of the target
- Returns:
a list of
DebugModule
- property pid_attach: int¶
The remote port to connect to. (read/write)
remote_host
andremote_port
are only useful for remote debugging.- Getter:
returns the remote port
- Setter:
sets the remote port
- property processes: List[DebugProcess]¶
The processes of the target.
- property regs: DebugRegisters¶
All registers of the target
- Returns:
a list of
DebugRegister
- property remote_arch: Architecture¶
Get the architecture of the running target (read-only). This could be different from the architecture of the original binary.
- property remote_host: str¶
The remote host to connect to. (read/write)
remote_host
andremote_port
are only useful for remote debugging.- Getter:
returns the remote host
- Setter:
sets the remote host
- property remote_port: int¶
The remote port to connect to. (read/write)
remote_host
andremote_port
are only useful for remote debugging.- Getter:
returns the remote port
- Setter:
sets the remote port
- property request_terminal_emulator: bool¶
Whether to run the target in a separate terminal. (read/write)
The default value is false.
This can be set before launching the target to configure whether the target should be executed in a separate terminal. On Linux and macOS, when set, the target runs in its own terminal and the DebuggerController cannot receive notification of stdout output, or write to its stdin. All input/output must be performed in the target’s console. On Windows, this option has no effect and the target always runs in its own terminal.
- Getter:
returns whether to run the target in a separate terminal
- Setter:
sets whether to run the target in a separate terminal
- property stop_reason: DebugStopReason¶
The reason for the target to stop
This is the same value to the return value of the function that resumed the target, e.g.,
go()
- property target_status: DebugAdapterTargetStatus¶
Get the status of the target
- property threads: List[DebugThread]¶
The threads of the target.
- property working_directory: str¶
The path of the target. (read/write)
This can be set before launching the target to configure a working directory. Be default, it is the path of the binaryninja executable. In the future, we will change the default working directory to the folder that the executable is in.
- Getter:
returns the working directory
- Setter:
sets the working directory
- class DebuggerEvent(type: DebuggerEventType, data: DebuggerEventData)[source]¶
Bases:
object
DebuggerEvent is the event object that a debugger event callback receives
type
: a DebuggerEventType that specifies the event typedata
: a DebuggerEventData that specifies the event data
- Parameters:
type (DebuggerEventType) –
data (DebuggerEventData) –
- class DebuggerEventData(target_stopped_data: TargetStoppedEventData, error_data: ErrorEventData, absolute_address: int, relative_address: ModuleNameAndOffset, exit_data: TargetExitedEventData, message_data: StdOutMessageEventData)[source]¶
Bases:
object
DebuggerEventData is the collection of all possible data associated with the debugger events
target_stopped_data
: the data associated with a TargetStoppedEventerror_data
: the data associated with an ErrorEventabsolute_address
: an integer address, which is used when an absolute breakpoint is added/removedrelative_address
: a ModuleNameAndOffset, which is used when a relative breakpoint is added/removedexit_data
: the data associated with a TargetExitedEventmessage_data
: message data, used by both StdOutMessageEvent and BackendMessageEvent
- Parameters:
target_stopped_data (TargetStoppedEventData) –
error_data (ErrorEventData) –
absolute_address (int) –
relative_address (ModuleNameAndOffset) –
exit_data (TargetExitedEventData) –
message_data (StdOutMessageEventData) –
- class DebuggerEventWrapper[source]¶
Bases:
object
- classmethod register(controller: DebuggerController, callback: Callable[[DebuggerEvent], None], name: str | bytes) int [source]¶
- Parameters:
controller (DebuggerController) –
callback (Callable[[DebuggerEvent], None]) –
- Return type:
- classmethod remove(controller: DebuggerController, index: int) None [source]¶
- Parameters:
controller (DebuggerController) –
index (int) –
- Return type:
None
- class ErrorEventData(error: str, data)[source]¶
Bases:
object
ErrorEventData is the data associated with a ErrorEvent
error
: the error messagedata
: extra data. Not used.
- Parameters:
error (str) –
- class ModuleNameAndOffset(module, offset)[source]¶
Bases:
object
ModuleNameAndOffset represents an address that is relative to the start of module. It is useful when ASLR is on.
module
: the name of the module for which the address is inoffset
: the offset of the address to the start of the module
- class StdOutMessageEventData(message: str)[source]¶
Bases:
object
StdOutMessageEventData is the data associated with a StdOutMessageEvent
message
: the message that the target writes to the stdout
- Parameters:
message (str) –
- class TargetExitedEventData(exit_code: int)[source]¶
Bases:
object
TargetExitedEventData is the data associated with a TargetExitedEvent
exit_code
: the exit code of the target
- Parameters:
exit_code (int) –
- class TargetStoppedEventData(reason: DebugStopReason, last_active_thread: int, exit_code: int, data)[source]¶
Bases:
object
TargetStoppedEventData is the data associated with a TargetStoppedEvent
reason
: the reason of the stoplast_active_thread
: not usedexit_code
: not useddata
: extra data. Not used.
- Parameters:
reason (DebugStopReason) –
last_active_thread (int) –
exit_code (int) –