Commit Graph

3 Commits

Author SHA1 Message Date
8750186e55 chore: Phase 26-H セッション完了 - 全ドキュメント更新
Phase 26-H 完了内容:
 JoinIR 型定義実装(src/mir/join_ir.rs)
 MIR → JoinIR 自動変換実装(lower_min_loop_to_joinir)
 自動変換テスト実装(mir_joinir_min_auto_lowering)
 PHI/Loop箱 → JoinIR 移行対応表追加(loopform_ssot.md)

ドキュメント更新:
- Phase 27 JoinIR タスク計画追加
- Phase 26-H タスク完了記録
- 各種 README 更新(進捗反映)
- CURRENT_TASK.md 更新

コミット統計: $(git status --short | wc -l) files changed

次のステップ: Phase 27 一般化 MIR → JoinIR 変換
2025-11-23 05:53:27 +09:00
75f3df2505 refactor(mir): Phase 25.1o - do_break/continue 共通化(LoopExitKind型統一)
【変更内容】
1. LoopExitKind enum定義
   - Break / Continue の型安全な区別

2. do_loop_exit() 共通メソッド作成(47行)
   - スナップショット取得(共通処理)
   - kind別のスナップショット保存
   - kind別のジャンプターゲット
   - unreachable ブロック切り替え(共通処理)

3. do_break/continue をthin wrapperに変換
   - do_break: 13行 → 4行
   - do_continue: 12行 → 4行
   - 合計21行削減

【効果】
- 構造改善: break/continue の共通ロジック一箇所に集約
- 保守性向上: デバッグログなどの共通処理が統一管理
- 拡張性向上: labeled break/continue等の将来拡張が容易

【検証結果】
- ビルド成功(警告なし)
- mir_stageb_loop_break_continue_verifies: PASS
- /tmp/loop_continue_fixed.hako: RC=3(期待通り)

関連: Phase 25.1m (continue PHI修正), Phase 25.1n (レガシー削除)
2025-11-19 08:56:44 +09:00
f85e485195 feat(mir/phi): add LoopForm Meta-Box for PHI circular dependency solution
**Problem**: ValueId(14)/ValueId(17) circular dependency in multi-carrier
loop PHI construction. Loop body PHIs referenced ValueIds not defined in
header exit block, causing SSA use-before-def violations.

**Root Cause**: Interleaved ValueId allocation when processing pinned
(parameters like 'me', 'args') and carrier (locals like 'i', 'n')
variables created forward references:
```
Iteration 1: pre_copy=%13, phi=%14  
Iteration 2: pre_copy=%15, phi=%19   (but %14 not yet emitted!)
Body PHI: phi %17 = [%14, bb3]   %14 doesn't exist in bb3
```

**Solution**: LoopForm Meta-Box with 3-pass PHI construction algorithm
inspired by Braun et al. (2013) "Simple and Efficient SSA Construction".

**Core Design**:
- **Meta-Box abstraction**: Treat entire loop as single Box with explicit
  carrier/pinned separation
- **Three-pass algorithm**:
  1. Allocate ALL ValueIds upfront (no emission)
  2. Emit preheader copies in deterministic order
  3. Emit header PHIs (incomplete)
  4. Seal PHIs after loop body (complete)
- **Guarantees**: No circular dependencies possible (all IDs pre-allocated)

**Academic Foundation**:
- Cytron et al. (1991): Classical SSA with dominance frontiers
- Braun et al. (2013): Simple SSA with incomplete φ-nodes  Applied here
- LLVM Canonical Loop Form: Preheader→Header(PHI)→Body→Latch

**Files Added**:

1. **src/mir/phi_core/loopform_builder.rs** (360 lines):
   - LoopFormBuilder struct with carrier/pinned separation
   - LoopFormOps trait (abstraction layer)
   - Three-pass algorithm implementation
   - Unit tests (all pass )

2. **docs/development/analysis/loopform-phi-circular-dependency-solution.md**:
   - Comprehensive problem analysis (600+ lines)
   - Academic literature review
   - Alternative approaches comparison
   - Detailed implementation plan

3. **docs/development/analysis/LOOPFORM_PHI_SOLUTION_SUMMARY.md**:
   - Executive summary (250 lines)
   - Testing strategy
   - Migration timeline (4 weeks)
   - Risk assessment

4. **docs/development/analysis/LOOPFORM_PHI_NEXT_STEPS.md**:
   - Step-by-step integration guide (400 lines)
   - Code snippets for mir/loop_builder.rs
   - Troubleshooting guide
   - Success metrics

**Testing**:
-  Unit tests pass (deterministic allocation verified)
-  Integration tests (Week 2 with feature flag)
-  Selfhost support (Week 3)

**Migration Strategy**:
- Week 1 (Current):  Prototype complete
- Week 2: Integration with NYASH_LOOPFORM_PHI_V2=1 feature flag
- Week 3: Selfhost compiler support
- Week 4: Full migration, deprecate old code

**Advantages**:
1. **Correctness**: Guarantees SSA definition-before-use
2. **Simplicity**: ~360 lines (preserves Box Theory philosophy)
3. **Academic alignment**: Matches state-of-art SSA construction
4. **Backward compatible**: Feature-flagged with rollback capability

**Impact**: This resolves the fundamental ValueId circular dependency
issue blocking Stage-B selfhosting, while maintaining the LoopForm
design philosophy of "normalize everything, confine to scope".

**Total Contribution**: ~2,000 lines of code + documentation

**Next Steps**: Integrate LoopFormBuilder into src/mir/loop_builder.rs
following LOOPFORM_PHI_NEXT_STEPS.md guide (estimated 2-4 hours).

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-17 04:56:47 +09:00