185 lines
3.9 KiB
Markdown
185 lines
3.9 KiB
Markdown
|
|
# 🔄 wasmtime互換性マトリクス
|
|||
|
|
|
|||
|
|
## 📅 最終更新: 2025-08-15
|
|||
|
|
|
|||
|
|
## 🎯 **現在の状況**
|
|||
|
|
|
|||
|
|
### 開発環境
|
|||
|
|
```toml
|
|||
|
|
# Cargo.toml
|
|||
|
|
wasmtime = "18.0"
|
|||
|
|
wabt = "0.10"
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 実行環境
|
|||
|
|
```bash
|
|||
|
|
# システムインストール
|
|||
|
|
wasmtime 35.0.0 (509af9e5f 2025-07-22)
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 互換性状況
|
|||
|
|
❌ **非互換**: 18.0.4 vs 35.0.0 - 実行不可
|
|||
|
|
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
## 📊 **バージョン互換性マトリクス**
|
|||
|
|
|
|||
|
|
| Nyash wasmtime | System wasmtime | 互換性 | 状況 | 対応 |
|
|||
|
|
|----------------|-----------------|--------|------|------|
|
|||
|
|
| **18.0.4** | **35.0.0** | ❌ | 現在 | 要修正 |
|
|||
|
|
| 35.0.x | 35.0.x | ✅ | 目標 | 推奨 |
|
|||
|
|
| 34.0.x | 35.0.x | ⚠️ | 検証必要 | テスト |
|
|||
|
|
| 33.0.x | 35.0.x | ❌ | 古すぎ | 非推奨 |
|
|||
|
|
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
## 🔧 **修正オプション**
|
|||
|
|
|
|||
|
|
### Option A: Nyash側更新 (推奨)
|
|||
|
|
```toml
|
|||
|
|
# Cargo.toml - 更新案
|
|||
|
|
wasmtime = "35.0"
|
|||
|
|
wabt = "0.10" # 互換性確認必要
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
**メリット**:
|
|||
|
|
- ✅ 最新機能・性能向上
|
|||
|
|
- ✅ セキュリティ修正取り込み
|
|||
|
|
- ✅ 将来性
|
|||
|
|
|
|||
|
|
**リスク**:
|
|||
|
|
- ⚠️ API変更による修正必要
|
|||
|
|
- ⚠️ 既存.cwasmファイル互換性喪失
|
|||
|
|
|
|||
|
|
### Option B: システム側ダウングレード
|
|||
|
|
```bash
|
|||
|
|
# wasmtime 18.0.4 をインストール
|
|||
|
|
curl -sSf https://wasmtime.dev/install.sh | bash -s -- --version 18.0.4
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
**メリット**:
|
|||
|
|
- ✅ Nyashコード修正不要
|
|||
|
|
- ✅ 即座対応可能
|
|||
|
|
|
|||
|
|
**デメリット**:
|
|||
|
|
- ❌ 古いバージョン使用
|
|||
|
|
- ❌ セキュリティリスク
|
|||
|
|
- ❌ 他プロジェクトへの影響
|
|||
|
|
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
## 🎯 **推奨対応手順**
|
|||
|
|
|
|||
|
|
### Step 1: 依存関係調査 (30分)
|
|||
|
|
```bash
|
|||
|
|
# 現在の依存関係確認
|
|||
|
|
cargo tree | grep wasmtime
|
|||
|
|
cargo tree | grep wabt
|
|||
|
|
|
|||
|
|
# API変更点調査
|
|||
|
|
# https://github.com/bytecodealliance/wasmtime/releases
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Step 2: テスト環境構築 (30分)
|
|||
|
|
```bash
|
|||
|
|
# ブランチ作成
|
|||
|
|
git checkout -b feature/wasmtime-35-upgrade
|
|||
|
|
|
|||
|
|
# Cargo.toml更新
|
|||
|
|
# wasmtime = "35.0"
|
|||
|
|
|
|||
|
|
# 依存関係更新
|
|||
|
|
cargo update
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### Step 3: ビルド修正 (2-4時間)
|
|||
|
|
予想される修正箇所:
|
|||
|
|
- `src/backend/aot/compiler.rs`: Engine設定API
|
|||
|
|
- `src/backend/wasm/mod.rs`: Module生成API
|
|||
|
|
- `src/backend/aot/config.rs`: Config構造変更
|
|||
|
|
|
|||
|
|
### Step 4: 動作確認 (1時間)
|
|||
|
|
```bash
|
|||
|
|
# 基本コンパイル
|
|||
|
|
cargo build --release
|
|||
|
|
|
|||
|
|
# WASM/AOT テスト
|
|||
|
|
./target/release/nyash --aot test_simple.nyash
|
|||
|
|
wasmtime --allow-precompiled test_simple.cwasm
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
## 📋 **wasmtime API変更予想箇所**
|
|||
|
|
|
|||
|
|
### 18.x → 35.x 主要変更点
|
|||
|
|
|
|||
|
|
#### Engine/Store API
|
|||
|
|
```rust
|
|||
|
|
// 18.x (予想)
|
|||
|
|
let engine = Engine::default();
|
|||
|
|
let store = Store::new(&engine, ());
|
|||
|
|
|
|||
|
|
// 35.x (要確認)
|
|||
|
|
let engine = Engine::new(&Config::default())?;
|
|||
|
|
let mut store = Store::new(&engine, ());
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
#### Module serialize/deserialize
|
|||
|
|
```rust
|
|||
|
|
// 18.x
|
|||
|
|
module.serialize()?;
|
|||
|
|
Module::deserialize(&engine, bytes)?;
|
|||
|
|
|
|||
|
|
// 35.x (API変更可能性)
|
|||
|
|
module.serialize()?; // 戻り値型変更?
|
|||
|
|
unsafe { Module::deserialize(&engine, bytes)? } // unsafe要求?
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
#### Config API
|
|||
|
|
```rust
|
|||
|
|
// 18.x
|
|||
|
|
let config = Config::new();
|
|||
|
|
|
|||
|
|
// 35.x
|
|||
|
|
let mut config = Config::new();
|
|||
|
|
config.cranelift_opt_level(OptLevel::Speed)?;
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
## ✅ **アクションアイテム**
|
|||
|
|
|
|||
|
|
### 緊急 (今日)
|
|||
|
|
- [ ] wasmtime 35.0 API ドキュメント確認
|
|||
|
|
- [ ] 修正工数見積もり (2-8時間予想)
|
|||
|
|
|
|||
|
|
### 短期 (今週)
|
|||
|
|
- [ ] **wasmtime 35.0 への更新実装**
|
|||
|
|
- [ ] 全WASM/AOT機能のテスト実行
|
|||
|
|
- [ ] 互換性問題解決
|
|||
|
|
|
|||
|
|
### 中期 (来週)
|
|||
|
|
- [ ] wasmtime自動バージョン検知機能
|
|||
|
|
- [ ] CI/CDでの互換性テスト自動化
|
|||
|
|
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
## 🎯 **成功指標**
|
|||
|
|
|
|||
|
|
### 技術指標
|
|||
|
|
```bash
|
|||
|
|
# ✅ 成功条件
|
|||
|
|
./target/release/nyash --aot test.nyash # コンパイル成功
|
|||
|
|
wasmtime --allow-precompiled test.cwasm # 実行成功
|
|||
|
|
echo $? # 0 (正常終了)
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 性能指標
|
|||
|
|
- コンパイル時間: 18.x と同等以上
|
|||
|
|
- 実行速度: 18.x と同等以上
|
|||
|
|
- メモリ使用量: 18.x と同等以下
|
|||
|
|
|
|||
|
|
---
|
|||
|
|
|
|||
|
|
**🚀 Next Action**: wasmtime 35.0 へのアップグレード実装を最優先で開始
|