Files
hakorune/docs/private/ideas/other/2025-08-25-cranelift-research.md

77 lines
2.2 KiB
Markdown
Raw Normal View History

# Cranelift JIT 調査メモ
Status: Research
Created: 2025-08-25
Priority: High (Phase 10関連)
Related: Phase 10 - Cranelift JIT実装
## 調査内容
### Craneliftとは
- Wasmtime/Firefoxで使用されているコード生成器
- LLVMより軽量で高速なコンパイル
- Rustで書かれており、Nyashとの統合が容易
### 基本的な使用方法
```rust
use cranelift::prelude::*;
use cranelift_module::{Module, Linkage};
// 関数シグネチャ定義
let mut sig = module.make_signature();
sig.params.push(AbiParam::new(types::I64));
sig.returns.push(AbiParam::new(types::I64));
// 関数生成
let func_id = module.declare_function("add_one", Linkage::Export, &sig)?;
```
### MIR → Cranelift IR変換の検討
- MIR命令とCranelift命令の対応関係
- Box型の表現方法ポインタ vs 値)
- GCとの統合方法
### パフォーマンス予測
- コンパイル時間: LLVM比 10x高速
- 実行速度: インタープリター比 10-100x高速
- メモリ使用量: 中程度
## 実装スケッチ
```rust
// MIR → Cranelift変換器
struct MirToCranelift {
builder: FunctionBuilder<'static>,
module: Module<SimpleJITBackend>,
}
impl MirToCranelift {
fn translate_instruction(&mut self, inst: &MirInstruction) {
match inst {
MirInstruction::Const { dst, value } => {
// Cranelift IRへの変換
}
// ...
}
}
}
```
## 課題と検討事項
1. **Box型の扱い**: ヒープ割り当てとGCの統合
2. **動的ディスパッチ**: BoxCallの効率的な実装
3. **例外処理**: Nyashのエラーハンドリングとの統合
4. **デバッグ情報**: ソース位置の保持
## 次のステップ
- [ ] 最小限のPoC実装整数演算のみ
- [ ] ベンチマーク環境の構築
- [ ] VM実装との性能比較
## 参考資料
- [Cranelift公式ドキュメント](https://github.com/bytecodealliance/wasmtime/tree/main/cranelift)
- [Cranelift IR Reference](https://github.com/bytecodealliance/wasmtime/blob/main/cranelift/docs/ir.md)
- wasmtimeのJIT実装
## メモ
- Phase 10での実装が決定
- まずはホットパスの特定から
- 段階的な移行が重要(全部一度には無理)