Files
ruvnet--RuView/plugins/ruview/commands/ruview-flash.md
T
ruv 8ff7c2c35a feat(plugins): RuView Claude Code + Codex marketplace plugin
Add `plugins/ruview` — an end-to-end toolkit for working with RuView
(WiFi-DensePose) from Claude Code, mirrored as Codex prompts.

Marketplace: `plugins/.claude-plugin/marketplace.json` (one plugin, `ruview`).

Skills (9): ruview-quickstart, ruview-hardware-setup, ruview-configure,
ruview-applications, ruview-model-training, ruview-advanced-sensing,
ruview-cli-api, ruview-mmwave, ruview-verify — shell-first (cargo / python /
idf.py / docker / node), no claude-flow MCP dependency.

Commands (7): /ruview-start, /ruview-flash, /ruview-provision, /ruview-app,
/ruview-train, /ruview-advanced, /ruview-verify.

Agents (3): ruview-onboarding-guide, ruview-config-engineer,
ruview-training-engineer.

Codex mirror: codex/AGENTS.md + codex/README.md + codex/prompts/*.md (full
command parity, enforced by scripts/smoke.sh).

Docs: docs/adrs/0001-ruview-plugin-contract.md (Proposed). Verification:
scripts/smoke.sh (13 structural checks). Provisioning docs reflect the full
`provision.py` flag set (TDM mesh, edge tiers, vitals, hop channels, Cognitum
Seed, swarm intervals) and the issue #391 NVS-namespace-replace gotcha.

Verified: `claude plugin validate` (plugin + marketplace), loads via
`claude --plugin-dir`, smoke 13/13, and confirmed against an attached ESP32-S3
on COM8 running the RuView CSI firmware (live adaptive_ctrl + csi_collector
serial output).

Co-Authored-By: claude-flow <ruv@ruv.net>
2026-05-11 17:39:16 -04:00

1.1 KiB

description, argument-hint
description argument-hint
Build and flash RuView ESP32 firmware (8MB or 4MB), then confirm the CSI stream. [8mb|4mb] [COM port]

/ruview-flash

Build + flash RuView firmware to an ESP32-S3 sensing node.

  1. Invoke the ruview-hardware-setup skill.
  2. Determine variant from $ARGUMENTS (default 8mb). For 4mb: cp firmware/esp32-csi-node/sdkconfig.defaults.4mb firmware/esp32-csi-node/sdkconfig.defaults first. For 8mb: ensure it's built from sdkconfig.defaults.template (no mock).
  3. Build using the Python-subprocess command from CLAUDE.local.md (ESP-IDF v5.4 does NOT work under Git Bash — strip MSYSTEM* env vars). Never use cmd.exe /C from bash.
  4. Flash: same subprocess, [python, idf_py, '-p', '<COM port>', 'flash'] (default port COM8), or python -m esptool ... write_flash ... with the four binaries.
  5. Confirm: serial monitor via pyserial (not idf.py monitor), then cd v2 && cargo run -p wifi-densepose-sensing-server to see frames arrive.
  6. If no frames: re-run /ruview-provision, check channel matches the AP, drop any --filter-mac.