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

81 lines
26 KiB
JSON

____
/ _ | Frida 17.9.1 - A world-class dynamic instrumentation toolkit
| (_| |
> _ | Commands:
/_/ |_| help -> Displays the help system
. . . . object? -> Display information about 'object'
. . . . exit/quit -> Exit
. . . .
. . . . More info at https://frida.re/docs/home/
. . . .
. . . . Connected to Local System (id=local)
Spawning `C:\Users\dohertj2\Desktop\mxaccess\src\MxTraceHarness\bin\Release\net481\MxTraceHarness.exe --scenario=write --tag=TestChildObject.TestStringArray[] --type=string[] --value=KA1;KB2;KC3;KD4;KE5;KF6;KG7;KH8;KI9;KJ10 --write-delay-ms=1000 --duration=6 --log=C:\Users\dohertj2\Desktop\mxaccess\captures\101-frida-write-string-array-update\harness.log --client=MxFridaTrace-101-frida-write-string-array-update`...
Spawned `C:\Users\dohertj2\Desktop\mxaccess\src\MxTraceHarness\bin\Release\net481\MxTraceHarness.exe --scenario=write --tag=TestChildObject.TestStringArray[] --type=string[] --value=KA1;KB2;KC3;KD4;KE5;KF6;KG7;KH8;KI9;KJ10 --write-delay-ms=1000 --duration=6 --log=C:\Users\dohertj2\Desktop\mxaccess\captures\101-frida-write-string-array-update\harness.log --client=MxFridaTrace-101-frida-write-string-array-update`. Resuming main thread!
[Local::MxTraceHarness.exe ]-> {"event":"hook.installed","module":"LmxProxy.dll","name":"CLMXProxyServer.Write.variantA","base":"0x65a40000","rva":"0x12c0c","address":"0x65a52c0c","time":"2026-04-25T22:04:45.164Z"}
{"event":"hook.installed","module":"LmxProxy.dll","name":"CLMXProxyServer.Write.variantB","base":"0x65a40000","rva":"0x13280","address":"0x65a53280","time":"2026-04-25T22:04:45.165Z"}
{"event":"hook.installed","module":"LmxProxy.dll","name":"CLMXProxyServer.WriteSecured.variantA","base":"0x65a40000","rva":"0x12f24","address":"0x65a52f24","time":"2026-04-25T22:04:45.165Z"}
{"event":"hook.installed","module":"LmxProxy.dll","name":"CLMXProxyServer.WriteSecured.variantB","base":"0x65a40000","rva":"0x135fe","address":"0x65a535fe","time":"2026-04-25T22:04:45.166Z"}
{"event":"hook.installed","module":"LmxProxy.dll","name":"CLMXProxyServer.AddBufferedItem","base":"0x65a40000","rva":"0x1121d","address":"0x65a5121d","time":"2026-04-25T22:04:45.167Z"}
{"event":"hook.installed","module":"LmxProxy.dll","name":"CLMXProxyServer.SetBufferedUpdateInterval","base":"0x65a40000","rva":"0xfc80","address":"0x65a4fc80","time":"2026-04-25T22:04:45.167Z"}
{"event":"hook.installed","module":"LmxProxy.dll","name":"CLMXProxyServer.AdviseSupervisory","base":"0x65a40000","rva":"0x142b4","address":"0x65a542b4","time":"2026-04-25T22:04:45.168Z"}
{"event":"hook.installed","module":"LmxProxy.dll","name":"CProxy_ILMXProxyServerEvents2.Fire_OnBufferedDataChange","base":"0x65a40000","rva":"0x163c0","address":"0x65a563c0","time":"2026-04-25T22:04:45.168Z"}
{"event":"hook.installed","module":"LmxProxy.dll","name":"CLMXProxyServer.AuthenticateUser","base":"0x65a40000","rva":"0x1399f","address":"0x65a5399f","time":"2026-04-25T22:04:45.168Z"}
{"event":"hook.installed","module":"Lmx.dll","name":"MxConnection.PrebindReference","base":"0x10000000","rva":"0xea780","address":"0x100ea780","time":"2026-04-25T22:04:52.109Z"}
{"event":"hook.installed","module":"Lmx.dll","name":"MxConnection.UserRegisterPreboundReference","base":"0x10000000","rva":"0xe1920","address":"0x100e1920","time":"2026-04-25T22:04:52.111Z"}
{"event":"hook.installed","module":"Lmx.dll","name":"IMxReference.GetMxHandle","base":"0x10000000","rva":"0x5f730","address":"0x1005f730","time":"2026-04-25T22:04:52.111Z"}
{"event":"hook.installed","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","base":"0x10000000","rva":"0x8f8b0","address":"0x1008f8b0","time":"2026-04-25T22:04:52.112Z"}
{"event":"hook.installed","module":"Lmx.dll","name":"PreboundReference.Resolve","base":"0x10000000","rva":"0x113d40","address":"0x10113d40","time":"2026-04-25T22:04:52.113Z"}
{"event":"hook.installed","module":"Lmx.dll","name":"PreboundReference.OnPlatformResolveReferenceResults","base":"0x10000000","rva":"0x1155a0","address":"0x101155a0","time":"2026-04-25T22:04:52.114Z"}
{"event":"hook.installed","module":"Lmx.dll","name":"PreboundReference.OnSetAttributeResult","base":"0x10000000","rva":"0x114a90","address":"0x10114a90","time":"2026-04-25T22:04:52.115Z"}
{"event":"hook.installed","module":"NmxAdptr.dll","name":"CNmxAdapter.TransferData","base":"0x64180000","rva":"0x10996","address":"0x64190996","time":"2026-04-25T22:04:52.211Z"}
{"event":"hook.installed","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","base":"0x64180000","rva":"0x112da","address":"0x641912da","time":"2026-04-25T22:04:52.211Z"}
{"event":"hook.installed","module":"NmxAdptr.dll","name":"CNmxAdapter.PutRequest","base":"0x64180000","rva":"0x15169","address":"0x64195169","time":"2026-04-25T22:04:52.214Z"}
{"event":"hook.installed","module":"NmxAdptr.dll","name":"CNmxAdapter.PutRequestEx","base":"0x64180000","rva":"0x159c3","address":"0x641959c3","time":"2026-04-25T22:04:52.215Z"}
{"event":"lmx.fixup-mxhandle.enter","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","accessManager":"0x9117010","outPtr":"0xafe998","inWords":[65537,65537,0,0,0,0],"time":"2026-04-25T22:04:52.232Z"}
{"event":"lmx.fixup-mxhandle.leave","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","outPtr":"0xafe998","handle":{"raw":"01 00 01 00 01 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00","w0":65537,"w1":65537,"w2":0,"w3":0,"w4":0},"retval":"0xafe998","time":"2026-04-25T22:04:52.233Z"}
{"event":"lmx.fixup-mxhandle.enter","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","accessManager":"0x9117010","outPtr":"0xafe998","inWords":[65537,65537,0,0,0,0],"time":"2026-04-25T22:04:52.233Z"}
{"event":"lmx.fixup-mxhandle.leave","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","outPtr":"0xafe998","handle":{"raw":"01 00 01 00 01 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00","w0":65537,"w1":65537,"w2":0,"w3":0,"w4":0},"retval":"0xafe998","time":"2026-04-25T22:04:52.234Z"}
{"event":"lmx.prebind.enter","module":"Lmx.dll","name":"MxConnection.PrebindReference","ecx":"0x10188a34","reference":"\u8a34\u1018\u8a20\u1018\u8a04\u1018\u89f0\u1018\u89dc\u1018\u89ac\u1018\u0004","time":"2026-04-25T22:04:52.327Z"}
{"event":"lmx.mxhandle.read","module":"Lmx.dll","name":"IMxReference.GetMxHandle","referencePtr":"0x91c0d70","outPtr":"0xafef04","handle":{"raw":"01 00 01 00 02 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff","w0":65537,"w1":327682,"w2":186166,"w3":655525,"w4":4294921053},"retval":"0xafef04","time":"2026-04-25T22:04:52.327Z"}
{"event":"lmx.prebound-resolve.enter","module":"Lmx.dll","name":"PreboundReference.Resolve","prebound":{"ptr":"0x9120588","referenceString":{"length":33,"capacity":39,"value":"TestChildObject.TestStringArray[]"},"contextString":{"length":0,"capacity":7,"value":""},"auxString":{"length":0,"capacity":7,"value":""},"mxReference":"0x91eca28","status":3,"errorText":"","raw":"08 64 19 10 f0 63 19 10 00 6f 00 6e e8 63 19 10 00 67 00 43 02 00 00 00 38 90 1f 09 00 65 00 00 00 02 00 00 00 00 00 02 21 00 00 00 27 00 00 00 00 00 00 01 00 00 01 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 07 00 00 00 01 00 02 00 28 ca 1e 09 5c 27 d3 07 00 00 00 00 00 00 00 00 00 00 00 00 10 70 11 09 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 00 07 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 00 00 00 00 00 00 00 00 03 00 00 00 f4 19 f2 00 00 00 00 00"},"time":"2026-04-25T22:04:52.328Z"}
{"event":"lmx.mxhandle.read","module":"Lmx.dll","name":"IMxReference.GetMxHandle","referencePtr":"0x91205d8","outPtr":"0xafee94","handle":{"raw":"01 00 01 00 02 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff","w0":65537,"w1":327682,"w2":186166,"w3":655525,"w4":4294921053},"retval":"0xafee94","time":"2026-04-25T22:04:52.329Z"}
{"event":"lmx.mxhandle.read","module":"Lmx.dll","name":"IMxReference.GetMxHandle","referencePtr":"0x91205d8","outPtr":"0xafee94","handle":{"raw":"01 00 01 00 02 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff","w0":65537,"w1":327682,"w2":186166,"w3":655525,"w4":4294921053},"retval":"0xafee94","time":"2026-04-25T22:04:52.329Z"}
{"event":"lmx.mxhandle.read","module":"Lmx.dll","name":"IMxReference.GetMxHandle","referencePtr":"0x91205d8","outPtr":"0xafee94","handle":{"raw":"01 00 01 00 02 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff","w0":65537,"w1":327682,"w2":186166,"w3":655525,"w4":4294921053},"retval":"0xafee94","time":"2026-04-25T22:04:52.330Z"}
{"event":"lmx.prebound-resolve.leave","module":"Lmx.dll","name":"PreboundReference.Resolve","prebound":{"ptr":"0x9120588","referenceString":{"length":33,"capacity":39,"value":"TestChildObject.TestStringArray[]"},"contextString":{"length":0,"capacity":7,"value":""},"auxString":{"length":0,"capacity":7,"value":""},"mxReference":"0x91eca28","status":3,"errorText":"","raw":"08 64 19 10 f0 63 19 10 00 6f 00 6e e8 63 19 10 00 67 00 43 02 00 00 00 38 90 1f 09 00 65 00 00 00 02 00 00 00 00 00 02 21 00 00 00 27 00 00 00 00 00 00 01 00 00 01 00 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 07 00 00 00 01 00 02 00 28 ca 1e 09 5c 27 d3 07 00 00 00 00 00 00 00 00 00 00 00 00 10 70 11 09 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 00 07 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 00 00 00 00 00 00 00 00 03 00 00 00 f4 19 f2 00 00 00 00 00"},"retval":"0x70fe1e01","time":"2026-04-25T22:04:52.331Z"}
{"event":"lmx.prebind.leave","module":"Lmx.dll","name":"MxConnection.PrebindReference","handle":6619220,"time":"2026-04-25T22:04:52.331Z"}
{"event":"call.enter","module":"LmxProxy.dll","name":"CLMXProxyServer.AdviseSupervisory","address":"0x65a542b4","ecx":"0xaff064","args":["0x5e08ff0","0x1","0x1","0x8f4c5e0","0x74794704"],"time":"2026-04-25T22:04:52.333Z"}
{"event":"lmx.fixup-mxhandle.enter","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","accessManager":"0x9117010","outPtr":"0xafeee4","inWords":[65537,327682,186166,655525,4294921053,0],"time":"2026-04-25T22:04:52.333Z"}
{"event":"lmx.fixup-mxhandle.leave","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","outPtr":"0xafeee4","handle":{"raw":"01 00 01 00 02 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff","w0":65537,"w1":327682,"w2":186166,"w3":655525,"w4":4294921053},"retval":"0xafeee4","time":"2026-04-25T22:04:52.333Z"}
{"event":"lmx.fixup-mxhandle.enter","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","accessManager":"0x9117010","outPtr":"0xafdb78","inWords":[65537,327682,186166,655525,4294921053,0],"time":"2026-04-25T22:04:52.334Z"}
{"event":"lmx.fixup-mxhandle.leave","module":"Lmx.dll","name":"AccessManager.FixUpMxHandle","outPtr":"0xafdb78","handle":{"raw":"01 00 01 00 02 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff","w0":65537,"w1":327682,"w2":186166,"w3":655525,"w4":4294921053},"retval":"0xafdb78","time":"2026-04-25T22:04:52.334Z"}
{"event":"call.leave","module":"LmxProxy.dll","name":"CLMXProxyServer.AdviseSupervisory","retval":"0x0","time":"2026-04-25T22:04:52.334Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.PutRequest","address":"0x64195169","ecx":"0x1","args":["0x911c738","0x1","0x1","0x1","0x2","0x0","0x13a","0x9120648","0xafed28","0xb41e8ea7"],"candidates":[{"sizeIndex":3,"ptrIndex":4,"size":1,"ptr":"0x2","hex":""},{"sizeIndex":6,"ptrIndex":7,"size":314,"ptr":"0x9120648","hex":"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 11 09 1f 01 00 25 c8 40 0a 09 83 87 42 b0 24 b6 f2 a3 bf 7a b6 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 12 09 20 01 00 02 00 00 00"}],"time":"2026-04-25T22:04:52.461Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.TransferData","address":"0x64190996","ecx":"0x911c738","args":["0x1","0x1","0x1","0x168","0x9ab5020","0x7c4b9942","0x9120214","0x9120204","0x641add04","0x0"],"candidates":[{"sizeIndex":3,"ptrIndex":4,"size":360,"ptr":"0x9ab5020","hex":"01 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 11 09 1f 01 00 25 c8 40 0a 09 83 87 42 b0 24 b6 f2 a3 bf 7a b6 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 12 09 20 01 00 02 00 00 00"}],"time":"2026-04-25T22:04:52.465Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.TransferData","retval":"0x0","time":"2026-04-25T22:04:52.465Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.PutRequest","retval":"0x0","time":"2026-04-25T22:04:52.466Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.PutRequest","address":"0x64195169","ecx":"0x1","args":["0x911c738","0x1","0x1","0x2","0x2","0x0","0x27","0x91ece60","0xafed28","0xb41e8ea7"],"candidates":[{"sizeIndex":3,"ptrIndex":4,"size":2,"ptr":"0x2","hex":""},{"sizeIndex":6,"ptrIndex":7,"size":39,"ptr":"0x91ece60","hex":"1f 01 00 25 c8 40 0a 09 83 87 42 b0 24 b6 f2 a3 bf 7a b6 00 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff 03 00 00 00"}],"time":"2026-04-25T22:04:52.468Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.TransferData","address":"0x64190996","ecx":"0x911c738","args":["0x1","0x1","0x2","0x55","0x9ab5020","0x7c4b9942","0x91f9634","0x91f9624","0x641add04","0x0"],"candidates":[{"sizeIndex":3,"ptrIndex":4,"size":85,"ptr":"0x9ab5020","hex":"01 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 25 c8 40 0a 09 83 87 42 b0 24 b6 f2 a3 bf 7a b6 00 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff 03 00 00 00"}],"time":"2026-04-25T22:04:52.470Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.TransferData","retval":"0x0","time":"2026-04-25T22:04:52.470Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.PutRequest","retval":"0x0","time":"2026-04-25T22:04:52.470Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","address":"0x641912da","ecx":"0x911c738","args":["0x2c2","0x7c382f4","0x729ec88","0x76ffedd8","0x911c744","0x2c2","0x7c382f4","0x206","0x3","0x772ed1c"],"candidates":[{"sizeIndex":5,"ptrIndex":6,"size":706,"ptr":"0x7c382f4","hex":"c2 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 95 8b f8 08 02 24 e3 4e 82 ea 07 2c 36 84 45 da 25 c8 40 0a 09 83 87 42 b0 24 b6 f2 a3 bf 7a b6 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"},{"sizeIndex":7,"ptrIndex":8,"size":518,"ptr":"0x3","hex":""},{"sizeIndex":8,"ptrIndex":9,"size":3,"ptr":"0x772ed1c","hex":"c0 c9 72"}],"time":"2026-04-25T22:04:52.499Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","retval":"0x0","time":"2026-04-25T22:04:52.501Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","address":"0x641912da","ecx":"0x911c738","args":["0x97","0xf0fb54","0x729ec88","0x76ffedd8","0x911c744","0x97","0xf0fb54","0x206","0x3","0x772ed1c"],"candidates":[{"sizeIndex":5,"ptrIndex":6,"size":151,"ptr":"0xf0fb54","hex":"97 00 00 00 01 00 69 00 00 00 00 00 00 00 d5 5c 0c 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 95 8b f8 08 02 24 e3 4e 82 ea 07 2c 36 84 45 da 25 c8 40 0a 09 83 87 42 b0 24 b6 f2 a3 bf 7a b6 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"},{"sizeIndex":7,"ptrIndex":8,"size":518,"ptr":"0x3","hex":""},{"sizeIndex":8,"ptrIndex":9,"size":3,"ptr":"0x772ed1c","hex":"c0 c9 72"}],"time":"2026-04-25T22:04:52.505Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","retval":"0x0","time":"2026-04-25T22:04:52.506Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","address":"0x641912da","ecx":"0x911c738","args":["0x5c","0xf10c5c","0x729ec88","0x76ffedd8","0x911c744","0x5c","0xf10c5c","0x206","0x3","0x772ed1c"],"candidates":[{"sizeIndex":5,"ptrIndex":6,"size":92,"ptr":"0xf10c5c","hex":"5c 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 2c 87 3a c9 d6 4e 1a 4a a4 f7 e7 31 f3 06 cc 88 25 c8 40 0a 09 83 87 42 b0 24 b6 f2"},{"sizeIndex":7,"ptrIndex":8,"size":518,"ptr":"0x3","hex":""},{"sizeIndex":8,"ptrIndex":9,"size":3,"ptr":"0x772ed1c","hex":"c0 c9 72"}],"time":"2026-04-25T22:04:52.523Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","retval":"0x0","time":"2026-04-25T22:04:52.525Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","address":"0x641912da","ecx":"0x911c738","args":["0x146","0xf0fb54","0x729ec88","0x76ffedd8","0x911c744","0x146","0xf0fb54","0x206","0x3","0x772ed1c"],"candidates":[{"sizeIndex":5,"ptrIndex":6,"size":326,"ptr":"0xf0fb54","hex":"46 01 00 00 01 00 18 01 00 00 00 00 00 00 c9 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 2c 87 3a c9 d6 4e 1a 4a a4 f7 e7 31 f3 06 cc 88 25 c8 40 0a 09 83 87 42 b0 24 b6 f2 a3 bf 7a b6 03 00 00 00 03 00 00 00 c0 00 80 4c b4 bf ac d4 dc 01 45 00 00 00 00 0a 00 04 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 41 00 41 00 31 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 42 00 42 00 32 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 43 00 43 00 33 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 44 00 44 00 34 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 45 00 45 00 35 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 46 00 46 00 36 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 47 00 47 00 37 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 48 00 48 00 38 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 49 00 49 00 39 00 00 00 13 00 00 00 05 0e 00 00 00 0a 00 00 00 4a 00 4a 00 31 00"},{"sizeIndex":7,"ptrIndex":8,"size":518,"ptr":"0x3","hex":""},{"sizeIndex":8,"ptrIndex":9,"size":3,"ptr":"0x772ed1c","hex":"c0 c9 72"}],"time":"2026-04-25T22:04:52.529Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","retval":"0x0","time":"2026-04-25T22:04:52.530Z"}
{"event":"call.enter","module":"LmxProxy.dll","name":"CLMXProxyServer.Write.variantA","address":"0x65a52c0c","ecx":"0xaff038","args":["0x5e08ff0","0x1","0x1","0x2008","0x0","0x7c1a908","0x0","0x0","0x8f4c5e0","0x74794704"],"time":"2026-04-25T22:04:53.381Z"}
{"event":"call.leave","module":"LmxProxy.dll","name":"CLMXProxyServer.Write.variantA","retval":"0x0","time":"2026-04-25T22:04:53.381Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.PutRequest","address":"0x64195169","ecx":"0x1","args":["0x911c738","0x1","0x1","0x2","0x2","0x0","0x102","0x91fa2e0","0xafed28","0xb41e8ea7"],"candidates":[{"sizeIndex":3,"ptrIndex":4,"size":2,"ptr":"0x2","hex":""},{"sizeIndex":6,"ptrIndex":7,"size":258,"ptr":"0x91fa2e0","hex":"37 01 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff 45 00 00 00 00 0a 00 04 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 41 00 31 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 42 00 32 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 43 00 33 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 44 00 34 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 45 00 35 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 46 00 36 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 47 00 37 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 48 00 38 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 49 00 39 00 00 00 13 00 00 00 05 0e 00 00 00 0a 00 00 00 4b 00 4a 00 31 00 30 00 00 00 ff ff 00 00 00 00 00 00 00 00 45 12 13 0c 01 00 00 00"}],"time":"2026-04-25T22:04:53.434Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.TransferData","address":"0x64190996","ecx":"0x911c738","args":["0x1","0x1","0x2","0x130","0x9ab5020","0x7c4b9942","0x91177f4","0x91177e4","0x641add04","0x0"],"candidates":[{"sizeIndex":3,"ptrIndex":4,"size":304,"ptr":"0x9ab5020","hex":"01 00 02 01 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 37 01 00 05 00 36 d7 02 00 a5 00 0a 00 5d 4b ff ff 45 00 00 00 00 0a 00 04 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 41 00 31 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 42 00 32 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 43 00 33 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 44 00 34 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 45 00 35 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 46 00 36 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 47 00 37 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 48 00 38 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 49 00 39 00 00 00 13 00 00 00 05 0e 00 00 00 0a 00 00 00 4b 00 4a 00 31 00 30 00 00 00 ff ff 00 00 00 00 00 00 00 00 45 12 13 0c 01 00 00 00"}],"time":"2026-04-25T22:04:53.436Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.TransferData","retval":"0x0","time":"2026-04-25T22:04:53.437Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.PutRequest","retval":"0x0","time":"2026-04-25T22:04:53.437Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","address":"0x641912da","ecx":"0x911c738","args":["0x33","0x7c3b60c","0x729ec88","0x76ffedd8","0x911c744","0x33","0x7c3b60c","0x206","0x3","0x772ed1c"],"candidates":[{"sizeIndex":5,"ptrIndex":6,"size":51,"ptr":"0x7c3b60c","hex":"33 00 00 00 01 00 05 00 00 00 00 00 00 00 03 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"},{"sizeIndex":7,"ptrIndex":8,"size":518,"ptr":"0x3","hex":""},{"sizeIndex":8,"ptrIndex":9,"size":3,"ptr":"0x772ed1c","hex":"c0 c9 72"}],"time":"2026-04-25T22:04:53.474Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","retval":"0x0","time":"2026-04-25T22:04:53.476Z"}
{"event":"nmx.enter","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","address":"0x641912da","ecx":"0x911c738","args":["0x132","0x7c382f4","0x729ec88","0x76ffedd8","0x911c744","0x132","0x7c382f4","0x206","0x3","0x772ed1c"],"candidates":[{"sizeIndex":5,"ptrIndex":6,"size":306,"ptr":"0x7c382f4","hex":"32 01 00 00 01 00 04 01 00 00 00 00 00 00 ca 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 33 01 00 01 00 00 00 2c 87 3a c9 d6 4e 1a 4a a4 f7 e7 31 f3 06 cc 88 03 00 00 00 c0 00 00 b6 65 8b ff d4 dc 01 45 00 00 00 00 0a 00 04 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 41 00 31 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 42 00 32 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 43 00 33 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 44 00 34 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 45 00 35 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 46 00 36 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 47 00 37 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 48 00 38 00 00 00 11 00 00 00 05 0c 00 00 00 08 00 00 00 4b 00 49 00 39 00 00 00 13 00 00 00 05 0e 00 00 00 0a 00 00 00 4b 00 4a 00 31 00"},{"sizeIndex":7,"ptrIndex":8,"size":518,"ptr":"0x3","hex":""},{"sizeIndex":8,"ptrIndex":9,"size":3,"ptr":"0x772ed1c","hex":"c0 c9 72"}],"time":"2026-04-25T22:04:53.479Z"}
{"event":"nmx.leave","module":"NmxAdptr.dll","name":"CNmxAdapter.ProcessDataReceived","retval":"0x0","time":"2026-04-25T22:04:53.480Z"}
Process terminated
Thank you for using Frida!