# Phase 11: LLVM AOT Backend(進行中) ## 🎯 概要 Phase 11は、LLVM を使用した Ahead-of-Time(AOT)コンパイル機能の研究・実装フェーズです。 Phase 10のCranelift JITで実用的な性能を達成した後、さらなる最適化をLLVM AOTで追求します。 ## 📊 位置づけ ``` Phase 10: Cranelift JIT(実用的な高速化)← 完了 ↓ Phase 11: LLVM AOT(最高性能への挑戦)← 進行中 ``` ## 📁 ドキュメント ### 🔬 研究・設計ドキュメント - [phase10_aot_scaffolding.md](phase10_aot_scaffolding.md) - LLVM Direct AOT実装計画 - MIR→LLVM IR直接変換 - Everything is Box最適化(エスケープ解析) - LTO/PGO統合 - 目標: 13,500倍高速化(対インタープリタ) - [phase_10_x_llvm_backend_skeleton.md](phase_10_x_llvm_backend_skeleton.md) - LLVM Backend最小実装 - 具体的な実装ステップ - ExternCall対応 - オブジェクトファイル生成 ## ⏰ タイムライン(短期スプリント) - Status: In Progress(進行中) - 前提条件: Phase 10(Cranelift JIT)の完了、Core‑15統一(VM/Verifierで運用) - 想定期間: 4週間(各フェーズ1週間目安) - 11.1 基本変換: Const/Unary/Bin/Compare, Load/Store, Jump/Branch/Return/Phi - 11.2 Box統合: NewBox/BoxCall/ExternCall(安全パスはランタイム呼び出し) - 11.3 最適化: 注釈統合・型特化(get/setField・Array get/set のInline化+バリア) - 11.4 高度化: 脱箱化・TBAA・PGO/ThinLTO ## 🎯 期待される成果 1. **最高性能**: インタープリタ比13,500倍の実行速度 2. **メモリ効率**: Box割当80%削減 3. **起動時間**: 1ms以下 4. **配布形式**: スタンドアロン実行ファイル ## ⚠️ 注意事項(運用方針) - Core‑15 仕様固定(第三案): { Const, UnaryOp, BinOp, Compare, TypeOp, Load, Store, Jump, Branch, Return, Phi, Call, NewBox, BoxCall, ExternCall } - 統一ルール: ArrayGet/ArraySet, RefGet/RefSet, PluginInvoke はBoxCallに一本化(Optimizerで正規化、Verifierで禁止) - バリア方針: 初期はランタイム関数側で安全に処理、型特化Lowering段でIRへ内挿(write barrier) ## 🔗 関連フェーズ - [Phase 10](../phase-10/) - Cranelift JIT(前提) - [Phase 9](../phase-9/) - 統一Box設計(基盤) - [00_MASTER_ROADMAP.md](../00_MASTER_ROADMAP.md) - 全体計画