🛠️ Zeroize監査
C/C++/Rustのソースコードから、秘密鍵やパスワードなどの機密データが適切に消去されていない箇所や、コンパイラの最適化によって消去処理が削除された箇所を、アセンブリレベルで解析・検証し検出するSkill。
📺 まず動画で見る(YouTube)
▶ 【衝撃】最強のAIエージェント「Claude Code」の最新機能・使い方・プログラミングをAIで効率化する超実践術を解説! ↗
※ jpskill.com 編集部が参考用に選んだ動画です。動画の内容と Skill の挙動は厳密には一致しないことがあります。
📜 元の英語説明(参考)
Detects missing zeroization of sensitive data in source code and identifies zeroization removed by compiler optimizations, with assembly-level analysis, and control-flow verification. Use for auditing C/C++/Rust code handling secrets, keys, passwords, or other sensitive data.
🇯🇵 日本人クリエイター向け解説
C/C++/Rustのソースコードから、秘密鍵やパスワードなどの機密データが適切に消去されていない箇所や、コンパイラの最適化によって消去処理が削除された箇所を、アセンブリレベルで解析・検証し検出するSkill。
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o zeroize-audit.zip https://jpskill.com/download/3742.zip && unzip -o zeroize-audit.zip && rm zeroize-audit.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/3742.zip -OutFile "$d\zeroize-audit.zip"; Expand-Archive "$d\zeroize-audit.zip" -DestinationPath $d -Force; ri "$d\zeroize-audit.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
zeroize-audit.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
zeroize-auditフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-17
- 取得日時
- 2026-05-17
- 同梱ファイル
- 1
💬 こう話しかけるだけ — サンプルプロンプト
- › Zeroize Audit を使って、最小構成のサンプルコードを示して
- › Zeroize Audit の主な使い方と注意点を教えて
- › Zeroize Audit を既存プロジェクトに組み込む方法を教えて
これをClaude Code に貼るだけで、このSkillが自動発動します。
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
[Skill 名] zeroize-audit
zeroize-audit — Claude Skill
使用する場面
- 暗号実装(鍵、シード、ノンス、シークレット)の監査
- 認証システム(パスワード、トークン、セッションデータ)のレビュー
- PIIまたは機密性の高い認証情報を扱うコードの分析
- セキュリティ上重要なコードベースにおける安全なクリーンアップの検証
- 機密データの取り扱いにおけるメモリ安全性の調査
使用しない場面
- セキュリティに焦点を当てない一般的なコードレビュー
- パフォーマンス最適化(安全なワイピングに関連する場合を除く)
- 機密データに関連しないリファクタリングタスク
- 識別可能なシークレットや機密値を含まないコード
目的
ソースコードにおける機密データのゼロ化の欠落を検出し、コンパイラ最適化(例:デッドストア除去)によってゼロ化が削除または弱められている箇所を、必須のLLVM IR/asmエビデンスとともに特定します。機能は以下の通りです。
- レジスタスピルとスタック保持のためのアセンブリレベル分析
- シークレットコピーのデータフロー追跡
- ヒープアロケータのセキュリティ警告
- ループアンローリングとSSA形式のためのセマンティックIR分析
- パスカバレッジ検証のための制御フローグラフ分析
- ランタイム検証テストの生成
スコープ
- ターゲットコードベースに対する読み取り専用(監査対象コードは変更しません。分析成果物を一時的な作業ディレクトリに書き込みます)。
- 構造化されたレポート(JSON)を生成します。
- 有効なビルドコンテキスト(
compile_commands.json)とコンパイル可能な翻訳単位が必要です。 - 「最適化によって削除された」という発見は、コンパイラのエビデンス(IR/asm diff)がある場合にのみ許可されます。
入力
完全なスキーマについては、{baseDir}/schemas/input.json を参照してください。主要なフィールドは以下の通りです。
| フィールド | 必須 | デフォルト | 説明 |
|---|---|---|---|
path |
はい | — | リポジトリのルート |
compile_db |
いいえ | null |
C/C++分析のための compile_commands.json へのパス。cargo_manifest が設定されていない場合、必須です。 |
cargo_manifest |
いいえ | null |
Rustクレート分析のための Cargo.toml へのパス。compile_db が設定されていない場合、必須です。 |
config |
いいえ | — | ヒューリスティックと承認されたワイプを定義するYAML |
opt_levels |
いいえ | ["O0","O1","O2"] |
IR比較のための最適化レベル。O1は診断レベルです。O1でワイプが消える場合は単純なDSEです。O2はより積極的な除去を捕捉します。 |
languages |
いいえ | ["c","cpp","rust"] |
分析する言語 |
max_tus |
いいえ | — | コンパイルDBから処理される翻訳単位の制限 |
mcp_mode |
いいえ | prefer |
off、prefer、または require — Serena MCPの使用を制御します。 |
mcp_required_for_advanced |
いいえ | true |
MCPが利用できない場合、SECRET_COPY、MISSING_ON_ERROR_PATH、および NOT_DOMINATING_EXITS を needs_review にダウングレードします。 |
mcp_timeout_ms |
いいえ | — | MCPセマンティッククエリのタイムアウト予算 |
poc_categories |
いいえ | 全11の悪用可能なカテゴリ | PoCを生成する発見カテゴリ。C/C++の発見:全11カテゴリがサポートされています。Rustの発見:MISSING_SOURCE_ZEROIZE、SECRET_COPY、および PARTIAL_WIPE のみがサポートされています。その他のRustカテゴリは poc_supported=false とマークされます。 |
poc_output_dir |
いいえ | generated_pocs/ |
生成されたPoCの出力ディレクトリ |
enable_asm |
いいえ | true |
アセンブリの出力と分析を有効にします(ステップ8)。STACK_RETENTION、REGISTER_SPILL を生成します。emit_asm.sh がない場合、自動的に無効になります。 |
enable_semantic_ir |
いいえ | false |
セマンティックLLVM IR分析を有効にします(ステップ9)。LOOP_UNROLLED_INCOMPLETE を生成します。 |
enable_cfg |
いいえ | false |
制御フローグラフ分析を有効にします(ステップ10)。MISSING_ON_ERROR_PATH、NOT_DOMINATING_EXITS を生成します。 |
enable_runtime_tests |
いいえ | false |
ランタイムテストハーネスの生成を有効にします(ステップ11)。 |
前提条件
実行する前に、以下を確認してください。それぞれに定義された失敗モードがあります。
C/C++の前提条件:
| 前提条件 | 欠落した場合の失敗モード |
|---|---|
compile_commands.json が compile_db パスにあること |
即時失敗 — 続行しません |
clang がPATH上にあること |
即時失敗 — IR/ASM分析が不可能です |
uvx がPATH上にあること (Serena用) |
mcp_mode=require の場合:失敗します。mcp_mode=prefer の場合:MCPなしで続行し、影響を受ける発見をConfidence Gatingルールに従ってダウングレードします。 |
{baseDir}/tools/extract_compile_flags.py |
即時失敗 — TUごとのフラグを抽出できません |
{baseDir}/tools/emit_ir.sh |
即時失敗 — IR分析が不可能です |
{baseDir}/tools/emit_asm.sh |
警告を発し、アセンブリの発見(STACK_RETENTION、REGISTER_SPILL)をスキップします |
{baseDir}/tools/mcp/check_mcp.sh |
警告を発し、MCPが利用できないものとして扱います |
{baseDir}/tools/mcp/normalize_mcp_evidence.py |
警告を発し、生のMCP出力を使用します |
Rustの前提条件:
| 前提条件 | 欠落した場合の失敗モード |
|---|---|
Cargo.toml が cargo_manifest パスにあること |
即時失敗 — 続行しません |
cargo check がパスすること |
即時失敗 — クレートがビルド可能である必要があります |
cargo +nightly がPATH上にあること |
即時失敗 — MIRおよびLLVM IRの出力にはnightlyが必要です |
uv がPATH上にあること |
即時失敗 — Python分析スクリプトの実行に必要です |
{baseDir}/tools/validate_rust_toolchain.sh |
警告 — プレフライトを手動で実行します。すべてのツール、スクリプト、nightly、およびオプションで cargo check をチェックします。機械可読な出力には --json を、クレートのビルドも検証するには --manifest を使用します。 |
{baseDir}/tools/emit_rust_mir.sh |
即時失敗 — MIR分析が不可能です(--opt、--crate、--bin/--lib がサポートされています。--out はファイルまたはディレクトリにできます) |
{baseDir}/tools/emit_rust_ir.sh |
即時失敗 — LLVM IR分析が不可能です(--opt が必須です。--crate、--bin/--lib がサポートされています。--out は .ll である必要があります) |
{baseDir}/tools/emit_rust_asm.sh |
警告を発し、アセンブリの発見(STACK_RETENTION、REGISTER_SPILL)をスキップします。--opt、--crate、--bin/--lib、--target、--intel-syntax をサポートしています。--out は .s ファイルまたはディレクトリにできます。 |
{baseDir}/tools/diff_rust_mir.sh |
警告を発し、MIRレベルの最適化比較をスキップします。2つ以上のMIRファイルを受け入れ、正規化し、ペアごとに差分を取り、ゼロ化/ドロップグルーパターンが消える最初の最適化レベルを報告します。 |
{baseDir}/tools/scripts/semantic_audit.py |
警告を発し、セマンティックソース分析をスキップします |
{baseDir}/tools/scripts/find_dangerous_apis.py |
警告を発し、危険なAPIスキャンをスキップします |
| `{baseDir}/t |
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
zeroize-audit — Claude Skill
When to Use
- Auditing cryptographic implementations (keys, seeds, nonces, secrets)
- Reviewing authentication systems (passwords, tokens, session data)
- Analyzing code that handles PII or sensitive credentials
- Verifying secure cleanup in security-critical codebases
- Investigating memory safety of sensitive data handling
When NOT to Use
- General code review without security focus
- Performance optimization (unless related to secure wiping)
- Refactoring tasks not related to sensitive data
- Code without identifiable secrets or sensitive values
Purpose
Detect missing zeroization of sensitive data in source code and identify zeroization that is removed or weakened by compiler optimizations (e.g., dead-store elimination), with mandatory LLVM IR/asm evidence. Capabilities include:
- Assembly-level analysis for register spills and stack retention
- Data-flow tracking for secret copies
- Heap allocator security warnings
- Semantic IR analysis for loop unrolling and SSA form
- Control-flow graph analysis for path coverage verification
- Runtime validation test generation
Scope
- Read-only against the target codebase (does not modify audited code; writes analysis artifacts to a temporary working directory).
- Produces a structured report (JSON).
- Requires valid build context (
compile_commands.json) and compilable translation units. - "Optimized away" findings only allowed with compiler evidence (IR/asm diff).
Inputs
See {baseDir}/schemas/input.json for the full schema. Key fields:
| Field | Required | Default | Description |
|---|---|---|---|
path |
yes | — | Repo root |
compile_db |
no | null |
Path to compile_commands.json for C/C++ analysis. Required if cargo_manifest is not set. |
cargo_manifest |
no | null |
Path to Cargo.toml for Rust crate analysis. Required if compile_db is not set. |
config |
no | — | YAML defining heuristics and approved wipes |
opt_levels |
no | ["O0","O1","O2"] |
Optimization levels for IR comparison. O1 is the diagnostic level: if a wipe disappears at O1 it is simple DSE; O2 catches more aggressive eliminations. |
languages |
no | ["c","cpp","rust"] |
Languages to analyze |
max_tus |
no | — | Limit on translation units processed from compile DB |
mcp_mode |
no | prefer |
off, prefer, or require — controls Serena MCP usage |
mcp_required_for_advanced |
no | true |
Downgrade SECRET_COPY, MISSING_ON_ERROR_PATH, and NOT_DOMINATING_EXITS to needs_review when MCP is unavailable |
mcp_timeout_ms |
no | — | Timeout budget for MCP semantic queries |
poc_categories |
no | all 11 exploitable | Finding categories for which to generate PoCs. C/C++ findings: all 11 categories supported. Rust findings: only MISSING_SOURCE_ZEROIZE, SECRET_COPY, and PARTIAL_WIPE are supported; other Rust categories are marked poc_supported=false. |
poc_output_dir |
no | generated_pocs/ |
Output directory for generated PoCs |
enable_asm |
no | true |
Enable assembly emission and analysis (Step 8); produces STACK_RETENTION, REGISTER_SPILL. Auto-disabled if emit_asm.sh is missing. |
enable_semantic_ir |
no | false |
Enable semantic LLVM IR analysis (Step 9); produces LOOP_UNROLLED_INCOMPLETE |
enable_cfg |
no | false |
Enable control-flow graph analysis (Step 10); produces MISSING_ON_ERROR_PATH, NOT_DOMINATING_EXITS |
enable_runtime_tests |
no | false |
Enable runtime test harness generation (Step 11) |
Prerequisites
Before running, verify the following. Each has a defined failure mode.
C/C++ prerequisites:
| Prerequisite | Failure mode if missing |
|---|---|
compile_commands.json at compile_db path |
Fail fast — do not proceed |
clang on PATH |
Fail fast — IR/ASM analysis impossible |
uvx on PATH (for Serena) |
If mcp_mode=require: fail. If mcp_mode=prefer: continue without MCP; downgrade affected findings per Confidence Gating rules. |
{baseDir}/tools/extract_compile_flags.py |
Fail fast — cannot extract per-TU flags |
{baseDir}/tools/emit_ir.sh |
Fail fast — IR analysis impossible |
{baseDir}/tools/emit_asm.sh |
Warn and skip assembly findings (STACK_RETENTION, REGISTER_SPILL) |
{baseDir}/tools/mcp/check_mcp.sh |
Warn and treat as MCP unavailable |
{baseDir}/tools/mcp/normalize_mcp_evidence.py |
Warn and use raw MCP output |
Rust prerequisites:
| Prerequisite | Failure mode if missing |
|---|---|
Cargo.toml at cargo_manifest path |
Fail fast — do not proceed |
cargo check passes |
Fail fast — crate must be buildable |
cargo +nightly on PATH |
Fail fast — nightly required for MIR and LLVM IR emission |
uv on PATH |
Fail fast — required to run Python analysis scripts |
{baseDir}/tools/validate_rust_toolchain.sh |
Warn — run preflight manually. Checks all tools, scripts, nightly, and optionally cargo check. Use --json for machine-readable output, --manifest to also validate the crate builds. |
{baseDir}/tools/emit_rust_mir.sh |
Fail fast — MIR analysis impossible (--opt, --crate, --bin/--lib supported; --out can be file or directory) |
{baseDir}/tools/emit_rust_ir.sh |
Fail fast — LLVM IR analysis impossible (--opt required; --crate, --bin/--lib supported; --out must be .ll) |
{baseDir}/tools/emit_rust_asm.sh |
Warn and skip assembly findings (STACK_RETENTION, REGISTER_SPILL). Supports --opt, --crate, --bin/--lib, --target, --intel-syntax; --out can be .s file or directory. |
{baseDir}/tools/diff_rust_mir.sh |
Warn and skip MIR-level optimization comparison. Accepts 2+ MIR files, normalizes, diffs pairwise, and reports first opt level where zeroize/drop-glue patterns disappear. |
{baseDir}/tools/scripts/semantic_audit.py |
Warn and skip semantic source analysis |
{baseDir}/tools/scripts/find_dangerous_apis.py |
Warn and skip dangerous API scan |
{baseDir}/tools/scripts/check_mir_patterns.py |
Warn and skip MIR analysis |
{baseDir}/tools/scripts/check_llvm_patterns.py |
Warn and skip LLVM IR analysis |
{baseDir}/tools/scripts/check_rust_asm.py |
Warn and skip Rust assembly analysis (STACK_RETENTION, REGISTER_SPILL, drop-glue checks). Dispatches to check_rust_asm_x86.py (production) or check_rust_asm_aarch64.py (EXPERIMENTAL — AArch64 findings require manual verification). |
{baseDir}/tools/scripts/check_rust_asm_x86.py |
Required by check_rust_asm.py for x86-64 analysis; warn and skip if missing |
{baseDir}/tools/scripts/check_rust_asm_aarch64.py |
Required by check_rust_asm.py for AArch64 analysis (EXPERIMENTAL); warn and skip if missing |
Common prerequisite:
| Prerequisite | Failure mode if missing |
|---|---|
{baseDir}/tools/generate_poc.py |
Fail fast — PoC generation is mandatory |
Approved Wipe APIs
The following are recognized as valid zeroization. Configure additional entries in {baseDir}/configs/.
C/C++
explicit_bzeromemset_sSecureZeroMemoryOPENSSL_cleansesodium_memzero- Volatile wipe loops (pattern-based; see
volatile_wipe_patternsin{baseDir}/configs/default.yaml) - In IR:
llvm.memsetwith volatile flag, volatile stores, or non-elidable wipe call
Rust
zeroize::Zeroizetrait (zeroize()method)Zeroizing<T>wrapper (drop-based)ZeroizeOnDropderive macro
Finding Capabilities
Findings are grouped by required evidence. Only attempt findings for which the required tooling is available.
| Finding ID | Description | Requires | PoC Support |
|---|---|---|---|
MISSING_SOURCE_ZEROIZE |
No zeroization found in source | Source only | Yes (C/C++ + Rust) |
PARTIAL_WIPE |
Incorrect size or incomplete wipe | Source only | Yes (C/C++ + Rust) |
NOT_ON_ALL_PATHS |
Zeroization missing on some control-flow paths (heuristic) | Source only | Yes (C/C++ only) |
SECRET_COPY |
Sensitive data copied without zeroization tracking | Source + MCP preferred | Yes (C/C++ + Rust) |
INSECURE_HEAP_ALLOC |
Secret uses insecure allocator (malloc vs. secure_malloc) | Source only | Yes (C/C++ only) |
OPTIMIZED_AWAY_ZEROIZE |
Compiler removed zeroization | IR diff required (never source-only) | Yes |
STACK_RETENTION |
Stack frame may retain secrets after return | Assembly required (C/C++); LLVM IR alloca+lifetime.end evidence (Rust); assembly corroboration upgrades to confirmed |
Yes (C/C++ only) |
REGISTER_SPILL |
Secrets spilled from registers to stack | Assembly required (C/C++); LLVM IR load+call-site evidence (Rust); assembly corroboration upgrades to confirmed |
Yes (C/C++ only) |
MISSING_ON_ERROR_PATH |
Error-handling paths lack cleanup | CFG or MCP required | Yes |
NOT_DOMINATING_EXITS |
Wipe doesn't dominate all exits | CFG or MCP required | Yes |
LOOP_UNROLLED_INCOMPLETE |
Unrolled loop wipe is incomplete | Semantic IR required | Yes |
Agent Architecture
The analysis pipeline uses 11 agents across 8 phases, invoked by the orchestrator ({baseDir}/prompts/task.md) via Task. Agents write persistent finding files to a shared working directory (/tmp/zeroize-audit-{run_id}/), enabling parallel execution and protecting against context pressure.
| Agent | Phase | Purpose | Output Directory |
|---|---|---|---|
0-preflight |
Phase 0 | Preflight checks (tools, toolchain, compile DB, crate build), config merge, workdir creation, TU enumeration | {workdir}/ |
1-mcp-resolver |
Phase 1, Wave 1 (C/C++ only) | Resolve symbols, types, and cross-file references via Serena MCP | mcp-evidence/ |
2-source-analyzer |
Phase 1, Wave 2a (C/C++ only) | Identify sensitive objects, detect wipes, validate correctness, data-flow/heap | source-analysis/ |
2b-rust-source-analyzer |
Phase 1, Wave 2b (Rust only, parallel with 2a) | Rustdoc JSON trait-aware analysis + dangerous API grep | source-analysis/ |
3-tu-compiler-analyzer |
Phase 2, Wave 3 (C/C++ only, N parallel) | Per-TU IR diff, assembly, semantic IR, CFG analysis | compiler-analysis/{tu_hash}/ |
3b-rust-compiler-analyzer |
Phase 2, Wave 3R (Rust only, single agent) | Crate-level MIR, LLVM IR, and assembly analysis | rust-compiler-analysis/ |
4-report-assembler |
Phase 3 (interim) + Phase 6 (final) | Collect findings from all agents, apply confidence gates; merge PoC results and produce final report | report/ |
5-poc-generator |
Phase 4 | Craft bespoke proof-of-concept programs (C/C++: all categories; Rust: MISSING_SOURCE_ZEROIZE, SECRET_COPY, PARTIAL_WIPE) | poc/ |
5b-poc-validator |
Phase 5 | Compile and run all PoCs | poc/ |
5c-poc-verifier |
Phase 5 | Verify each PoC proves its claimed finding | poc/ |
6-test-generator |
Phase 7 (optional) | Generate runtime validation test harnesses | tests/ |
The orchestrator reads one per-phase workflow file from {baseDir}/workflows/ at a time, and maintains orchestrator-state.json for recovery after context compression. Agents receive configuration by file path (config_path), not by value.
Execution flow
Phase 0: 0-preflight agent — Preflight + config + create workdir + enumerate TUs
→ writes orchestrator-state.json, merged-config.yaml, preflight.json
Phase 1: Wave 1: 1-mcp-resolver (skip if mcp_mode=off OR language_mode=rust)
Wave 2a: 2-source-analyzer (C/C++ only; skip if no compile_db) ─┐ parallel
Wave 2b: 2b-rust-source-analyzer (Rust only; skip if no cargo_manifest) ─┘
Phase 2: Wave 3: 3-tu-compiler-analyzer x N (C/C++ only; parallel per TU)
Wave 3R: 3b-rust-compiler-analyzer (Rust only; single crate-level agent)
Phase 3: Wave 4: 4-report-assembler (mode=interim → findings.json; reads all agent outputs)
Phase 4: Wave 5: 5-poc-generator (C/C++: all categories; Rust: MISSING_SOURCE_ZEROIZE, SECRET_COPY, PARTIAL_WIPE; other Rust findings: poc_supported=false)
Phase 5: PoC Validation & Verification
Step 1: 5b-poc-validator agent (compile and run all PoCs)
Step 2: 5c-poc-verifier agent (verify each PoC proves its claimed finding)
Step 3: Orchestrator presents verification failures to user via AskUserQuestion
Step 4: Orchestrator merges all results into poc_final_results.json
Phase 6: Wave 6: 4-report-assembler (mode=final → merge PoC results, final-report.md)
Phase 7: Wave 7: 6-test-generator (optional)
Phase 8: Orchestrator — Return final-report.md
Cross-Reference Convention
IDs are namespaced per agent to prevent collisions during parallel execution:
| Entity | Pattern | Assigned By |
|---|---|---|
| Sensitive object (C/C++) | SO-0001–SO-4999 |
2-source-analyzer |
| Sensitive object (Rust) | SO-5000–SO-9999 (Rust namespace) |
2b-rust-source-analyzer |
| Source finding (C/C++) | F-SRC-NNNN |
2-source-analyzer |
| Source finding (Rust) | F-RUST-SRC-NNNN |
2b-rust-source-analyzer |
| IR finding (C/C++) | F-IR-{tu_hash}-NNNN |
3-tu-compiler-analyzer |
| ASM finding (C/C++) | F-ASM-{tu_hash}-NNNN |
3-tu-compiler-analyzer |
| CFG finding | F-CFG-{tu_hash}-NNNN |
3-tu-compiler-analyzer |
| Semantic IR finding | F-SIR-{tu_hash}-NNNN |
3-tu-compiler-analyzer |
| Rust MIR finding | F-RUST-MIR-NNNN |
3b-rust-compiler-analyzer |
| Rust LLVM IR finding | F-RUST-IR-NNNN |
3b-rust-compiler-analyzer |
| Rust assembly finding | F-RUST-ASM-NNNN |
3b-rust-compiler-analyzer |
| Translation unit | TU-{hash} |
Orchestrator |
| Final finding | ZA-NNNN |
4-report-assembler |
Every finding JSON object includes related_objects, related_findings, and evidence_files fields for cross-referencing between agents.
Detection Strategy
Analysis runs in two phases. For complete step-by-step guidance, see {baseDir}/references/detection-strategy.md.
| Phase | Steps | Findings produced | Required tooling |
|---|---|---|---|
| Phase 1 (Source) | 1–6 | MISSING_SOURCE_ZEROIZE, PARTIAL_WIPE, NOT_ON_ALL_PATHS, SECRET_COPY, INSECURE_HEAP_ALLOC |
Source + compile DB |
| Phase 2 (Compiler) | 7–12 | OPTIMIZED_AWAY_ZEROIZE, STACK_RETENTION, REGISTER_SPILL, LOOP_UNROLLED_INCOMPLETE†, MISSING_ON_ERROR_PATH‡, NOT_DOMINATING_EXITS‡ |
clang, IR/ASM tools |
* requires enable_asm=true (default)
† requires enable_semantic_ir=true
‡ requires enable_cfg=true
Output Format
Each run produces two outputs:
final-report.md— Comprehensive markdown report (primary human-readable output)findings.json— Structured JSON matching{baseDir}/schemas/output.json(for machine consumption and downstream tools)
Markdown Report Structure
The markdown report (final-report.md) contains these sections:
- Header: Run metadata (run_id, timestamp, repo, compile_db, config summary)
- Executive Summary: Finding counts by severity, confidence, and category
- Sensitive Objects Inventory: Table of all identified objects with IDs, types, locations
- Findings: Grouped by severity then confidence. Each finding includes location, object, all evidence (source/IR/ASM/CFG), compiler evidence details, and recommended fix
- Superseded Findings: Source findings replaced by CFG-backed findings
- Confidence Gate Summary: Downgrades applied and overrides rejected
- Analysis Coverage: TUs analyzed, agent success/failure, features enabled
- Appendix: Evidence Files: Mapping of finding IDs to evidence file paths
Structured JSON
The findings.json file follows the schema in {baseDir}/schemas/output.json. Each Finding object:
{
"id": "ZA-0001",
"category": "OPTIMIZED_AWAY_ZEROIZE",
"severity": "high",
"confidence": "confirmed",
"language": "c",
"file": "src/crypto.c",
"line": 42,
"symbol": "key_buf",
"evidence": "store volatile i8 0 count: O0=32, O2=0 — wipe eliminated by DSE",
"compiler_evidence": {
"opt_levels": ["O0", "O2"],
"o0": "32 volatile stores targeting key_buf",
"o2": "0 volatile stores (all eliminated)",
"diff_summary": "All volatile wipe stores removed at O2 — classic DSE pattern"
},
"suggested_fix": "Replace memset with explicit_bzero or add compiler_fence(SeqCst) after the wipe",
"poc": {
"file": "generated_pocs/ZA-0001.c",
"makefile_target": "ZA-0001",
"compile_opt": "-O2",
"requires_manual_adjustment": false,
"validated": true,
"validation_result": "exploitable"
}
}
See {baseDir}/schemas/output.json for the full schema and enum values.
Confidence Gating
Evidence thresholds
A finding requires at least 2 independent signals to be marked confirmed. With 1 signal, mark likely. With 0 strong signals (name-pattern match only), mark needs_review.
Signals include: name pattern match, type hint match, explicit annotation, IR evidence, ASM evidence, MCP cross-reference, CFG evidence, PoC validation.
PoC validation as evidence signal
Every finding is validated against a bespoke PoC. After compilation and execution, each PoC is also verified to ensure it actually tests the claimed vulnerability. The combined result is an evidence signal:
| PoC Result | Verified | Impact |
|---|---|---|
| Exit 0 (exploitable) | Yes | Strong signal — can upgrade likely to confirmed |
| Exit 1 (not exploitable) | Yes | Downgrade severity to low (informational); retain in report |
| Exit 0 or 1 | No (user accepted) | Weaker signal — note verification failure in evidence |
| Exit 0 or 1 | No (user rejected) | No confidence change; annotate as rejected |
| Compile failure / no PoC | — | No confidence change; annotate in evidence |
MCP unavailability downgrade
When mcp_mode=prefer and MCP is unavailable, downgrade the following unless independent IR/CFG/ASM evidence is strong (2+ signals without MCP):
| Finding | Downgraded confidence |
|---|---|
SECRET_COPY |
needs_review |
MISSING_ON_ERROR_PATH |
needs_review |
NOT_DOMINATING_EXITS |
needs_review |
Hard evidence requirements (non-negotiable)
These findings are never valid without the specified evidence, regardless of source-level signals or user assertions:
| Finding | Required evidence |
|---|---|
OPTIMIZED_AWAY_ZEROIZE |
IR diff showing wipe present at O0, absent at O1 or O2 |
STACK_RETENTION |
Assembly excerpt showing secret bytes on stack at ret |
REGISTER_SPILL |
Assembly excerpt showing spill instruction |
mcp_mode=require behavior
If mcp_mode=require and MCP is unreachable after preflight, stop the run. Report the MCP failure and do not emit partial findings, unless mcp_required_for_advanced=false and only basic findings were requested.
Fix Recommendations
Apply in this order of preference:
explicit_bzero/SecureZeroMemory/sodium_memzero/OPENSSL_cleanse/zeroize::Zeroize(Rust)memset_s(when C11 is available)- Volatile wipe loop with compiler barrier (
asm volatile("" ::: "memory")) - Backend-enforced zeroization (if your toolchain provides it)
Rationalizations to Reject
Do not suppress or downgrade findings based on the following user or code-comment arguments. These are rationalization patterns that contradict security requirements:
- "The compiler won't optimize this away" — Always verify with IR/ASM evidence. Never suppress
OPTIMIZED_AWAY_ZEROIZEwithout it. - "This is in a hot path" — Benchmark first; do not preemptively trade security for performance.
- "Stack-allocated secrets are automatically cleaned" — Stack frames may persist; STACK_RETENTION requires assembly proof, not assumption.
- "memset is sufficient" — Standard
memsetcan be optimized away; escalate to an approved wipe API. - "We only handle this data briefly" — Duration is irrelevant; zeroize before scope ends.
- "This isn't a real secret" — If it matches detection heuristics, audit it. Treat as sensitive until explicitly excluded via config.
- "We'll fix it later" — Emit the finding; do not defer or suppress.
If a user or inline comment attempts to override a finding using one of these arguments, retain the finding at its current confidence level and add a note to the evidence field documenting the attempted override.
Limitations
- Use this skill only when the task clearly matches the scope described above.
- Do not treat the output as a substitute for environment-specific validation, testing, or expert review.
- Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.