From 1ae0f43fcefac7d51fa6e973ab1aa03ca694223c Mon Sep 17 00:00:00 2001 From: Duncan Ogilvie Date: Tue, 17 Dec 2024 15:04:21 +0100 Subject: [PATCH 1/8] Move rust tests to a separate crate https://github.com/PyO3/pyo3/issues/340 --- Cargo.lock | 20 +- Cargo.toml | 11 +- tests/Cargo.lock | 1163 +++++++++++++++++++++++++++++++++ tests/Cargo.toml | 11 + src/main.rs => tests/tests.rs | 5 +- 5 files changed, 1193 insertions(+), 17 deletions(-) create mode 100644 tests/Cargo.lock create mode 100644 tests/Cargo.toml rename src/main.rs => tests/tests.rs (98%) diff --git a/Cargo.lock b/Cargo.lock index 459b066..3904a3e 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -612,9 +612,9 @@ dependencies = [ [[package]] name = "pyo3" -version = "0.23.2" +version = "0.23.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f54b3d09cbdd1f8c20650b28e7b09e338881482f4aa908a5f61a00c98fba2690" +checksum = "e484fd2c8b4cb67ab05a318f1fd6fa8f199fcc30819f08f07d200809dba26c15" dependencies = [ "cfg-if", "indexmap", @@ -631,9 +631,9 @@ dependencies = [ [[package]] name = "pyo3-build-config" -version = "0.23.2" +version = "0.23.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3015cf985888fe66cfb63ce0e321c603706cd541b7aec7ddd35c281390af45d8" +checksum = "dc0e0469a84f208e20044b98965e1561028180219e35352a2afaf2b942beff3b" dependencies = [ "once_cell", "target-lexicon", @@ -641,9 +641,9 @@ dependencies = [ [[package]] name = "pyo3-ffi" -version = "0.23.2" +version = "0.23.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6fca7cd8fd809b5ac4eefb89c1f98f7a7651d3739dfb341ca6980090f554c270" +checksum = "eb1547a7f9966f6f1a0f0227564a9945fe36b90da5a93b3933fc3dc03fae372d" dependencies = [ "libc", "pyo3-build-config", @@ -651,9 +651,9 @@ dependencies = [ [[package]] name = "pyo3-macros" -version = "0.23.2" +version = "0.23.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "34e657fa5379a79151b6ff5328d9216a84f55dc93b17b08e7c3609a969b73aa0" +checksum = "fdb6da8ec6fa5cedd1626c886fc8749bdcbb09424a86461eb8cdf096b7c33257" dependencies = [ "proc-macro2", "pyo3-macros-backend", @@ -663,9 +663,9 @@ dependencies = [ [[package]] name = "pyo3-macros-backend" -version = "0.23.2" +version = "0.23.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "295548d5ffd95fd1981d2d3cf4458831b21d60af046b729b6fd143b0ba7aee2f" +checksum = "38a385202ff5a92791168b1136afae5059d3ac118457bb7bc304c197c2d33e7d" dependencies = [ "heck", "proc-macro2", diff --git a/Cargo.toml b/Cargo.toml index dbe3a35..1fe44cc 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -7,7 +7,7 @@ edition = "2021" [lib] name = "icicle" -crate-type = ["cdylib"] +crate-type = ["cdylib", "lib"] [dependencies] icicle-cpu = { path = "icicle-emu/icicle-cpu" } @@ -15,10 +15,15 @@ icicle-vm = { path = "icicle-emu/icicle-vm" } pcode = { path = "icicle-emu/sleigh/pcode" } sleigh-runtime = { path = "icicle-emu/sleigh/sleigh-runtime" } indexmap = "2.2.6" -pyo3 = { version = "0.23.2", features = ["extension-module", "indexmap", "abi3-py37"] } +pyo3 = { version = "0.23.3", features = ["indexmap", "abi3-py37"] } target-lexicon = "0.12.7" tracing = "*" tracing-subscriber = "0.3.17" [build-dependencies] -pyo3-build-config = "0.23.2" +pyo3-build-config = "0.23.3" + +# Reference: https://github.com/PyO3/pyo3/issues/340 +[features] +extension-module = ["pyo3/extension-module"] +default = ["extension-module"] diff --git a/tests/Cargo.lock b/tests/Cargo.lock new file mode 100644 index 0000000..4181e57 --- /dev/null +++ b/tests/Cargo.lock @@ -0,0 +1,1163 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 4 + +[[package]] +name = "addr2line" +version = "0.24.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dfbe277e56a376000877090da837660b4427aad530e3028d44e0bffe4f89a1c1" +dependencies = [ + "cpp_demangle", + "fallible-iterator", + "gimli", + "memmap2", + "object", + "rustc-demangle", + "smallvec", + "typed-arena", +] + +[[package]] +name = "adler2" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "512761e0bb2578dd7380c6baaa0f4ce03e84f95e960231d1dec8bf4d7d6e2627" + +[[package]] +name = "ahash" +version = "0.8.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e89da841a80418a9b391ebaea17f5c112ffaaa96f621d2c285b5174da76b9011" +dependencies = [ + "cfg-if", + "getrandom", + "once_cell", + "version_check", + "zerocopy", +] + +[[package]] +name = "anyhow" +version = "1.0.94" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c1fd03a028ef38ba2276dce7e33fcd6369c158a1bca17946c4b1b701891c1ff7" + +[[package]] +name = "arbitrary" +version = "1.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dde20b3d026af13f561bdd0f15edf01fc734f0dafcedbaf42bba506a9517f223" + +[[package]] +name = "autocfg" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ace50bade8e6234aa140d9a2f552bbee1db4d353f69b8217bc503490fc1a9f26" + +[[package]] +name = "base64" +version = "0.21.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567" + +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + +[[package]] +name = "bitflags" +version = "2.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b048fb63fd8b5923fc5aa7b340d8e156aec7ec02f0c78fa8a6ddc2613f6f71de" +dependencies = [ + "serde", +] + +[[package]] +name = "bstr" +version = "1.11.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "786a307d683a5bf92e6fd5fd69a7eb613751668d1d8d67d802846dfe367c62c8" +dependencies = [ + "memchr", + "serde", +] + +[[package]] +name = "bumpalo" +version = "3.16.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "79296716171880943b8470b5f8d03aa55eb2e645a4874bdbb28adb49162e012c" + +[[package]] +name = "bytemuck" +version = "1.20.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8b37c88a63ffd85d15b406896cc343916d7cf57838a847b3a6f2ca5d39a5695a" + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "cpp_demangle" +version = "0.4.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "96e58d342ad113c2b878f16d5d034c03be492ae460cdbc02b7f0f2284d310c7d" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "cranelift" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "27711210499725bafe52c320a988e27283e6cf477ee8edac57e8275bef8ea550" +dependencies = [ + "cranelift-codegen", + "cranelift-frontend", + "cranelift-module", +] + +[[package]] +name = "cranelift-bforest" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "540b193ff98b825a1f250a75b3118911af918a734154c69d80bcfcf91e7e9522" +dependencies = [ + "cranelift-entity", +] + +[[package]] +name = "cranelift-bitset" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c7cb269598b9557ab942d687d3c1086d77c4b50dcf35813f3a65ba306fd42279" + +[[package]] +name = "cranelift-codegen" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "46566d7c83a8bff4150748d66020f4c7224091952aa4b4df1ec4959c39d937a1" +dependencies = [ + "bumpalo", + "cranelift-bforest", + "cranelift-bitset", + "cranelift-codegen-meta", + "cranelift-codegen-shared", + "cranelift-control", + "cranelift-entity", + "cranelift-isle", + "gimli", + "hashbrown 0.14.5", + "log", + "regalloc2", + "rustc-hash", + "smallvec", + "target-lexicon", +] + +[[package]] +name = "cranelift-codegen-meta" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2df8a86a34236cc75a8a6a271973da779c2aeb36c43b6e14da474cf931317082" +dependencies = [ + "cranelift-codegen-shared", +] + +[[package]] +name = "cranelift-codegen-shared" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cf75340b6a57b7c7c1b74f10d3d90883ee6d43a554be8131a4046c2ebcf5eb65" + +[[package]] +name = "cranelift-control" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2e84495bc5d23d86aad8c86f8ade4af765b94882af60d60e271d3153942f1978" +dependencies = [ + "arbitrary", +] + +[[package]] +name = "cranelift-entity" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "963c17147b80df351965e57c04d20dbedc85bcaf44c3436780a59a3f1ff1b1c2" +dependencies = [ + "cranelift-bitset", +] + +[[package]] +name = "cranelift-frontend" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "727f02acbc4b4cb2ba38a6637101d579db50190df1dd05168c68e762851a3dd5" +dependencies = [ + "cranelift-codegen", + "log", + "smallvec", + "target-lexicon", +] + +[[package]] +name = "cranelift-isle" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "32b00cc2e03c748f2531eea01c871f502b909d30295fdcad43aec7bf5c5b4667" + +[[package]] +name = "cranelift-jit" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f74630af581f32b99c8f4e06ee45799383ecc0795e3ff8aa86b7584bb2d643fd" +dependencies = [ + "anyhow", + "cranelift-codegen", + "cranelift-control", + "cranelift-entity", + "cranelift-module", + "cranelift-native", + "libc", + "log", + "region", + "target-lexicon", + "wasmtime-jit-icache-coherence", + "windows-sys 0.59.0", +] + +[[package]] +name = "cranelift-module" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6aaa16c4f18a15be310df221ea544f516acc42fc58ca96e09a3d08651744efa1" +dependencies = [ + "anyhow", + "cranelift-codegen", + "cranelift-control", +] + +[[package]] +name = "cranelift-native" +version = "0.113.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bbeaf978dc7c1a2de8bbb9162510ed218eb156697bc45590b8fbdd69bb08e8de" +dependencies = [ + "cranelift-codegen", + "libc", + "target-lexicon", +] + +[[package]] +name = "crc32fast" +version = "1.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a97769d94ddab943e4510d138150169a2758b5ef3eb191a9ee688de3e23ef7b3" +dependencies = [ + "cfg-if", +] + +[[package]] +name = "crunchy" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7a81dae078cea95a014a339291cec439d2f232ebe854a9d672b796c6afafa9b7" + +[[package]] +name = "equivalent" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" + +[[package]] +name = "errno" +version = "0.3.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "33d852cb9b869c2a9b3df2f71a3074817f01e1844f839a144f5fcef059a4eb5d" +dependencies = [ + "libc", + "windows-sys 0.59.0", +] + +[[package]] +name = "fallible-iterator" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2acce4a10f12dc2fb14a218589d4f1f62ef011b2d0cc4b3cb1bba8e94da14649" + +[[package]] +name = "flate2" +version = "1.0.35" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c936bfdafb507ebbf50b8074c54fa31c5be9a1e7e5f467dd659697041407d07c" +dependencies = [ + "crc32fast", + "miniz_oxide", +] + +[[package]] +name = "foldhash" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f81ec6369c545a7d40e4589b5597581fa1c441fe1cce96dd1de43159910a36a2" + +[[package]] +name = "getrandom" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c4567c8db10ae91089c99af84c68c38da3ec2f087c3f82960bcdbf3656b6f4d7" +dependencies = [ + "cfg-if", + "libc", + "wasi", +] + +[[package]] +name = "gimli" +version = "0.31.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "07e28edb80900c19c28f1072f2e8aeca7fa06b23cd4169cefe1af5aa3260783f" +dependencies = [ + "fallible-iterator", + "indexmap", + "stable_deref_trait", +] + +[[package]] +name = "half" +version = "2.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6dd08c532ae367adf81c312a4580bc67f1d0fe8bc9c460520283f4c0ff277888" +dependencies = [ + "cfg-if", + "crunchy", +] + +[[package]] +name = "hashbrown" +version = "0.14.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e5274423e17b7c9fc20b6e7e208532f9b19825d82dfd615708b70edd83df41f1" +dependencies = [ + "ahash", +] + +[[package]] +name = "hashbrown" +version = "0.15.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bf151400ff0baff5465007dd2f3e717f3fe502074ca563069ce3a6629d07b289" +dependencies = [ + "foldhash", +] + +[[package]] +name = "heck" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2304e00983f87ffb38b55b444b5e3b60a884b5d30c0fca7d82fe33449bbe55ea" + +[[package]] +name = "icicle-cpu" +version = "0.1.0" +dependencies = [ + "addr2line", + "ahash", + "anyhow", + "bitflags 2.6.0", + "bytemuck", + "gimli", + "half", + "icicle-mem", + "object", + "pcode", + "sleigh-runtime", + "target-lexicon", + "tracing", +] + +[[package]] +name = "icicle-jit" +version = "0.2.0" +dependencies = [ + "cranelift", + "cranelift-codegen", + "cranelift-jit", + "cranelift-module", + "cranelift-native", + "icicle-cpu", + "memoffset", + "pcode", + "target-lexicon", + "tracing", + "wasmtime-jit-debug", +] + +[[package]] +name = "icicle-linux" +version = "0.1.0" +dependencies = [ + "bitflags 2.6.0", + "bstr", + "bytemuck", + "icicle-cpu", + "object", + "pcode", + "sleigh-runtime", + "target-lexicon", + "tracing", +] + +[[package]] +name = "icicle-mem" +version = "0.3.0" +dependencies = [ + "tracing", +] + +[[package]] +name = "icicle-python" +version = "0.0.5" +dependencies = [ + "icicle-cpu", + "icicle-vm", + "indexmap", + "pcode", + "pyo3", + "pyo3-build-config", + "sleigh-runtime", + "target-lexicon", + "tracing", + "tracing-subscriber", +] + +[[package]] +name = "icicle-vm" +version = "0.2.0" +dependencies = [ + "anyhow", + "icicle-cpu", + "icicle-jit", + "icicle-linux", + "ihex", + "object", + "pcode", + "ron", + "serde", + "serde-xml-rs", + "sleigh-compile", + "sleigh-runtime", + "target-lexicon", + "tracing", +] + +[[package]] +name = "ihex" +version = "3.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "365a784774bb381e8c19edb91190a90d7f2625e057b55de2bc0f6b57bc779ff2" + +[[package]] +name = "indexmap" +version = "2.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "62f822373a4fe84d4bb149bf54e584a7f4abec90e072ed49cda0edea5b95471f" +dependencies = [ + "equivalent", + "hashbrown 0.15.2", +] + +[[package]] +name = "indoc" +version = "2.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b248f5224d1d606005e02c97f5aa4e88eeb230488bcc03bc9ca4d7991399f2b5" + +[[package]] +name = "lazy_static" +version = "1.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bbd2bcb4c963f2ddae06a2efc7e9f3591312473c50c6685e1f298068316e66fe" + +[[package]] +name = "libc" +version = "0.2.168" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5aaeb2981e0606ca11d79718f8bb01164f1d6ed75080182d3abf017e6d244b6d" + +[[package]] +name = "linux-raw-sys" +version = "0.4.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "78b3ae25bc7c8c38cec158d1f2757ee79e9b3740fbc7ccf0e59e4b08d793fa89" + +[[package]] +name = "log" +version = "0.4.22" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a7a70ba024b9dc04c27ea2f0c0548feb474ec5c54bba33a7f72f873a39d07b24" + +[[package]] +name = "mach2" +version = "0.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "19b955cdeb2a02b9117f121ce63aa52d08ade45de53e48fe6a38b39c10f6f709" +dependencies = [ + "libc", +] + +[[package]] +name = "memchr" +version = "2.7.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "78ca9ab1a0babb1e7d5695e3530886289c18cf2f87ec19a575a0abdce112e3a3" + +[[package]] +name = "memmap2" +version = "0.9.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fd3f7eed9d3848f8b98834af67102b720745c4ec028fcd0aa0239277e7de374f" +dependencies = [ + "libc", +] + +[[package]] +name = "memoffset" +version = "0.9.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "488016bfae457b036d996092f6cb448677611ce4449e970ceaf42695203f218a" +dependencies = [ + "autocfg", +] + +[[package]] +name = "miniz_oxide" +version = "0.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a2ef2593ffb6958c941575cee70c8e257438749971869c4ae5acf6f91a168a61" +dependencies = [ + "adler2", +] + +[[package]] +name = "nu-ansi-term" +version = "0.46.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "77a8165726e8236064dbb45459242600304b42a5ea24ee2948e18e023bf7ba84" +dependencies = [ + "overload", + "winapi", +] + +[[package]] +name = "object" +version = "0.36.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "aedf0a2d09c573ed1d8d85b30c119153926a2b36dce0ab28322c09a117a4683e" +dependencies = [ + "crc32fast", + "flate2", + "hashbrown 0.15.2", + "indexmap", + "memchr", + "ruzstd", +] + +[[package]] +name = "once_cell" +version = "1.20.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1261fe7e33c73b354eab43b1273a57c8f967d0391e80353e51f764ac02cf6775" + +[[package]] +name = "overload" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39" + +[[package]] +name = "pcode" +version = "0.2.0" + +[[package]] +name = "pin-project-lite" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "915a1e146535de9163f3987b8944ed8cf49a18bb0056bcebcdcece385cece4ff" + +[[package]] +name = "portable-atomic" +version = "1.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "280dc24453071f1b63954171985a0b0d30058d287960968b9b2aca264c8d4ee6" + +[[package]] +name = "proc-macro2" +version = "1.0.92" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "37d3544b3f2748c54e147655edb5025752e2303145b5aefb3c3ea2c78b973bb0" +dependencies = [ + "unicode-ident", +] + +[[package]] +name = "pyo3" +version = "0.23.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e484fd2c8b4cb67ab05a318f1fd6fa8f199fcc30819f08f07d200809dba26c15" +dependencies = [ + "cfg-if", + "indexmap", + "indoc", + "libc", + "memoffset", + "once_cell", + "portable-atomic", + "pyo3-build-config", + "pyo3-ffi", + "pyo3-macros", + "unindent", +] + +[[package]] +name = "pyo3-build-config" +version = "0.23.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc0e0469a84f208e20044b98965e1561028180219e35352a2afaf2b942beff3b" +dependencies = [ + "once_cell", + "target-lexicon", +] + +[[package]] +name = "pyo3-ffi" +version = "0.23.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "eb1547a7f9966f6f1a0f0227564a9945fe36b90da5a93b3933fc3dc03fae372d" +dependencies = [ + "libc", + "pyo3-build-config", +] + +[[package]] +name = "pyo3-macros" +version = "0.23.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fdb6da8ec6fa5cedd1626c886fc8749bdcbb09424a86461eb8cdf096b7c33257" +dependencies = [ + "proc-macro2", + "pyo3-macros-backend", + "quote", + "syn", +] + +[[package]] +name = "pyo3-macros-backend" +version = "0.23.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "38a385202ff5a92791168b1136afae5059d3ac118457bb7bc304c197c2d33e7d" +dependencies = [ + "heck", + "proc-macro2", + "pyo3-build-config", + "quote", + "syn", +] + +[[package]] +name = "quote" +version = "1.0.37" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b5b9d34b8991d19d98081b46eacdd8eb58c6f2b201139f7c5f643cc155a633af" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "regalloc2" +version = "0.10.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "12908dbeb234370af84d0579b9f68258a0f67e201412dd9a2814e6f45b2fc0f0" +dependencies = [ + "hashbrown 0.14.5", + "log", + "rustc-hash", + "slice-group-by", + "smallvec", +] + +[[package]] +name = "region" +version = "3.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e6b6ebd13bc009aef9cd476c1310d49ac354d36e240cf1bd753290f3dc7199a7" +dependencies = [ + "bitflags 1.3.2", + "libc", + "mach2", + "windows-sys 0.52.0", +] + +[[package]] +name = "ron" +version = "0.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b91f7eff05f748767f183df4320a63d6936e9c6107d97c9e6bdd9784f4289c94" +dependencies = [ + "base64", + "bitflags 2.6.0", + "serde", + "serde_derive", +] + +[[package]] +name = "rustc-demangle" +version = "0.1.24" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "719b953e2095829ee67db738b3bfa9fa368c94900df327b3f07fe6e794d2fe1f" + +[[package]] +name = "rustc-hash" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c7fb8039b3032c191086b10f11f319a6e99e1e82889c5cc6046f515c9db1d497" + +[[package]] +name = "rustix" +version = "0.38.42" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f93dc38ecbab2eb790ff964bb77fa94faf256fd3e73285fd7ba0903b76bedb85" +dependencies = [ + "bitflags 2.6.0", + "errno", + "libc", + "linux-raw-sys", + "windows-sys 0.59.0", +] + +[[package]] +name = "ruzstd" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fad02996bfc73da3e301efe90b1837be9ed8f4a462b6ed410aa35d00381de89f" +dependencies = [ + "twox-hash", +] + +[[package]] +name = "serde" +version = "1.0.216" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b9781016e935a97e8beecf0c933758c97a5520d32930e460142b4cd80c6338e" +dependencies = [ + "serde_derive", +] + +[[package]] +name = "serde-xml-rs" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fb3aa78ecda1ebc9ec9847d5d3aba7d618823446a049ba2491940506da6e2782" +dependencies = [ + "log", + "serde", + "thiserror", + "xml-rs", +] + +[[package]] +name = "serde_derive" +version = "1.0.216" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "46f859dbbf73865c6627ed570e78961cd3ac92407a2d117204c49232485da55e" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "sharded-slab" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f40ca3c46823713e0d4209592e8d6e826aa57e928f09752619fc696c499637f6" +dependencies = [ + "lazy_static", +] + +[[package]] +name = "sleigh-compile" +version = "0.3.0" +dependencies = [ + "pcode", + "serde", + "serde-xml-rs", + "serde_derive", + "sleigh-parse", + "sleigh-runtime", +] + +[[package]] +name = "sleigh-parse" +version = "0.3.0" + +[[package]] +name = "sleigh-runtime" +version = "0.1.0" +dependencies = [ + "pcode", + "sleigh-parse", +] + +[[package]] +name = "slice-group-by" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "826167069c09b99d56f31e9ae5c99049e932a98c9dc2dac47645b08dbbf76ba7" + +[[package]] +name = "smallvec" +version = "1.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c5e1a9a646d36c3599cd173a41282daf47c44583ad367b8e6837255952e5c67" + +[[package]] +name = "stable_deref_trait" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a8f112729512f8e442d81f95a8a7ddf2b7c6b8a1a6f509a95864142b30cab2d3" + +[[package]] +name = "static_assertions" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a2eb9349b6444b326872e140eb1cf5e7c522154d69e7a0ffb0fb81c06b37543f" + +[[package]] +name = "syn" +version = "2.0.90" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "919d3b74a5dd0ccd15aeb8f93e7006bd9e14c295087c9896a110f490752bcf31" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "target-lexicon" +version = "0.12.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "61c41af27dd6d1e27b1b16b489db798443478cef1f06a660c96db617ba5de3b1" + +[[package]] +name = "tests" +version = "0.0.0" +dependencies = [ + "icicle-python", + "pyo3", +] + +[[package]] +name = "thiserror" +version = "1.0.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b6aaf5339b578ea85b50e080feb250a3e8ae8cfcdff9a461c9ec2904bc923f52" +dependencies = [ + "thiserror-impl", +] + +[[package]] +name = "thiserror-impl" +version = "1.0.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4fee6c4efc90059e10f81e6d42c60a18f76588c3d74cb83a0b242a2b6c7504c1" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "thread_local" +version = "1.1.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8b9ef9bad013ada3808854ceac7b46812a6465ba368859a37e2100283d2d719c" +dependencies = [ + "cfg-if", + "once_cell", +] + +[[package]] +name = "tracing" +version = "0.1.41" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "784e0ac535deb450455cbfa28a6f0df145ea1bb7ae51b821cf5e7927fdcfbdd0" +dependencies = [ + "pin-project-lite", + "tracing-attributes", + "tracing-core", +] + +[[package]] +name = "tracing-attributes" +version = "0.1.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "395ae124c09f9e6918a2310af6038fba074bcf474ac352496d5910dd59a2226d" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "tracing-core" +version = "0.1.33" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e672c95779cf947c5311f83787af4fa8fffd12fb27e4993211a84bdfd9610f9c" +dependencies = [ + "once_cell", + "valuable", +] + +[[package]] +name = "tracing-log" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ee855f1f400bd0e5c02d150ae5de3840039a3f54b025156404e34c23c03f47c3" +dependencies = [ + "log", + "once_cell", + "tracing-core", +] + +[[package]] +name = "tracing-subscriber" +version = "0.3.19" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e8189decb5ac0fa7bc8b96b7cb9b2701d60d48805aca84a238004d665fcc4008" +dependencies = [ + "nu-ansi-term", + "sharded-slab", + "smallvec", + "thread_local", + "tracing-core", + "tracing-log", +] + +[[package]] +name = "twox-hash" +version = "1.6.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "97fee6b57c6a41524a810daee9286c02d7752c4253064d0b05472833a438f675" +dependencies = [ + "cfg-if", + "static_assertions", +] + +[[package]] +name = "typed-arena" +version = "2.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6af6ae20167a9ece4bcb41af5b80f8a1f1df981f6391189ce00fd257af04126a" + +[[package]] +name = "unicode-ident" +version = "1.0.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "adb9e6ca4f869e1180728b7950e35922a7fc6397f7b641499e8f3ef06e50dc83" + +[[package]] +name = "unindent" +version = "0.2.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c7de7d73e1754487cb58364ee906a499937a0dfabd86bcb980fa99ec8c8fa2ce" + +[[package]] +name = "valuable" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "830b7e5d4d90034032940e4ace0d9a9a057e7a45cd94e6c007832e39edb82f6d" + +[[package]] +name = "version_check" +version = "0.9.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b928f33d975fc6ad9f86c8f283853ad26bdd5b10b7f1542aa2fa15e2289105a" + +[[package]] +name = "wasi" +version = "0.11.0+wasi-snapshot-preview1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" + +[[package]] +name = "wasmtime-jit-debug" +version = "26.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f02a0118d471de665565ed200bc56673eaa10cc8e223dfe2cef5d50ed0d9d143" +dependencies = [ + "object", + "rustix", + "wasmtime-versioned-export-macros", +] + +[[package]] +name = "wasmtime-jit-icache-coherence" +version = "26.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "da47fba49af72581bc0dc67c8faaf5ee550e6f106e285122a184a675193701a5" +dependencies = [ + "anyhow", + "cfg-if", + "libc", + "windows-sys 0.59.0", +] + +[[package]] +name = "wasmtime-versioned-export-macros" +version = "26.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "db8efb877c9e5e67239d4553bb44dd2a34ae5cfb728f3cf2c5e64439c6ca6ee7" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "winapi" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5c839a674fcd7a98952e593242ea400abe93992746761e38641405d28b00f419" +dependencies = [ + "winapi-i686-pc-windows-gnu", + "winapi-x86_64-pc-windows-gnu", +] + +[[package]] +name = "winapi-i686-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" + +[[package]] +name = "winapi-x86_64-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" + +[[package]] +name = "windows-sys" +version = "0.52.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" +dependencies = [ + "windows-targets", +] + +[[package]] +name = "windows-sys" +version = "0.59.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e38bc4d79ed67fd075bcc251a1c39b32a1776bbe92e5bef1f0bf1f8c531853b" +dependencies = [ + "windows-targets", +] + +[[package]] +name = "windows-targets" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9b724f72796e036ab90c1021d4780d4d3d648aca59e491e6b98e725b84e99973" +dependencies = [ + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", + "windows_i686_gnullvm", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", +] + +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "32a4622180e7a0ec044bb555404c800bc9fd9ec262ec147edd5989ccd0c02cd3" + +[[package]] +name = "windows_aarch64_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "09ec2a7bb152e2252b53fa7803150007879548bc709c039df7627cabbd05d469" + +[[package]] +name = "windows_i686_gnu" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8e9b5ad5ab802e97eb8e295ac6720e509ee4c243f69d781394014ebfe8bbfa0b" + +[[package]] +name = "windows_i686_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0eee52d38c090b3caa76c563b86c3a4bd71ef1a819287c19d586d7334ae8ed66" + +[[package]] +name = "windows_i686_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "240948bc05c5e7c6dabba28bf89d89ffce3e303022809e73deaefe4f6ec56c66" + +[[package]] +name = "windows_x86_64_gnu" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "147a5c80aabfbf0c7d901cb5895d1de30ef2907eb21fbbab29ca94c5b08b1a78" + +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "24d5b23dc417412679681396f2b49f3de8c1473deb516bd34410872eff51ed0d" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.52.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "589f6da84c646204747d1270a2a5661ea66ed1cced2631d546fdfb155959f9ec" + +[[package]] +name = "xml-rs" +version = "0.8.24" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ea8b391c9a790b496184c29f7f93b9ed5b16abb306c05415b68bcc16e4d06432" + +[[package]] +name = "zerocopy" +version = "0.7.35" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1b9b4fd18abc82b8136838da5d50bae7bdea537c574d8dc1a34ed098d6c166f0" +dependencies = [ + "zerocopy-derive", +] + +[[package]] +name = "zerocopy-derive" +version = "0.7.35" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fa4f8080344d4671fb4e831a13ad1e68092748387dfc4f55e356242fae12ce3e" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] diff --git a/tests/Cargo.toml b/tests/Cargo.toml new file mode 100644 index 0000000..a522350 --- /dev/null +++ b/tests/Cargo.toml @@ -0,0 +1,11 @@ +[package] +name = "tests" +edition = "2021" + +[[bin]] +name = "tests" +path = "tests.rs" + +[dependencies] +icicle-python = { path = "..", default-features = false } +pyo3 = { version = "*" } diff --git a/src/main.rs b/tests/tests.rs similarity index 98% rename from src/main.rs rename to tests/tests.rs index 7494784..acb5a9b 100644 --- a/src/main.rs +++ b/tests/tests.rs @@ -1,7 +1,4 @@ -#![allow(special_module_name)] -mod lib; - -use lib::*; +use icicle::*; use pyo3::PyResult; fn nx_start() -> PyResult<()> { From 70cfc3260a15dfa775cede74dbf78e52bbd5b7a9 Mon Sep 17 00:00:00 2001 From: Duncan Ogilvie Date: Tue, 17 Dec 2024 15:33:13 +0100 Subject: [PATCH 2/8] Switch to a [workspace] https://github.com/PyO3/pyo3/issues/340 --- Cargo.lock | 8 ++++++++ Cargo.toml | 9 +++++++-- tests/Cargo.toml | 2 +- 3 files changed, 16 insertions(+), 3 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 3904a3e..d513e73 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -860,6 +860,14 @@ version = "0.12.16" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "61c41af27dd6d1e27b1b16b489db798443478cef1f06a660c96db617ba5de3b1" +[[package]] +name = "tests" +version = "0.0.0" +dependencies = [ + "icicle-python", + "pyo3", +] + [[package]] name = "thiserror" version = "1.0.40" diff --git a/Cargo.toml b/Cargo.toml index 1fe44cc..2edf29e 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,4 +1,6 @@ -# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html +[workspace] +members = ["tests"] +exclude = ["icicle-emu"] [package] name = "icicle-python" @@ -9,13 +11,16 @@ edition = "2021" name = "icicle" crate-type = ["cdylib", "lib"] +[workspace.dependencies] +pyo3 = { version = "0.23.3", features = ["indexmap", "abi3-py37"] } + [dependencies] +pyo3 = { workspace = true } icicle-cpu = { path = "icicle-emu/icicle-cpu" } icicle-vm = { path = "icicle-emu/icicle-vm" } pcode = { path = "icicle-emu/sleigh/pcode" } sleigh-runtime = { path = "icicle-emu/sleigh/sleigh-runtime" } indexmap = "2.2.6" -pyo3 = { version = "0.23.3", features = ["indexmap", "abi3-py37"] } target-lexicon = "0.12.7" tracing = "*" tracing-subscriber = "0.3.17" diff --git a/tests/Cargo.toml b/tests/Cargo.toml index a522350..2e0f437 100644 --- a/tests/Cargo.toml +++ b/tests/Cargo.toml @@ -8,4 +8,4 @@ path = "tests.rs" [dependencies] icicle-python = { path = "..", default-features = false } -pyo3 = { version = "*" } +pyo3 = { workspace = true } From 5853b8260347a9264ce68d24f2eba815ea9c57ab Mon Sep 17 00:00:00 2001 From: Duncan Ogilvie Date: Tue, 24 Dec 2024 12:59:10 +0100 Subject: [PATCH 3/8] Fix test execution by defining GHIDRA_SRC --- .cargo/config.toml | 2 ++ tests/.cargo/config.toml | 2 ++ tests/Cargo.toml | 2 +- 3 files changed, 5 insertions(+), 1 deletion(-) create mode 100644 .cargo/config.toml create mode 100644 tests/.cargo/config.toml diff --git a/.cargo/config.toml b/.cargo/config.toml new file mode 100644 index 0000000..47921a5 --- /dev/null +++ b/.cargo/config.toml @@ -0,0 +1,2 @@ +[env] +GHIDRA_SRC = { value = "python/icicle", relative = true } diff --git a/tests/.cargo/config.toml b/tests/.cargo/config.toml new file mode 100644 index 0000000..64058b5 --- /dev/null +++ b/tests/.cargo/config.toml @@ -0,0 +1,2 @@ +[env] +GHIDRA_SRC = { value = "../python/icicle", relative = true } diff --git a/tests/Cargo.toml b/tests/Cargo.toml index 2e0f437..cc6fdde 100644 --- a/tests/Cargo.toml +++ b/tests/Cargo.toml @@ -8,4 +8,4 @@ path = "tests.rs" [dependencies] icicle-python = { path = "..", default-features = false } -pyo3 = { workspace = true } +pyo3 = { workspace = true, features = ["auto-initialize"] } From 38d64a466c8d937044fdcf358d3cc02cccc7ff55 Mon Sep 17 00:00:00 2001 From: Duncan Ogilvie Date: Tue, 24 Dec 2024 13:36:14 +0100 Subject: [PATCH 4/8] Chance icicle initialization parameters --- tests/tests.rs | 95 +++++++++++++++++++++++++++++++++++--------------- 1 file changed, 67 insertions(+), 28 deletions(-) diff --git a/tests/tests.rs b/tests/tests.rs index acb5a9b..59ebba7 100644 --- a/tests/tests.rs +++ b/tests/tests.rs @@ -1,17 +1,23 @@ use icicle::*; use pyo3::PyResult; +use std::process::exit; + +#[test] +fn example() -> PyResult<()> { + Err(pyo3::exceptions::PyException::new_err("test")) +} fn nx_start() -> PyResult<()> { let mut vm: Icicle = Icicle::new( "x86_64".to_string(), false, true, - true, - true, false, true, + false, true, false, + false, )?; let page = 0x10000; vm.mem_map(page, 0x1000, MemoryProtection::ReadOnly)?; @@ -30,12 +36,12 @@ fn nx_middle() -> PyResult<()> { "x86_64".to_string(), false, true, - true, - true, false, true, + false, true, false, + false, )?; let page = 0x10000; vm.mem_map(page, 0x2000, MemoryProtection::ExecuteRead)?; @@ -57,12 +63,12 @@ fn inv_start() -> PyResult<()> { "x86_64".to_string(), false, true, - true, - true, false, true, + false, true, false, + false, )?; let page = 0x10000; vm.mem_map(page, 0x1000, MemoryProtection::ExecuteRead)?; @@ -82,12 +88,12 @@ fn inv_middle() -> PyResult<()> { "x86_64".to_string(), false, true, - true, - true, false, true, + false, true, false, + false, )?; let page = 0x10000; vm.mem_map(page, 0x1000, MemoryProtection::ExecuteRead)?; @@ -104,15 +110,15 @@ fn inv_middle() -> PyResult<()> { fn block_optimization() -> PyResult<()> { let mut vm: Icicle = Icicle::new( - "x86_64".to_string(), // architecture - true, // jit - true, // jit_mem - true, // shadow_stack - true, // recompilation - false, // track_uninitialized - true, // optimize_instructions - true, // optimize_block - false, // tracing + "x86_64".to_string(), + true, + true, + true, + true, + false, + true, + true, + false, )?; // Memory setup @@ -156,15 +162,48 @@ fn block_optimization() -> PyResult<()> { } fn main() { - #![allow(unused_must_use)] - println!("=== NX (block start) ==="); - nx_start(); - println!("=== NX (block middle) ==="); - nx_middle(); - println!("=== Invalid instruction (block start) ==="); - inv_start(); - println!("=== Invalid instruction (block middle) ==="); - inv_middle(); - println!("=== Block optimization bug ==="); - block_optimization(); + // Make sure the GHIDRA_SRC environment variable is valid + match std::env::var("GHIDRA_SRC") { + Ok(ghidra_src) => { + // Make sure the directory $GHIDRA_SRC/Ghidra/Processors exists + if !std::path::Path::new(&ghidra_src) + .join("Ghidra") + .join("Processors") + .exists() + { + println!("GHIDRA_SRC environment variable invalid!"); + exit(1); + } + println!("GHIDRA_SRC: {}", ghidra_src); + } + Err(_) => { + println!("GHIDRA_SRC environment variable not set!"); + exit(1); + } + } + + let tests: Vec<(&str, fn() -> PyResult<()>)> = vec![ + ("NX (block start)", nx_start), + ("NX (block middle)", nx_middle), + ("Invalid instruction (block start)", inv_start), + ("Invalid instruction (block middle)", inv_middle), + ("Block optimization bug", block_optimization), + ]; + + let mut success = 0; + for (name, f) in tests.iter() { + println!("=== {} ===", name); + match f() { + Ok(_) => { + success += 1; + println!("[OK]"); + } + Err(e) => { + println!("[ERROR] {}", e); + } + } + } + + println!("{}/{} tests passed", success, tests.len()); + exit(if success == tests.len() { 0 } else { 1 }); } From d8673ecdfda446e24acdd67e23491e288033ab1f Mon Sep 17 00:00:00 2001 From: Duncan Ogilvie Date: Tue, 24 Dec 2024 13:36:54 +0100 Subject: [PATCH 5/8] Add rust test for #10 --- tests/tests.rs | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/tests/tests.rs b/tests/tests.rs index 59ebba7..12009d0 100644 --- a/tests/tests.rs +++ b/tests/tests.rs @@ -161,6 +161,35 @@ fn block_optimization() -> PyResult<()> { Ok(()) } +fn rewind() -> PyResult<()> { + let mut ic: Icicle = Icicle::new( + "x86_64".to_string(), + true, + true, + false, + true, + false, + true, + false, + false, + )?; + + ic.mem_map(0x100, 0x20, MemoryProtection::ExecuteRead)?; + ic.mem_map(0x200, 0x20, MemoryProtection::ReadOnly)?; + + ic.mem_write(0x100, b"\x55".to_vec())?; // push rbp + ic.reg_write("rbp", 0xF00)?; + ic.reg_write("rsp", 0x210)?; + ic.reg_write("rip", 0x100)?; + let status = ic.step(1); + println!("run status : {:?}", status); + println!("exception code : {:?}", ic.get_exception_code()); + println!("exception value : {:#x}", ic.get_exception_value()); + println!("stack pointer : {:#x}", ic.reg_read("rsp")?); + + Ok(()) +} + fn main() { // Make sure the GHIDRA_SRC environment variable is valid match std::env::var("GHIDRA_SRC") { @@ -188,6 +217,7 @@ fn main() { ("Invalid instruction (block start)", inv_start), ("Invalid instruction (block middle)", inv_middle), ("Block optimization bug", block_optimization), + ("Rewind", rewind), ]; let mut success = 0; From 46a937a0e1433a2419f3794931bdf5f279a92506 Mon Sep 17 00:00:00 2001 From: Duncan Ogilvie Date: Tue, 24 Dec 2024 14:00:38 +0100 Subject: [PATCH 6/8] Simplify icicle vm construction in tests --- tests/tests.rs | 81 ++++++++++++++------------------------------------ 1 file changed, 23 insertions(+), 58 deletions(-) diff --git a/tests/tests.rs b/tests/tests.rs index 12009d0..7ea107d 100644 --- a/tests/tests.rs +++ b/tests/tests.rs @@ -2,15 +2,16 @@ use icicle::*; use pyo3::PyResult; use std::process::exit; +// NOTE: https://github.com/rust-lang/rust-analyzer/issues/18752 #[test] fn example() -> PyResult<()> { Err(pyo3::exceptions::PyException::new_err("test")) } -fn nx_start() -> PyResult<()> { - let mut vm: Icicle = Icicle::new( +fn new_vm(jit: bool) -> PyResult { + Icicle::new( "x86_64".to_string(), - false, + jit, true, false, true, @@ -18,7 +19,11 @@ fn nx_start() -> PyResult<()> { true, false, false, - )?; + ) +} + +fn nx_start() -> PyResult<()> { + let mut vm = new_vm(false)?; let page = 0x10000; vm.mem_map(page, 0x1000, MemoryProtection::ReadOnly)?; // inc eax; ret @@ -32,17 +37,7 @@ fn nx_start() -> PyResult<()> { } fn nx_middle() -> PyResult<()> { - let mut vm: Icicle = Icicle::new( - "x86_64".to_string(), - false, - true, - false, - true, - false, - true, - false, - false, - )?; + let mut vm = new_vm(false)?; let page = 0x10000; vm.mem_map(page, 0x2000, MemoryProtection::ExecuteRead)?; vm.mem_protect(page + 0x1000, 0x1000, MemoryProtection::ReadOnly)?; @@ -59,17 +54,7 @@ fn nx_middle() -> PyResult<()> { } fn inv_start() -> PyResult<()> { - let mut vm: Icicle = Icicle::new( - "x86_64".to_string(), - false, - true, - false, - true, - false, - true, - false, - false, - )?; + let mut vm = new_vm(false)?; let page = 0x10000; vm.mem_map(page, 0x1000, MemoryProtection::ExecuteRead)?; // ; ret @@ -84,17 +69,7 @@ fn inv_start() -> PyResult<()> { } fn inv_middle() -> PyResult<()> { - let mut vm: Icicle = Icicle::new( - "x86_64".to_string(), - false, - true, - false, - true, - false, - true, - false, - false, - )?; + let mut vm = new_vm(false)?; let page = 0x10000; vm.mem_map(page, 0x1000, MemoryProtection::ExecuteRead)?; // inc eax; ; ret @@ -162,30 +137,20 @@ fn block_optimization() -> PyResult<()> { } fn rewind() -> PyResult<()> { - let mut ic: Icicle = Icicle::new( - "x86_64".to_string(), - true, - true, - false, - true, - false, - true, - false, - false, - )?; + let mut vm = new_vm(true)?; - ic.mem_map(0x100, 0x20, MemoryProtection::ExecuteRead)?; - ic.mem_map(0x200, 0x20, MemoryProtection::ReadOnly)?; + vm.mem_map(0x100, 0x20, MemoryProtection::ExecuteRead)?; + vm.mem_map(0x200, 0x20, MemoryProtection::ReadOnly)?; - ic.mem_write(0x100, b"\x55".to_vec())?; // push rbp - ic.reg_write("rbp", 0xF00)?; - ic.reg_write("rsp", 0x210)?; - ic.reg_write("rip", 0x100)?; - let status = ic.step(1); + vm.mem_write(0x100, b"\x55".to_vec())?; // push rbp + vm.reg_write("rbp", 0xF00)?; + vm.reg_write("rsp", 0x210)?; + vm.reg_write("rip", 0x100)?; + let status = vm.step(1); println!("run status : {:?}", status); - println!("exception code : {:?}", ic.get_exception_code()); - println!("exception value : {:#x}", ic.get_exception_value()); - println!("stack pointer : {:#x}", ic.reg_read("rsp")?); + println!("exception code : {:?}", vm.get_exception_code()); + println!("exception value : {:#x}", vm.get_exception_value()); + println!("stack pointer : {:#x}", vm.reg_read("rsp")?); Ok(()) } From d648e73ba1914330464213d5874666f7e5449269 Mon Sep 17 00:00:00 2001 From: Duncan Ogilvie Date: Tue, 24 Dec 2024 14:03:11 +0100 Subject: [PATCH 7/8] Add rust test for #9 --- tests/tests.rs | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/tests/tests.rs b/tests/tests.rs index 7ea107d..53cce15 100644 --- a/tests/tests.rs +++ b/tests/tests.rs @@ -155,6 +155,20 @@ fn rewind() -> PyResult<()> { Ok(()) } +fn execute_only() -> PyResult<()> { + let mut vm = new_vm(true)?; + + vm.mem_map(0x100, 0x20, MemoryProtection::ExecuteOnly)?; + vm.mem_write(0x100, b"\x90".to_vec())?; // nop + vm.reg_write("rip", 0x100)?; + let status = vm.step(1); + println!("run status : {:?}", status); + println!("exception code : {:?}", vm.get_exception_code()); + println!("exception value : {:#x}", vm.get_exception_value()); + + Ok(()) +} + fn main() { // Make sure the GHIDRA_SRC environment variable is valid match std::env::var("GHIDRA_SRC") { @@ -183,6 +197,7 @@ fn main() { ("Invalid instruction (block middle)", inv_middle), ("Block optimization bug", block_optimization), ("Rewind", rewind), + ("Execute only", execute_only), ]; let mut success = 0; From 2e4dea36ec43e99678f6b812a8e48b31b1abbeab Mon Sep 17 00:00:00 2001 From: Duncan Ogilvie Date: Tue, 24 Dec 2024 23:57:21 +0100 Subject: [PATCH 8/8] Add rust test for #13 --- tests/tests.rs | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/tests/tests.rs b/tests/tests.rs index 53cce15..2124d93 100644 --- a/tests/tests.rs +++ b/tests/tests.rs @@ -169,6 +169,43 @@ fn execute_only() -> PyResult<()> { Ok(()) } +fn step_modify_rip() -> PyResult<()> { + let mut vm = new_trace_vm(false)?; + vm.mem_map(0x100, 0x20, MemoryProtection::ExecuteRead)?; + + // 0x100: 48 01 d8 add rax,rbx + // 0x103: 48 83 e9 05 sub rcx,0x5 + // 0x107: 48 89 d9 mov rcx,rbx + // 0x10a: 90 nop + // 0x10b: 90 nop + vm.mem_write(0x100, b"\x48\x01\xD8\x48\x83\xE9\x05\x48\x89\xD9\x90\x90".to_vec())?; + + vm.reg_write("rax", 0xF00)?; + vm.reg_write("rbx", 0x210)?; + vm.reg_write("rip", 0x100)?; + + println!("starting run at {:#x}", vm.reg_read("rip")?); + let mut status = vm.step(1); + + println!( + "ending run at {:#x} (status: {:?})", + vm.reg_read("rip")?, + status + ); + vm.reg_write("rip", 0x100)?; + //vm.write_pc(0x100); + //println!("pc: {:#x}", vm.read_pc()); + println!("rip rewritten {:#x}", vm.reg_read("rip")?); + status = vm.step(1); + println!( + "ending run at {:#x} (status: {:?})", + vm.reg_read("rip")?, + status + ); + + Ok(()) +} + fn main() { // Make sure the GHIDRA_SRC environment variable is valid match std::env::var("GHIDRA_SRC") { @@ -198,6 +235,7 @@ fn main() { ("Block optimization bug", block_optimization), ("Rewind", rewind), ("Execute only", execute_only), + ("Step modify rip", step_modify_rip), ]; let mut success = 0;