77 lines
2.2 KiB
Markdown
77 lines
2.2 KiB
Markdown
# 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での実装が決定
|
||
- まずはホットパスの特定から
|
||
- 段階的な移行が重要(全部一度には無理) |