Phase 25.1 完了成果: - ✅ LoopForm v2 テスト・ドキュメント・コメント完備 - 4ケース(A/B/C/D)完全テストカバレッジ - 最小再現ケース作成(SSAバグ調査用) - SSOT文書作成(loopform_ssot.md) - 全ソースに [LoopForm] コメントタグ追加 - ✅ Stage-1 CLI デバッグ環境構築 - stage1_cli.hako 実装 - stage1_bridge.rs ブリッジ実装 - デバッグツール作成(stage1_debug.sh/stage1_minimal.sh) - アーキテクチャ改善提案文書 - ✅ 環境変数削減計画策定 - 25変数の完全調査・分類 - 6段階削減ロードマップ(25→5、80%削減) - 即時削除可能変数特定(NYASH_CONFIG/NYASH_DEBUG) Phase 26-D からの累積変更: - PHI実装改善(ExitPhiBuilder/HeaderPhiBuilder等) - MIRビルダーリファクタリング - 型伝播・最適化パス改善 - その他約300ファイルの累積変更 🎯 技術的成果: - SSAバグ根本原因特定(条件分岐内loop変数変更) - Region+next_iパターン適用完了(UsingCollectorBox等) - LoopFormパターン文書化・テスト化完了 - セルフホスティング基盤強化 Co-Authored-By: Claude <noreply@anthropic.com> Co-Authored-By: ChatGPT <noreply@openai.com> Co-Authored-By: Task Assistant <task@anthropic.com>
54 lines
1.9 KiB
Rust
54 lines
1.9 KiB
Rust
use crate::mir::function::MirFunction;
|
|
use crate::mir::verification_types::VerificationError;
|
|
use crate::mir::ValueId;
|
|
|
|
/// Verify SSA form: single assignment and all uses defined
|
|
pub fn check_ssa_form(function: &MirFunction) -> Result<(), Vec<VerificationError>> {
|
|
use std::collections::HashMap;
|
|
let mut errors = Vec::new();
|
|
let mut definitions: HashMap<ValueId, (crate::mir::BasicBlockId, usize)> = HashMap::new();
|
|
|
|
// Treat parameters as defined at the entry block.
|
|
for pid in &function.params {
|
|
definitions.insert(*pid, (function.entry_block, 0));
|
|
}
|
|
|
|
for (block_id, block) in &function.blocks {
|
|
for (inst_idx, instruction) in block.all_instructions().enumerate() {
|
|
if let Some(dst) = instruction.dst_value() {
|
|
if let Some((first_block, _)) = definitions.insert(dst, (*block_id, inst_idx)) {
|
|
errors.push(VerificationError::MultipleDefinition {
|
|
value: dst,
|
|
first_block,
|
|
second_block: *block_id,
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
for (block_id, block) in &function.blocks {
|
|
for (inst_idx, instruction) in block.all_instructions().enumerate() {
|
|
for used_value in instruction.used_values() {
|
|
if !definitions.contains_key(&used_value) {
|
|
eprintln!(
|
|
"[ssa-undef-debug] fn={} bb={:?} inst_idx={} used={:?} inst={:?}",
|
|
function.signature.name, block_id, inst_idx, used_value, instruction
|
|
);
|
|
errors.push(VerificationError::UndefinedValue {
|
|
value: used_value,
|
|
block: *block_id,
|
|
instruction_index: inst_idx,
|
|
});
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if errors.is_empty() {
|
|
Ok(())
|
|
} else {
|
|
Err(errors)
|
|
}
|
|
}
|