Files
Joseph Doherty fe2a6db786
rust / build / test / clippy / fmt (push) Has been cancelled
Initial project state: .NET reference, design, Rust port (M0+M1), evidence
Layout:
- src/                    .NET 10 x64 reference: MxNativeCodec, MxNativeClient,
                          MxAsbClient, probes, tests, harnesses. Executable spec.
- design/                 Architectural plan for the Rust port (M0–M6), error
                          model, protocol invariants, risks (R1–R16), adversarial
                          review log (review.md).
- rust/                   Rust workspace. M0 skeleton + M1 codec parity.
                          mxaccess-codec: 215 unit tests + 2 cross-implementation
                          parity tests (byte-identical against .NET reference).
                          Other crates are M0 stubs awaiting M2+.
- captures/               Frida + netsh + pcap evidence per CLAUDE.md
                          ("captures are evidence, not throwaway logs").
- analysis/               Decompiled C# (frida/proxy/decompiled-*),
                          Ghidra exports for native DLLs (`exports/` only —
                          working state at `projects/` and AVEVA's input
                          binaries at `input/` are gitignored).
- docs/                   Reverse-engineering reference docs.
- tools/                  Setup-LiveProbeEnv.ps1 (Infisical credential fetcher),
                          Compute-Crc.ps1 (.NET parity helper).
- .github/workflows/      Rust CI: fmt + build + test + clippy on Windows.
- LICENSE                 MIT (Joseph Doherty, 2026).

Verified:
- cargo test --workspace → 217 passed (215 unit + 2 .NET parity), 0 failed
- cargo clippy --workspace -- -D warnings → clean
- cargo fmt --all -- --check → clean
- cargo publish --dry-run -p mxaccess-codec → packages cleanly

Excluded from history (see .gitignore):
- **/bin, **/obj, **/target — build artifacts
- analysis/ghidra/projects/ — Ghidra working state (regenerable)
- analysis/ghidra/input/ — AVEVA proprietary DLLs (vendor IP)

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-05 06:21:00 -04:00

12 KiB

