Download Latest Version Release v1609 source code.tar.gz (62.5 MB)
Email in envelope

Get an email when there's a new version of WiFi DensePose

Home / v1591
Name Modified Size InfoDownloads / Week
Parent folder
README.md 2026-06-03 4.4 kB
Release v1591 source code.tar.gz 2026-06-03 62.5 MB
Release v1591 source code.zip 2026-06-03 64.2 MB
Totals: 3 Items   126.6 MB 0

Automated release from CI pipeline

Changes: fix(protocol): resolve 0xC511_0004 magic collision (closes [#928]) (#931)

  • fix(ci): SAST actually scans the code + drop deprecated flaky semgrep action

Two real problems in the Static Application Security Testing job:

  1. It scanned a path that no longer exists. bandit -r src/ and semgrep … src/ pointed at the repo-root src/, but the Python code moved to archive/v1/src/ (64 .py files) when the runtime was rewritten in Rust. So the SAST scan matched nothing — a silent no-op (this is also why bandit-results.sarif was "Path does not exist" on recent runs). Fixed both to archive/v1/src/.

  2. Deprecated + redundant + flaky semgrep step. The returntocorp/semgrep-action@v1 step pulled returntocorp/semgrep-agent:v1 from Docker Hub every run (intermittently timing out → red check, e.g. on [#929]) and is EOL. It was redundant: the pip semgrep --sarif step is what feeds GitHub Security; the action only pushed to the Semgrep cloud app via SEMGREP_APP_TOKEN. Removed it and folded its p/docker + p/kubernetes rulesets into the pip semgrep command, so coverage is preserved with no Docker pull.

The job stays continue-on-error: true (non-gating). YAML validated.

Co-Authored-By: claude-flow ruv@ruv.net

  • fix(protocol): resolve 0xC511_0004 magic collision (closes [#928])

Background

0xC511_0004 was assigned to two different packet formats in firmware — EDGE_FUSED_MAGIC (ADR-063, 48-byte edge_fused_vitals_pkt_t) and WASM_OUTPUT_MAGIC (ADR-040, variable-length wasm_output_pkt_t). Both were transmitted. The sensing-server only had a WASM parser for that magic and no fused-vitals parser, so on the ESP32-C6 + MR60BHA2 mmWave configuration the fused-vitals packet was silently misparsed as a malformed WASM output — breathing_rate was read as event_count, mmWave-fused vitals were lost, and spurious WASM events were emitted to subscribers.

Fix

  1. Reassign WASM_OUTPUT_MAGIC to 0xC511_0007 (next free slot per the registry in rv_feature_state.h). Smaller blast radius than moving fused-vitals — the registry already treats 0xC511_0004 as fused-vitals canonical and several years of deployed feature tracking depends on that assignment.

  2. Add parse_edge_fused_vitals + EdgeFusedVitalsPacket in wifi-densepose-sensing-server::main. Byte layout taken directly from edge_processing.h:129, mirroring the firmware's _Static_assert(sizeof(edge_fused_vitals_pkt_t) == 48) so future firmware changes that grow the packet will break this parser loudly instead of silently.

  3. Add a dispatch arm in the UDP receive loop. Fused-vitals is tried BEFORE WASM so a stale firmware (still emitting 0xC511_0004 with the WASM payload) fails to parse as fused-vitals (size mismatch), then fails to parse as WASM (magic mismatch on the new 0x...0007), and gets dropped — a deliberate "fail loud" outcome rather than the pre-fix silent garbage.

  4. Update the registry comment in rv_feature_state.h to add the new 0x...0007 row.

  5. Add five tests in a new issue_928_magic_collision_tests mod:

  6. parse_edge_fused_vitals_extracts_fields_correctly
  7. parse_edge_fused_vitals_rejects_short_buffer
  8. parse_edge_fused_vitals_rejects_wrong_magic
  9. parse_wasm_output_rejects_legacy_0004_magic
  10. parse_wasm_output_accepts_new_0007_magic

WebSocket payload

Fused-vitals now broadcasts as {"type": "edge_fused_vitals", ...} with the mmWave-specific block nested under mmwave. Schema is additive — existing subscribers that only inspect type are unaffected; subscribers that switch on type gain a new branch.

Deployment note

This is a wire-protocol change. Firmware older than this commit that emits WASM output on 0xC511_0004 will lose its WASM event stream against an updated host (host expects 0xC511_0007). Per the issue discussion, "fail loud" is preferred to silent misparsing. Operators running C6+mmWave should reflash firmware concurrent with the host upgrade.

Test results cargo test -p wifi-densepose-sensing-server --no-default-features --bin sensing-server → 122 passed / 0 failed (5 new + 117 existing, unchanged)

Co-Authored-By: claude-flow ruv@ruv.net

Docker Image: ghcr.io/ruvnet/RuView:2c136aca7456ee5555a21fdcf7176fae38b8cf38

Source: README.md, updated 2026-06-03