Files
mxaccess/captures/082-frida-add-buffered-plain-advise-testint/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-25T21:02:42.559Zhook.installedLmxProxy.dllCLMXProxyServer.Write.variantA[]
32026-04-25T21:02:42.560Zhook.installedLmxProxy.dllCLMXProxyServer.Write.variantB[]
42026-04-25T21:02:42.560Zhook.installedLmxProxy.dllCLMXProxyServer.WriteSecured.variantA[]
52026-04-25T21:02:42.561Zhook.installedLmxProxy.dllCLMXProxyServer.WriteSecured.variantB[]
62026-04-25T21:02:42.561Zhook.installedLmxProxy.dllCLMXProxyServer.AdviseSupervisory[]
72026-04-25T21:02:53.128Zhook.installedLmx.dllMxConnection.PrebindReference[]
82026-04-25T21:02:53.128Zhook.installedLmx.dllMxConnection.UserRegisterPreboundReference[]
92026-04-25T21:02:53.129Zhook.installedLmx.dllIMxReference.GetMxHandle[]
102026-04-25T21:02:53.130Zhook.installedLmx.dllAccessManager.FixUpMxHandle[]
112026-04-25T21:02:53.130Zhook.installedLmx.dllPreboundReference.Resolve[]
122026-04-25T21:02:53.131Zhook.installedLmx.dllPreboundReference.OnPlatformResolveReferenceResults[]
132026-04-25T21:02:53.132Zhook.installedLmx.dllPreboundReference.OnSetAttributeResult[]
142026-04-25T21:02:53.229Zhook.installedNmxAdptr.dllCNmxAdapter.TransferData[]
152026-04-25T21:02:53.230Zhook.installedNmxAdptr.dllCNmxAdapter.ProcessDataReceived[]
162026-04-25T21:02:53.230Zhook.installedNmxAdptr.dllCNmxAdapter.PutRequest[]
172026-04-25T21:02:53.231Zhook.installedNmxAdptr.dllCNmxAdapter.PutRequestEx[]
182026-04-25T21:02:53.289Zlmx.fixup-mxhandle.enterLmx.dllAccessManager.FixUpMxHandle[]
192026-04-25T21:02:53.291Zlmx.fixup-mxhandle.leaveLmx.dllAccessManager.FixUpMxHandle0x7be25c[]
202026-04-25T21:02:53.291Zlmx.fixup-mxhandle.enterLmx.dllAccessManager.FixUpMxHandle[]
212026-04-25T21:02:53.291Zlmx.fixup-mxhandle.leaveLmx.dllAccessManager.FixUpMxHandle0x7be25c[]
222026-04-25T21:02:53.392Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x7be76c[]
232026-04-25T21:02:53.393Zlmx.prebound-resolve.enterLmx.dllPreboundReference.Resolve[]
242026-04-25T21:02:53.393Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x7be70c[]
252026-04-25T21:02:53.394Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x7be6f8[]
262026-04-25T21:02:53.394Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x7be70c[]
272026-04-25T21:02:53.395Zlmx.prebound-resolve.leaveLmx.dllPreboundReference.Resolve0x70fe1e01[]
282026-04-25T21:02:53.396Zlmx.mxhandle.readLmx.dllIMxReference.GetMxHandle0x7be76c[]
292026-04-25T21:02:53.397Zlmx.user-register-prebound.enterLmx.dllMxConnection.UserRegisterPreboundReference0x916639c[]
302026-04-25T21:02:53.398Zlmx.user-register-prebound.leaveLmx.dllMxConnection.UserRegisterPreboundReference0x0[]
312026-04-25T21:02:53.522Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x908c738","0x1","0x1","0x1","0x2","0x0","0x13a","0x9090648","0x7be5fc","0x390b6112"]010x2
322026-04-25T21:02:53.522Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x908c738","0x1","0x1","0x1","0x2","0x0","0x13a","0x9090648","0x7be5fc","0x390b6112"]13140x909064817 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 08 09 1f 01 00 79 b5 69 d3 27 66 d3 4b b2 ed 96 43 5b c0 06 ff 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 09 09 20 01 00 02 00 00 00
332026-04-25T21:02:53.524Znmx.enterNmxAdptr.dllCNmxAdapter.TransferData0x908c738["0x1","0x1","0x1","0x168","0xa232020","0x8ec1ef54","0x9090214","0x9090204","0x641add04","0x64"]03600xa23202001 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 08 09 1f 01 00 79 b5 69 d3 27 66 d3 4b b2 ed 96 43 5b c0 06 ff 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 09 09 20 01 00 02 00 00 00
342026-04-25T21:02:53.525Znmx.leaveNmxAdptr.dllCNmxAdapter.TransferData0x0[]
352026-04-25T21:02:53.525Znmx.leaveNmxAdptr.dllCNmxAdapter.PutRequest0x0[]
362026-04-25T21:02:53.586Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x2c2","0xc28ba4","0x61cee88","0x76ffedd8","0x908c744","0x2c2","0xc28ba4","0x206","0x3","0x750ecc4"]07060xc28ba4c2 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 32 3e f0 9c ae 8f 79 40 bc 3a 40 38 cc ba d7 a9 79 b5 69 d3 27 66 d3 4b b2 ed 96 43 5b c0 06 ff 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
372026-04-25T21:02:53.586Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x2c2","0xc28ba4","0x61cee88","0x76ffedd8","0x908c744","0x2c2","0xc28ba4","0x206","0x3","0x750ecc4"]15180x3
382026-04-25T21:02:53.586Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x2c2","0xc28ba4","0x61cee88","0x76ffedd8","0x908c744","0x2c2","0xc28ba4","0x206","0x3","0x750ecc4"]230x750ecc4a0 12 5b
392026-04-25T21:02:53.588Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
402026-04-25T21:02:53.591Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x97","0xc2367c","0x61cee88","0x76ffedd8","0x908c744","0x97","0xc2367c","0x206","0x3","0x750ecc4"]01510xc2367c97 00 00 00 01 00 69 00 00 00 00 00 00 00 6a 22 0c 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 32 3e f0 9c ae 8f 79 40 bc 3a 40 38 cc ba d7 a9 79 b5 69 d3 27 66 d3 4b b2 ed 96 43 5b c0 06 ff 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
412026-04-25T21:02:53.591Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x97","0xc2367c","0x61cee88","0x76ffedd8","0x908c744","0x97","0xc2367c","0x206","0x3","0x750ecc4"]15180x3
422026-04-25T21:02:53.591Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x97","0xc2367c","0x61cee88","0x76ffedd8","0x908c744","0x97","0xc2367c","0x206","0x3","0x750ecc4"]230x750ecc4a0 12 5b
432026-04-25T21:02:53.592Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
442026-04-25T21:02:53.659Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x908c738","0x1","0x1","0x1","0x2","0x0","0xad","0x916a448","0x7be5fc","0x390b6112"]010x2
452026-04-25T21:02:53.659Znmx.enterNmxAdptr.dllCNmxAdapter.PutRequest0x1["0x908c738","0x1","0x1","0x1","0x2","0x0","0xad","0x916a448","0x7be5fc","0x390b6112"]11730x916a44810 01 00 01 00 00 00 fb df 86 dc 1f c4 34 4b bb 26 a9 97 35 e9 b7 57 ff ff 00 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 32 00 00 81 54 00 65 00 73 00 74 00 49 00 6e 00 74 00 2e 00 70 00 72 00 6f 00 70 00 65 00 72 00 74 00 79 00 28 00 62 00 75 00 66 00 66 00 65 00 72 00 29 00 00 00 00 00 00 00 00 00 00 00 20 00 00 00 54 00 65 00 73 00 74 00 43 00 68 00 69 00 6c 00 64 00 4f 00 62 00 6a 00 65 00 63 00 74 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 01
462026-04-25T21:02:53.661Znmx.enterNmxAdptr.dllCNmxAdapter.TransferData0x908c738["0x1","0x1","0x1","0xdb","0xa232020","0x8ec1ef54","0x90877f4","0x90877e4","0x641add04","0x64"]02190xa23202001 00 ad 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 01 00 00 00 01 02 00 00 30 75 00 00 10 01 00 01 00 00 00 fb df 86 dc 1f c4 34 4b bb 26 a9 97 35 e9 b7 57 ff ff 00 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 32 00 00 81 54 00 65 00 73 00 74 00 49 00 6e 00 74 00 2e 00 70 00 72 00 6f 00 70 00 65 00 72 00 74 00 79 00 28 00 62 00 75 00 66 00 66 00 65 00 72 00 29 00 00 00 00 00 00 00 00 00 00 00 20 00 00 00 54 00 65 00 73 00 74 00 43 00 68 00 69 00 6c 00 64 00 4f 00 62 00 6a 00 65 00 63 00 74 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 01
472026-04-25T21:02:53.661Znmx.leaveNmxAdptr.dllCNmxAdapter.TransferData0x0[]
482026-04-25T21:02:53.662Znmx.leaveNmxAdptr.dllCNmxAdapter.PutRequest0x0[]
492026-04-25T21:02:53.713Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x2e","0x74e0d54","0x61cee88","0x76ffedd8","0x908c744","0x2e","0x74e0d54","0x206","0x3","0x750ecc4"]0460x74e0d542e 00 00 00 01 00 00 00 00 00 00 00 00 00 02 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
502026-04-25T21:02:53.713Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x2e","0x74e0d54","0x61cee88","0x76ffedd8","0x908c744","0x2e","0x74e0d54","0x206","0x3","0x750ecc4"]15180x3
512026-04-25T21:02:53.713Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0x2e","0x74e0d54","0x61cee88","0x76ffedd8","0x908c744","0x2e","0x74e0d54","0x206","0x3","0x750ecc4"]230x750ecc4a0 12 5b
522026-04-25T21:02:53.715Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]
532026-04-25T21:02:53.718Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0xd3","0xc22574","0x61cee88","0x76ffedd8","0x908c744","0xd3","0xc22574","0x206","0x3","0x750ecc4"]02110xc22574d3 00 00 00 01 00 a5 00 00 00 00 00 00 00 6d 22 0c 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 11 01 00 01 00 00 00 fb df 86 dc 1f c4 34 4b bb 26 a9 97 35 e9 b7 57 00 a0 41 c3 55 bd dc 01 80 c1 75 25 a5 bd dc 01 01 08 78 00 00 00 32 00 00 81 54 00 65 00 73 00 74 00 49 00 6e 00 74 00 2e 00 70 00 72 00 6f 00 70 00 65 00 72 00 74 00 79 00 28 00 62 00 75 00 66 00 66 00 65 00 72 00 29 00 00 00 02 00 00 00 00 00 00 00 00 00 20 00 00 00 54 00 65 00 73 00 74 00 43 00 68 00 69 00 6c 00 64 00 4f 00 62 00 6a 00 65 00 63 00 74 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
542026-04-25T21:02:53.718Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0xd3","0xc22574","0x61cee88","0x76ffedd8","0x908c744","0xd3","0xc22574","0x206","0x3","0x750ecc4"]15180x3
552026-04-25T21:02:53.718Znmx.enterNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x908c738["0xd3","0xc22574","0x61cee88","0x76ffedd8","0x908c744","0xd3","0xc22574","0x206","0x3","0x750ecc4"]230x750ecc4a0 12 5b
562026-04-25T21:02:53.719Znmx.leaveNmxAdptr.dllCNmxAdapter.ProcessDataReceived0x0[]