Files
mxaccess/captures/063-frida-subscribe-elapsed-time-deadband/frida-events.tsv
T
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

14 KiB

1timeeventmodulenameecxretvalargscandidate_indexcandidate_sizecandidate_ptrvalue_hitshex
22026-04-25T19:51:27.538Zhook.installedLmxProxy.dllCLMXProxyServer.Write.variantA[]
32026-04-25T19:51:27.539Zhook.installedLmxProxy.dllCLMXProxyServer.Write.variantB[]
42026-04-25T19:51:27.539Zhook.installedLmxProxy.dllCLMXProxyServer.WriteSecured.variantA[]
52026-04-25T19:51:27.540Zhook.installedLmxProxy.dllCLMXProxyServer.WriteSecured.variantB[]
62026-04-25T19:51:27.540Zhook.installedLmxProxy.dllCLMXProxyServer.AdviseSupervisory[]
72026-04-25T19:51:40.329Zhook.installedLmx.dllMxConnection.PrebindReference[]
82026-04-25T19:51:40.330Zhook.installedLmx.dllMxConnection.UserRegisterPreboundReference[]
92026-04-25T19:51:40.331Zhook.installedLmx.dllIMxReference.GetMxHandle[]
102026-04-25T19:51:40.332Zhook.installedLmx.dllAccessManager.FixUpMxHandle[]
112026-04-25T19:51:40.333Zhook.installedLmx.dllPreboundReference.Resolve[]
122026-04-25T19:51:40.333Zhook.installedLmx.dllPreboundReference.OnPlatformResolveReferenceResults[]
132026-04-25T19:51:40.334Zhook.installedLmx.dllPreboundReference.OnSetAttributeResult[]
142026-04-25T19:51:40.407Zlmx.fixup-mxhandle.enterLmx.dllAccessManager.FixUpMxHandle[]
152026-04-25T19:51:40.407Zlmx.fixup-mxhandle.leaveLmx.dllAccessManager.FixUpMxHandle0x6fea34[]
162026-04-25T19:51:40.408Zlmx.fixup-mxhandle.enterLmx.dllAccessManager.FixUpMxHandle[]
172026-04-25T19:51:40.408Zlmx.fixup-mxhandle.leaveLmx.dllAccessManager.FixUpMxHandle0x6fea34[]
182026-04-25T19:51:40.428Zhook.installedNmxAdptr.dllCNmxAdapter.TransferData[]
192026-04-25T19:51:40.430Zhook.installedNmxAdptr.dllCNmxAdapter.ProcessDataReceived[]
202026-04-25T19:51:40.430Zhook.installedNmxAdptr.dllCNmxAdapter.PutRequest[]
212026-04-25T19:51:40.430Zhook.installedNmxAdptr.dllCNmxAdapter.PutRequestEx[]
222026-04-25T19:51:40.501Zlmx.prebind.enterLmx.dllMxConnection.PrebindReference0x10188a34[]
232026-04-25T19:51:40.502Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x6fef90[]
242026-04-25T19:51:40.503Zlmx.prebound-resolve.enterLmx.dllPreboundReference.Resolve[]
252026-04-25T19:51:40.504Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x6fef20[]
262026-04-25T19:51:40.505Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x6fef20[]
272026-04-25T19:51:40.505Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x6fef20[]
282026-04-25T19:51:40.506Zlmx.prebound-resolve.leaveLmx.dllPreboundReference.Resolve0x70fe1e01[]
292026-04-25T19:51:40.506Zlmx.prebind.leaveLmx.dllMxConnection.PrebindReference[]
302026-04-25T19:51:40.508Zcall.enterLmxProxy.dllCLMXProxyServer.AdviseSupervisory0x6ff10c["0x5978ff0","0x1","0x1","0x8c75e496","0x74794704"]
312026-04-25T19:51:40.508Zlmx.fixup-mxhandle.enterLmx.dllAccessManager.FixUpMxHandle[]
322026-04-25T19:51:40.508Zlmx.fixup-mxhandle.leaveLmx.dllAccessManager.FixUpMxHandle0x6fef8c[]
332026-04-25T19:51:40.509Zlmx.fixup-mxhandle.enterLmx.dllAccessManager.FixUpMxHandle[]
342026-04-25T19:51:40.509Zlmx.fixup-mxhandle.leaveLmx.dllAccessManager.FixUpMxHandle0x6fdc20[]
352026-04-25T19:51:40.509Zcall.leaveLmxProxy.dllCLMXProxyServer.AdviseSupervisory0x0[]
362026-04-25T19:51:40.636Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x8d6c738","0x1","0x1","0x1","0x2","0x0","0x13a","0x8d70648","0x6fedd0","0xedb8acd0"]010x2
372026-04-25T19:51:40.636Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x8d6c738","0x1","0x1","0x1","0x2","0x0","0x13a","0x8d70648","0x6fedd0","0xedb8acd0"]13140x8d7064817 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 d6 08 1f 01 00 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 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 d7 08 20 01 00 02 00 00 00
382026-04-25T19:51:40.639Znmx.enterNmxAdptr.dllCNmxAdapter.TransferData0x8d6c738["0x1","0x1","0x1","0x168","0x9713020","0x25697188","0x8d70214","0x8d70204","0x641add04","0x0"]03600x971302001 00 3a 01 00 00 00 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 fa 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 d6 08 1f 01 00 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 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 d7 08 20 01 00 02 00 00 00
392026-04-25T19:51:40.639Znmx.leaveNmxAdptr.dllCNmxAdapter.TransferData0x0[]
402026-04-25T19:51:40.640Znmx.leaveNmxAdptr.dllCNmxAdapter.PutRequest0x0[]
412026-04-25T19:51:40.641Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x8d6c738","0x1","0x1","0x2","0x2","0x0","0x27","0x8e3dfd0","0x6fedd0","0xedb8acd0"]020x2
422026-04-25T19:51:40.641Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x8d6c738","0x1","0x1","0x2","0x2","0x0","0x27","0x8e3dfd0","0x6fedd0","0xedb8acd0"]1390x8e3dfd01f 01 00 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 00 00 06 00 08 f4 7e 00 7d 00 0a 00 ac 59 00 00 03 00 00 00
432026-04-25T19:51:40.642Znmx.enterNmxAdptr.dllCNmxAdapter.TransferData0x8d6c738["0x1","0x1","0x2","0x55","0x9713020","0x25697188","0x8e49584","0x8e49574","0x641add04","0x0"]0850x971302001 00 27 00 00 00 00 00 00 00 02 00 00 00 01 00 00 00 01 00 00 00 fa 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 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 00 00 06 00 08 f4 7e 00 7d 00 0a 00 ac 59 00 00 03 00 00 00
442026-04-25T19:51:40.642Znmx.leaveNmxAdptr.dllCNmxAdapter.TransferData0x0[]
452026-04-25T19:51:40.643Znmx.leaveNmxAdptr.dllCNmxAdapter.PutRequest0x0[]
462026-04-25T19:51:40.652Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x5c","0xa0a924","0x717eb18","0x76ffedd8","0x8d6c744","0x5c","0xa0a924","0x206","0x3","0x74cdf94"]0920xa0a9245c 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 fa 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 00 c0 ac 3a 1a 83 b4 48 88 e6 43 56 87 4b 87 97 45 d3 97 30 68 7f b9 48 b8 c4 bf cd
472026-04-25T19:51:40.652Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x5c","0xa0a924","0x717eb18","0x76ffedd8","0x8d6c744","0x5c","0xa0a924","0x206","0x3","0x74cdf94"]15180x3
482026-04-25T19:51:40.652Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x5c","0xa0a924","0x717eb18","0x76ffedd8","0x8d6c744","0x5c","0xa0a924","0x206","0x3","0x74cdf94"]230x74cdf9460 a9 9f
492026-04-25T19:51:40.654Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
502026-04-25T19:51:40.657Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x70","0xa3bbac","0x717eb18","0x76ffedd8","0x8d6c744","0x70","0xa3bbac","0x206","0x3","0x74cdf94"]01120xa3bbac70 00 00 00 01 00 42 00 00 00 00 00 00 00 65 89 05 00 01 00 00 00 01 00 00 00 02 00 00 00 01 00 00 00 01 00 00 00 fa 7f 00 00 01 02 00 00 30 75 00 00 32 01 00 01 00 00 00 00 c0 ac 3a 1a 83 b4 48 88 e6 43 56 87 4b 87 97 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 03 00 00 00 00 00 00 00 c0 00 90 5c d6 49 28 d3 dc 01 07 00 00 00 00
512026-04-25T19:51:40.657Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x70","0xa3bbac","0x717eb18","0x76ffedd8","0x8d6c744","0x70","0xa3bbac","0x206","0x3","0x74cdf94"]15180x3
522026-04-25T19:51:40.657Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x70","0xa3bbac","0x717eb18","0x76ffedd8","0x8d6c744","0x70","0xa3bbac","0x206","0x3","0x74cdf94"]230x74cdf9460 a9 9f
532026-04-25T19:51:40.658Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
542026-04-25T19:51:40.673Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x2c2","0x78cc0bc","0x717eb18","0x76ffedd8","0x8d6c744","0x2c2","0x78cc0bc","0x206","0x3","0x74cdf94"]07060x78cc0bcc2 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 fa 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 6d 5e 2f 34 14 1f 63 47 81 8b 17 eb 0c b6 20 81 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 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
552026-04-25T19:51:40.673Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x2c2","0x78cc0bc","0x717eb18","0x76ffedd8","0x8d6c744","0x2c2","0x78cc0bc","0x206","0x3","0x74cdf94"]15180x3
562026-04-25T19:51:40.673Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x2c2","0x78cc0bc","0x717eb18","0x76ffedd8","0x8d6c744","0x2c2","0x78cc0bc","0x206","0x3","0x74cdf94"]230x74cdf9460 a9 9f
572026-04-25T19:51:40.675Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
582026-04-25T19:51:40.678Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x97","0x78ce2cc","0x717eb18","0x76ffedd8","0x8d6c744","0x97","0x78ce2cc","0x206","0x3","0x74cdf94"]01510x78ce2cc97 00 00 00 01 00 69 00 00 00 00 00 00 00 25 df 0b 00 01 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 01 00 00 00 fa 7f 00 00 01 02 00 00 30 75 00 00 32 01 00 02 00 00 00 6d 5e 2f 34 14 1f 63 47 81 8b 17 eb 0c b6 20 81 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 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
592026-04-25T19:51:40.678Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x97","0x78ce2cc","0x717eb18","0x76ffedd8","0x8d6c744","0x97","0x78ce2cc","0x206","0x3","0x74cdf94"]15180x3
602026-04-25T19:51:40.678Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x8d6c738["0x97","0x78ce2cc","0x717eb18","0x76ffedd8","0x8d6c744","0x97","0x78ce2cc","0x206","0x3","0x74cdf94"]230x74cdf9460 a9 9f
612026-04-25T19:51:40.679Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
622026-04-25T19:51:48.566Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x8d6c738","0x1","0x1","0x2","0x2","0x0","0x25","0x8e3e0a8","0x6fee2c","0xedb8acc4"]020x2
632026-04-25T19:51:48.566Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x8d6c738","0x1","0x1","0x2","0x2","0x0","0x25","0x8e3e0a8","0x6fee2c","0xedb8acc4"]1370x8e3e0a821 01 00 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 06 00 08 f4 7e 00 7d 00 0a 00 ac 59 00 00 03 00 00 00
642026-04-25T19:51:48.567Znmx.enterNmxAdptr.dllCNmxAdapter.TransferData0x8d6c738["0x1","0x1","0x2","0x53","0x9713020","0x2569719c","0x6fee7c","0x6fee6c","0x641add04","0x0"]0830x971302001 00 25 00 00 00 00 00 00 00 03 00 00 00 01 00 00 00 01 00 00 00 fa 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 45 d3 97 30 68 7f b9 48 b8 c4 bf cd 99 a7 a3 51 06 00 08 f4 7e 00 7d 00 0a 00 ac 59 00 00 03 00 00 00
652026-04-25T19:51:48.568Znmx.leaveNmxAdptr.dllCNmxAdapter.TransferData0x0[]
662026-04-25T19:51:48.568Znmx.leaveNmxAdptr.dllCNmxAdapter.PutRequest0x0[]