From idasql
Connects to IDA databases (.idb/.i64) via idasql CLI/REPL/HTTP. Bootstraps analysis sessions with orientation queries, schema introspection, and skill routing.
How this skill is triggered — by the user, by Claude, or both
Slash command
/idasql:connectThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
- For canonical schema catalog: [references/schema-catalog.md](references/schema-catalog.md)
Use these commands first to avoid guessing behavior or schema:
# Single query
idasql -s database.i64 -q "SELECT * FROM welcome"
# Interactive REPL
idasql -s database.i64 -i
# Long-lived HTTP server for iterative analysis
idasql -s database.i64 --http 8081
# Query over HTTP
curl -X POST http://127.0.0.1:8081/query -d "SELECT name, size FROM funcs LIMIT 5"
Critical guardrails:
-s <db> (.idb / .i64).--write when you want edits persisted on exit..schema <table>PRAGMA table_xinfo(<table>); (or PRAGMA table_info(<table>);)SELECT * FROM welcome;.Canonical table/view formats live in references/schema-catalog.md.
pragma_table_list + pragma_table_xinfo).references/legacy-parity-matrix.mdreferences/optimization-checklist.mdManual refresh:
SELECT schema, name, type, ncol FROM pragma_table_list WHERE schema='main' ORDER BY type, name;PRAGMA table_xinfo(<surface>);references/schema-catalog.md owner mapping when surfaces change.Use this exact startup flow before deep analysis:
-s, -i, or --http).SELECT * FROM welcome;
SELECT COUNT(*) AS funcs FROM funcs;
SELECT COUNT(*) AS xrefs FROM xrefs;
SELECT COUNT(*) AS strings FROM strings;
PRAGMA table_xinfo(funcs);
PRAGMA table_xinfo(xrefs);
Never skip steps 2-4 when the user prompt is broad or ambiguous.
These contracts apply across all idasql skills and should be treated as one shared agent behavior model.
SELECT) before writes (INSERT/UPDATE/DELETE).address, func_addr, idx, label_num)..schema or PRAGMA table_xinfo(...) before issuing uncertain queries.decompile(..., 1) for decompiler surfaces).xrefs, instructions, ctree*, pseudocode) by key columns.func_addr = X unless explicitly asked for broad scans.no such table/column: introspect schema and retry.rebuild_strings()), and runtime capabilities.Use this deterministic mapping for initial routing:
| User intent | Primary skill | Typical first query |
|---|---|---|
| "what does this binary do?" / triage | analysis | SELECT * FROM entries; |
| disassembly, segments, instructions | disassembly | SELECT * FROM funcs LIMIT 20; |
| xrefs/callers/callees/import dependencies | xrefs | SELECT * FROM xrefs WHERE to_ea = ...; |
| find functions/types/labels/members by name pattern | grep | SELECT name, kind, address FROM grep WHERE pattern = 'main' LIMIT 20; |
| strings/bytes/pattern search | data | SELECT * FROM strings LIMIT 20; |
| decompile/pseudocode/ctree/lvars | decompiler | SELECT decompile(0x...); |
| comments/renames/retyping/bookmarks | annotations | SELECT ... on target row before update |
| type creation/struct/enum/member work | types | SELECT * FROM types LIMIT 20; |
| breakpoints/patching | debugger | SELECT * FROM breakpoints; |
| persistent key/value notes | storage | SELECT * FROM netnode_kv LIMIT 20; |
| SQL function lookup/signature recall | functions | SELECT * FROM pragma_function_list; |
| live IDA UI context questions | ui-context | SELECT get_ui_context_json(); (when available) |
| IDA SDK-only logic not in SQL surfaces | idapython | PRAGMA idasql.enable_idapython = 1; SELECT idapython_snippet('print(...)'); |
| recursive source/structure recovery | re-source | start from function + recurse/handoff |
When prompts span domains, execute in this order:
connectxrefs + decompiler + annotations)analysis: identify candidates from imports/strings/call patterns.xrefs/disassembly: map call graph and call sites.decompiler: inspect logic and variable semantics.annotations: apply comments/renames/types with mutation loop.data: locate candidate strings and addresses.xrefs: map references to caller functions.debugger or annotations: patch or annotate specific sites.decompiler: inspect lvars, call args, and ctree patterns.types: create/refine structs/enums and apply declarations.annotations: finalize naming/comments and verify rendered pseudocode.For prompts like "what am I looking at?", "what's selected?", "what is on the screen?", "look at what I'm doing", or references to "this/current/that", use the dedicated ui-context skill.
ui-context owns:
get_ui_context_json() capture/reuse policythis vs that)Runtime caveat:
get_ui_context_json() is plugin GUI runtime only, not idalib/CLI mode.Database orientation surface for quick session metadata. This is metadata-only and not a replacement for UI context capture.
| Column | Type | Description |
|---|---|---|
summary | TEXT | One-line database summary |
processor | TEXT | Processor/module name |
is_64bit | INT | 1=64-bit database, 0=32-bit |
min_ea | TEXT | Minimum address in database |
max_ea | TEXT | Maximum address in database |
start_ea | TEXT | Entry/start address |
entry_name | TEXT | Entry symbol name (if known) |
funcs_count | INT | Number of detected functions |
segments_count | INT | Number of segments |
names_count | INT | Number of named addresses |
SELECT * FROM welcome;
For canonical schema and owner mapping, see references/schema-catalog.md.
IDA Pro is the industry-standard disassembler and reverse engineering tool. It analyzes compiled binaries (executables, DLLs, firmware) and produces:
IDASQL exposes all this analysis data through SQL virtual tables, enabling:
Everything in a binary has an address - a memory location where code or data lives. IDA uses ea_t (effective address) as unsigned 64-bit integers. SQL shows these as integers; use printf('0x%X', address) for hex display.
Address-taking SQL functions accept:
'4198400', '0x401000')get_name_ea(BADADDR, name) (global names)Examples:
SELECT decompile('DriverEntry');
SELECT set_type('DriverEntry', 'NTSTATUS DriverEntry(PDRIVER_OBJECT, PUNICODE_STRING);');
SELECT comment_at('0x401000');
If a symbol cannot be resolved, SQL functions return an explicit error like:
Could not resolve name to address: <name>.
Local label lookup that depends on a specific from context is not consulted by default (BADADDR resolution). Use explicit numeric EAs when needed.
IDA groups code into functions with:
address / start_ea - Where the function beginsend_ea - Where it endsname - Assigned or auto-generated name (e.g., main, sub_401000)size - Total bytes in the functionThere will be addresses and disassembly listing not belonging to a function. IDASQL can still get the bytes, disassembly listing ranges, etc.
For single-EA disassembly (code or data), prefer disasm_at(ea[, context]) over function-scoped queries.
Binary analysis is about understanding relationships:
from_ea -> to_ea represents "address X references address Y"
Use table: xrefs(from_ea, to_ea, type, is_code).Use table: segments(start_ea, end_ea, name, class, perm).
Memory is divided into segments with different purposes. For example, a typical PE file, has these segments:
.text - Executable code (typically).data - Initialized global data.rdata - Read-only data (strings, constants).bss - Uninitialized dataOf course, segment names and types can vary. You may query the segments table to understand memory layout.
Within a function, basic blocks are straight-line code sequences:
blocks(start_ea, end_ea, func_ea, size).The Hex-Rays decompiler converts assembly to C-like pseudocode:
Core decompiler surfaces:
decompile(addr) (PRIMARY read/display surface)
/* 401010 */ .../* */ ... (no address anchor for that line)pseudocode table (structured/edit surface)
func_addr, ea, line_num) and comment writes keyed by ea + comment_placement.ea == func_addr.ctree and ctree_call_args for AST-level analysisctree_lvars for local variable rename/type/comment updatesSome tables have optimized filters that use efficient IDA SDK APIs:
| Table | Optimized Filter | Without Filter |
|---|---|---|
instructions | func_addr = X | O(all instructions) - SLOW |
blocks | func_ea = X | O(all blocks) |
xrefs | to_ea = X or from_ea = X | O(all xrefs) |
pseudocode | func_addr = X | Decompiles ALL functions |
ctree* | func_addr = X | Decompiles ALL functions |
Always filter decompiler tables by func_addr!
-- SLOW: String comparison
WHERE mnemonic = 'call'
-- FAST: Integer comparison
WHERE itype IN (16, 18) -- x86 call opcodes
-- SLOW: O(n) - sorts all rows
SELECT address FROM funcs ORDER BY RANDOM() LIMIT 1;
-- FAST: O(1) - direct index access
SELECT func_at_index(ABS(RANDOM()) % func_qty());
For instruction lifecycle edits, use a CTE to identify precise targets first, then mutate:
WITH target AS (
SELECT address
FROM instructions
WHERE func_addr = 0x401000
ORDER BY address DESC
LIMIT 1
)
DELETE FROM instructions
WHERE address IN (SELECT address FROM target);
SELECT make_code_range(address, end_ea) FROM funcs WHERE address = 0x401000;
This keeps mutation scope explicit and predictable for both humans and agents.
| Goal | Table/Function |
|---|---|
| List all functions | funcs |
| Functions by return type | funcs WHERE return_is_integral = 1 |
| Functions by arg count | funcs WHERE arg_count >= N |
| Void functions | funcs WHERE return_is_void = 1 |
| Pointer-returning functions | funcs WHERE return_is_ptr = 1 |
| Functions by calling convention | funcs WHERE calling_conv = 'fastcall' |
| Find who calls what | xrefs with is_code = 1 |
| Find data references | xrefs with is_code = 0 |
| Analyze imports | imports |
| Find strings | strings |
| Configure string types | rebuild_strings(types, minlen) |
| Instruction analysis | instructions WHERE func_addr = X |
| Recreate deleted instructions | make_code(addr), make_code_range(start, end) |
| Create function at EA | INSERT INTO funcs(address) VALUES (...) |
| View function disassembly | disasm_func(addr) or disasm_range(start, end) |
| View decompiled code | decompile(addr) |
| UI/screen context questions | ui-context skill (get_ui_context_json(), plugin UI only) |
| Edit decompiler comments | Resolve writable anchor, then UPDATE pseudocode SET comment = '...' WHERE func_addr = X AND ea = Y |
| AST pattern matching | ctree WHERE func_addr = X |
| Call patterns | ctree_v_calls, disasm_calls |
| Control flow | ctree_v_loops, ctree_v_ifs |
| Return value analysis | ctree_v_returns |
| Functions returning specific values | ctree_v_returns WHERE return_num = 0 |
| Pass-through functions | ctree_v_returns WHERE returns_arg = 1 |
| Wrapper functions | ctree_v_returns WHERE returns_call_result = 1 |
| Variable analysis | ctree_lvars WHERE func_addr = X |
| Type information | types, types_members |
| Function signatures | types_func_args (with type classification) |
| Functions by return type | types_func_args WHERE arg_index = -1 |
| Typedef-aware type queries | types_func_args (surface vs resolved) |
| Hidden pointer types | types_func_args WHERE is_ptr = 0 AND is_ptr_resolved = 1 |
| Manage breakpoints | breakpoints (full CRUD) |
| Modify segments | segments (INSERT/UPDATE/DELETE) |
| Rename decompiler labels | rename_label(...) or UPDATE ctree_labels SET name=... |
| Delete instructions | instructions (DELETE converts to unexplored bytes) |
| Recreate instructions | make_code, make_code_range |
| Bulk patch from file bytes | load_file_bytes(path, file_offset, address, size[, patchable]) |
| EA to physical offset mapping | bytes.fpos (NULL means unmapped) |
| Create types | types (INSERT struct/union/enum) |
| Add struct members | types_members (INSERT) |
| Add enum values | types_enum_values (INSERT) |
| Modify database | funcs, names, comments, bookmarks (INSERT/UPDATE/DELETE) |
| Store custom key-value data | netnode_kv (full CRUD, persists in IDB) |
| Entity search (structured) | grep skill + grep WHERE pattern = '...' |
| Entity search (JSON) | grep skill + grep('pattern', limit, offset) |
Remember: Always use func_addr = X constraints on instruction and decompiler tables for acceptable performance.
pseudocode, ctree*, ctree_lvars) will be empty or unavailablefunc_at(addr) return NULLnpx claudepluginhub allthingsida/idasql-skills --plugin idasqlCatalogs complete idasql SQL functions for disassembly, byte access/patching, and binary search in IDA databases. Use to look up signatures, parameters, and usage examples.
Analyzes binaries using IDA Pro's Domain API: program structure, functions, disassembly, cross-references, and strings. Provides Pythonic API usage, database opening, and configuration options for headless analysis.
Executes Python scripts using the IDA Domain API for binary analysis and reverse engineering. Extracts functions, strings, cross-references, decompiles code, and automates IDA Pro tasks.