1timeeventmodulenameecxretvalargscandidate_indexcandidate_sizecandidate_ptrvalue_hitshex
22026-04-25T16:39:04.487Zhook.installedLmxProxy.dllCLMXProxyServer.Write.variantA[]
32026-04-25T16:39:04.488Zhook.installedLmxProxy.dllCLMXProxyServer.Write.variantB[]
42026-04-25T16:39:04.488Zhook.installedLmxProxy.dllCLMXProxyServer.WriteSecured.variantA[]
52026-04-25T16:39:04.489Zhook.installedLmxProxy.dllCLMXProxyServer.WriteSecured.variantB[]
62026-04-25T16:39:04.489Zhook.installedLmxProxy.dllCLMXProxyServer.AdviseSupervisory[]
72026-04-25T16:39:11.937Zhook.installedNmxAdptr.dllCNmxAdapter.TransferData[]
82026-04-25T16:39:11.938Zhook.installedNmxAdptr.dllCNmxAdapter.ProcessDataReceived[]
92026-04-25T16:39:11.939Zhook.installedNmxAdptr.dllCNmxAdapter.PutRequest[]
102026-04-25T16:39:11.940Zhook.installedNmxAdptr.dllCNmxAdapter.PutRequestEx[]
112026-04-25T16:39:12.092Zcall.enterLmxProxy.dllCLMXProxyServer.AdviseSupervisory0xd3eef0["0x5e38ff0","0x1","0x1","0x4ed46c2e","0x74794704"]
122026-04-25T16:39:12.093Zcall.leaveLmxProxy.dllCLMXProxyServer.AdviseSupervisory0x0[]
132026-04-25T16:39:12.220Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x93ec738","0x1","0x1","0x1","0x2","0x0","0x13a","0x93f0648","0xd3ebb4","0x2c608167"]010x2
142026-04-25T16:39:12.220Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x93ec738","0x1","0x1","0x1","0x2","0x0","0x13a","0x93f0648","0xd3ebb4","0x2c608167"]13140x93f064817 01 00 01 01 00 01 00 00 00 65 00 71 00 0a 00 00 00 00 00 08 6a 00 00 00 40 00 00 81 44 00 65 00 76 00 50 00 6c 00 61 00 74 00 66 00 6f 00 72 00 6d 00 2e 00 47 00 52 00 2e 00 54 00 69 00 6d 00 65 00 4f 00 66 00 4c 00 61 00 73 00 74 00 44 00 65 00 70 00 6c 00 6f 00 79 00 00 00 02 00 00 00 00 00 02 00 00 00 00 00 02 00 00 00 00 00 01 01 00 01 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 01 d0 fc 3e 09 1f 01 00 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 00 00 01 00 00 00 17 01 00 01 01 00 01 00 00 00 65 00 71 00 0a 00 00 00 00 00 08 76 00 00 00 4c 00 00 81 44 00 65 00 76 00 50 00 6c 00 61 00 74 00 66 00 6f 00 72 00 6d 00 2e 00 47 00 52 00 2e 00 54 00 69 00 6d 00 65 00 4f 00 66 00 4c 00 61 00 73 00 74 00 43 00 6f 00 6e 00 66 00 69 00 67 00 43 00 68 00 61 00 6e 00 67 00 65 00 00 00 02 00 00 00 00 00 02 00 00 00 00 00 02 00 00 00 00 00 01 01 00 01 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 01 50 03 3f 09 20 01 00 02 00 00 00
152026-04-25T16:39:12.223Znmx.enterNmxAdptr.dllCNmxAdapter.TransferData0x93ec738["0x1","0x1","0x1","0x168","0x9d79020","0x2fef99ee","0x93f0214","0x93f0204","0x641add04","0x64"]03600x9d7902001 00 3a 01 00 00 00 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 fb 7f 00 00 01 00 00 00 01 00 00 00 01 00 00 00 01 02 00 00 30 75 00 00 17 01 00 01 01 00 01 00 00 00 65 00 71 00 0a 00 00 00 00 00 08 6a 00 00 00 40 00 00 81 44 00 65 00 76 00 50 00 6c 00 61 00 74 00 66 00 6f 00 72 00 6d 00 2e 00 47 00 52 00 2e 00 54 00 69 00 6d 00 65 00 4f 00 66 00 4c 00 61 00 73 00 74 00 44 00 65 00 70 00 6c 00 6f 00 79 00 00 00 02 00 00 00 00 00 02 00 00 00 00 00 02 00 00 00 00 00 01 01 00 01 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 01 d0 fc 3e 09 1f 01 00 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 00 00 01 00 00 00 17 01 00 01 01 00 01 00 00 00 65 00 71 00 0a 00 00 00 00 00 08 76 00 00 00 4c 00 00 81 44 00 65 00 76 00 50 00 6c 00 61 00 74 00 66 00 6f 00 72 00 6d 00 2e 00 47 00 52 00 2e 00 54 00 69 00 6d 00 65 00 4f 00 66 00 4c 00 61 00 73 00 74 00 43 00 6f 00 6e 00 66 00 69 00 67 00 43 00 68 00 61 00 6e 00 67 00 65 00 00 00 02 00 00 00 00 00 02 00 00 00 00 00 02 00 00 00 00 00 01 01 00 01 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 01 50 03 3f 09 20 01 00 02 00 00 00
162026-04-25T16:39:12.224Znmx.leaveNmxAdptr.dllCNmxAdapter.TransferData0x0[]
172026-04-25T16:39:12.224Znmx.leaveNmxAdptr.dllCNmxAdapter.PutRequest0x0[]
182026-04-25T16:39:12.225Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x93ec738","0x1","0x1","0x2","0x2","0x0","0x27","0x94be378","0xd3ebb4","0x2c608167"]020x2
192026-04-25T16:39:12.225Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x93ec738","0x1","0x1","0x2","0x2","0x0","0x27","0x94be378","0xd3ebb4","0x2c608167"]1390x94be3781f 01 00 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 00 00 05 00 36 d7 02 00 9e 00 0a 00 1a 94 00 00 03 00 00 00
202026-04-25T16:39:12.227Znmx.enterNmxAdptr.dllCNmxAdapter.TransferData0x93ec738["0x1","0x1","0x2","0x55","0x9d79020","0x2fef99ee","0x94c9584","0x94c9574","0x641add04","0x64"]0850x9d7902001 00 27 00 00 00 00 00 00 00 02 00 00 00 01 00 00 00 01 00 00 00 fb 7f 00 00 01 00 00 00 01 00 00 00 02 00 00 00 01 02 00 00 30 75 00 00 1f 01 00 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 00 00 05 00 36 d7 02 00 9e 00 0a 00 1a 94 00 00 03 00 00 00
212026-04-25T16:39:12.227Znmx.leaveNmxAdptr.dllCNmxAdapter.TransferData0x0[]
222026-04-25T16:39:12.228Znmx.leaveNmxAdptr.dllCNmxAdapter.PutRequest0x0[]
232026-04-25T16:39:12.269Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x2c2","0x1139b3c","0x769eba8","0x76ffedd8","0x93ec744","0x2c2","0x1139b3c","0x206","0x3","0x79edc04"]07060x1139b3cc2 02 00 00 01 00 94 02 00 00 00 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 fb 7f 00 00 02 02 00 00 30 75 00 00 40 1f 50 80 08 a6 00 00 00 40 00 00 91 44 00 65 00 76 00 50 00 6c 00 61 00 74 00 66 00 6f 00 72 00 6d 00 2e 00 47 00 52 00 2e 00 54 00 69 00 6d 00 65 00 4f 00 66 00 4c 00 61 00 73 00 74 00 44 00 65 00 70 00 6c 00 6f 00 79 00 00 00 18 00 00 00 44 00 65 00 76 00 50 00 6c 00 61 00 74 00 66 00 6f 00 72 00 6d 00 00 00 28 00 00 00 47 00 52 00 2e 00 54 00 69 00 6d 00 65 00 4f 00 66 00 4c 00 61 00 73 00 74 00 44 00 65 00 70 00 6c 00 6f 00 79 00 00 00 02 00 00 00 00 00 01 01 00 01 00 01 00 53 f2 9a 00 6a 00 0a 00 5f f1 00 00 01 6c 00 00 00 41 00 6e 00 20 00 69 00 6e 00 74 00 65 00 72 00 6e 00 61 00 6c 00 20 00 65 00 72 00 72 00 6f 00 72 00 20 00 6f 00 63 00 63 00 75 00 72 00 72 00 65 00 64 00 20 00 69 00 6e 00 20 00 74 00 68 00 65 00 20 00 42 00 61 00 73 00 65 00 20 00 52 00 75 00 6e 00 74 00 69 00 6d 00 65 00 20 00 4f 00 62 00 6a 00 65 00 63 00 74 00 00 00 1f 00 00 50 80 01 00 01 00 01 00 30 75 00 00 0a 18 25 03 6d ae e3 43 8d 37 6d 6c f0 ad b2 bf 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 40 1f 50 80 08 be 00 00 00 4c 00 00 91 44 00 65 00 76 00 50 00 6c 00 61 00 74 00 66 00 6f 00 72 00 6d 00 2e 00 47 00 52 00 2e 00 54 00 69 00 6d 00 65 00 4f 00 66 00 4c 00 61 00 73 00 74 00 43 00 6f 00 6e 00 66 00 69 00 67 00 43 00 68 00 61 00 6e 00 67 00 65 00 00 00 18 00 00 00 44 00 65 00 76 00 50 00 6c 00 61 00 74 00 66 00 6f 00 72 00 6d 00 00 00 34 00 00 00 47 00 52 00 2e 00 54 00 69 00 6d 00 65 00 4f 00 66 00 4c 00 61 00 73 00 74 00 43 00 6f 00 6e 00 66 00 69 00 67 00 43 00 68 00 61 00 6e 00 67 00 65 00 00 00 02 00 00 00 00 00 01 01 00 01 00 01 00 53 f2 9a 00 6b 00 0a 00 87 3a 00 00 01 6c 00 00 00 41 00 6e 00 20 00 69 00 6e 00 74 00 65 00 72 00 6e 00 61 00 6c 00 20 00 65 00 72 00 72 00 6f 00 72 00 20 00 6f 00 63 00 63 00 75 00 72 00 72 00 65 00 64 00 20 00 69 00 6e 00 20 00 74 00 68 00 65 00 20 00 42 00 61 00 73 00 65 00 20 00 52 00 75 00 6e 00 74 00 69 00 6d 00 65 00 20 00 4f 00 62 00 6a 00 65 00 63 00 74 00 00 00 20 00 00 50 80 01 00 01 00 01 00
242026-04-25T16:39:12.269Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x2c2","0x1139b3c","0x769eba8","0x76ffedd8","0x93ec744","0x2c2","0x1139b3c","0x206","0x3","0x79edc04"]15180x3
252026-04-25T16:39:12.269Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x2c2","0x1139b3c","0x769eba8","0x76ffedd8","0x93ec744","0x2c2","0x1139b3c","0x206","0x3","0x79edc04"]230x79edc0478 11 88
262026-04-25T16:39:12.271Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
272026-04-25T16:39:12.274Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x97","0x113792c","0x769eba8","0x76ffedd8","0x93ec744","0x97","0x113792c","0x206","0x3","0x79edc04"]01510x113792c97 00 00 00 01 00 69 00 00 00 00 00 00 00 84 2a 0b 00 01 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 fb 7f 00 00 01 02 00 00 30 75 00 00 32 01 00 02 00 00 00 0a 18 25 03 6d ae e3 43 8d 37 6d 6c f0 ad b2 bf 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 01 00 00 00 03 00 00 00 c0 00 20 2e 5a 46 28 d3 dc 01 06 0a 00 00 00 00 a0 41 c3 55 bd dc 01 00 00 02 00 00 00 03 00 00 00 c0 00 80 18 5b 46 28 d3 dc 01 06 0a 00 00 00 80 c1 75 25 a5 bd
282026-04-25T16:39:12.274Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x97","0x113792c","0x769eba8","0x76ffedd8","0x93ec744","0x97","0x113792c","0x206","0x3","0x79edc04"]15180x3
292026-04-25T16:39:12.274Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x97","0x113792c","0x769eba8","0x76ffedd8","0x93ec744","0x97","0x113792c","0x206","0x3","0x79edc04"]230x79edc0478 11 88
302026-04-25T16:39:12.275Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
312026-04-25T16:39:12.281Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x5c","0x1139b3c","0x769eba8","0x76ffedd8","0x93ec744","0x5c","0x1139b3c","0x206","0x3","0x79edc04"]0920x1139b3c5c 00 00 00 01 00 2e 00 00 00 00 00 00 00 02 00 00 00 01 00 00 00 01 00 00 00 02 00 00 00 01 00 00 00 01 00 00 00 fb 7f 00 00 02 02 00 00 30 75 00 00 00 00 50 80 01 00 01 00 02 00 30 75 00 00 2d 4a 4d b9 a7 7f 49 41 a0 13 22 ca 6c 81 c0 9f 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3
322026-04-25T16:39:12.281Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x5c","0x1139b3c","0x769eba8","0x76ffedd8","0x93ec744","0x5c","0x1139b3c","0x206","0x3","0x79edc04"]15180x3
332026-04-25T16:39:12.281Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x5c","0x1139b3c","0x769eba8","0x76ffedd8","0x93ec744","0x5c","0x1139b3c","0x206","0x3","0x79edc04"]230x79edc0478 11 88
342026-04-25T16:39:12.282Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
352026-04-25T16:39:12.285Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x80","0x112f0ec","0x769eba8","0x76ffedd8","0x93ec744","0x80","0x112f0ec","0x206","0x3","0x79edc04"]01280x112f0ec80 00 00 00 01 00 52 00 00 00 00 00 00 00 5e 89 05 00 01 00 00 00 01 00 00 00 02 00 00 00 01 00 00 00 01 00 00 00 fb 7f 00 00 01 02 00 00 30 75 00 00 32 01 00 01 00 00 00 2d 4a 4d b9 a7 7f 49 41 a0 13 22 ca 6c 81 c0 9f 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 03 00 00 00 03 00 00 00 c0 00 90 4e 52 68 7c d4 dc 01 05 14 00 00 00 10 00 00 00 47 00 61 00 6d 00 6d 00 61 00 4d 00
362026-04-25T16:39:12.285Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x80","0x112f0ec","0x769eba8","0x76ffedd8","0x93ec744","0x80","0x112f0ec","0x206","0x3","0x79edc04"]15180x3
372026-04-25T16:39:12.285Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x93ec738["0x80","0x112f0ec","0x769eba8","0x76ffedd8","0x93ec744","0x80","0x112f0ec","0x206","0x3","0x79edc04"]230x79edc0478 11 88
382026-04-25T16:39:12.286Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
392026-04-25T16:39:15.147Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x93ec738","0x1","0x1","0x2","0x2","0x0","0x25","0x94be9f0","0xd3ec10","0x2c60814b"]020x2
402026-04-25T16:39:15.147Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x93ec738","0x1","0x1","0x2","0x2","0x0","0x25","0x94be9f0","0xd3ec10","0x2c60814b"]1370x94be9f021 01 00 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 05 00 36 d7 02 00 9e 00 0a 00 1a 94 00 00 03 00 00 00
412026-04-25T16:39:15.148Znmx.enterNmxAdptr.dllCNmxAdapter.TransferData0x93ec738["0x1","0x1","0x2","0x53","0x9d79020","0x2fef99f2","0xd3ec60","0xd3ec50","0x641add04","0x64"]0830x9d7902001 00 25 00 00 00 00 00 00 00 03 00 00 00 01 00 00 00 01 00 00 00 fb 7f 00 00 01 00 00 00 01 00 00 00 02 00 00 00 01 02 00 00 30 75 00 00 21 01 00 7d 4e 8d dc 01 db 02 41 9e 5d a4 f3 44 10 c4 73 05 00 36 d7 02 00 9e 00 0a 00 1a 94 00 00 03 00 00 00
422026-04-25T16:39:15.149Znmx.leaveNmxAdptr.dllCNmxAdapter.TransferData0x0[]
432026-04-25T16:39:15.149Znmx.leaveNmxAdptr.dllCNmxAdapter.PutRequest0x0[]