Sequence of instructions that is always entered at the top and exited at the bottom by a fall through and/or taken branch. If Pin detects a jump to an instruction in the middle of a bbl, it will create a new bbl beginning at the target. See Instrumentation Granularity.
◆ BBL_Address()
ADDRINT BBL_Address |
( |
BBL |
bbl | ) |
|
- Returns
- Address of a bbl
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_HasFallThrough()
BOOL BBL_HasFallThrough |
( |
BBL |
bbl | ) |
|
Refer to INS_HasFallThrough for checking if an instruction could have a fall-through path based on the opcode.
- Returns
- TRUE if the BBL has a fall-through bbl within the trace, else returns FALSE.
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_InsertCall()
VOID BBL_InsertCall |
( |
BBL |
bbl, |
|
|
IPOINT |
action, |
|
|
AFUNPTR |
funptr, |
|
|
|
... |
|
) |
| |
Insert call relative to a bbl.
- Parameters
-
- Availability:
- Mode: JIT
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_InsertIfCall()
VOID BBL_InsertIfCall |
( |
BBL |
bbl, |
|
|
IPOINT |
action, |
|
|
AFUNPTR |
funptr, |
|
|
|
... |
|
) |
| |
Insert a call to funptr relative to a BBL. If funptr returns a non-zero ADDRINT, then the immediately following "then" analysis call is executed. Note that if CALL_ORDER is used, Both "if" and "then" analysis calls must have the same order.
- Parameters
-
bbl | BBL to instrument |
action | Specifies when the analysis call executes. See the documentation in BBL_InsertCall(). |
funptr | Analysis function to call. Its return type must be ADDRINT |
... | IARG_TYPE. Arguments to pass to funptr |
- Availability:
- Mode: JIT
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_InsertThenCall()
VOID BBL_InsertThenCall |
( |
BBL |
bbl, |
|
|
IPOINT |
action, |
|
|
AFUNPTR |
funptr, |
|
|
|
... |
|
) |
| |
Insert a call to funptr relative to a BBL. The function is called only if the immediately preceding "if" analysis call returns a non-zero value. Note that if CALL_ORDER is used, Both "if" and "then" analysis calls must have the same order.
- Parameters
-
bbl | BBL to instrument |
action | Specifies when the analysis call executes. See the documentation in BBL_InsertCall(). |
funptr | Analysis function to call |
... | IARG_TYPE. Arguments to pass to funptr |
- Availability:
- Mode: JIT
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_InsHead()
- Returns
- First instruction of bbl
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_InsTail()
- Returns
- Last instruction of bbl
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_Next()
- Returns
- Next bbl or BBL_INVALID() if this is the end of trace or rtn
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_NumIns()
UINT32 BBL_NumIns |
( |
BBL |
bbl | ) |
|
◆ BBL_Original()
BOOL BBL_Original |
( |
BBL |
bbl | ) |
|
- Returns
- Whether the BBL data structure has been instrumented or optimized since it was created
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_Prev()
- Returns
- Previous bbl or BBL_INVALID() if this is the beginning of trace or rtn
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_Size()
USIZE BBL_Size |
( |
BBL |
bbl | ) |
|
- Returns
- Size of bbl code, in bytes
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All
◆ BBL_Valid()
- Returns
- True if x is not BBL_INVALID()
- Availability:
- Mode: JIT & Probe
O/S: Linux, Windows & macOS*
CPU: All