From dac89edfe863840ce17950c6dbfea41f96acccb2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=ED=9D=AC=EC=84=B1?= Date: Fri, 13 Dec 2024 15:37:08 +0900 Subject: [PATCH 1/2] Add `x86` to CpuArchitecture --- crates/wdk-build/rust-driver-makefile.toml | 4 ++-- crates/wdk-build/src/cargo_make.rs | 7 +++++++ crates/wdk-build/src/lib.rs | 9 +++++++++ 3 files changed, 18 insertions(+), 2 deletions(-) diff --git a/crates/wdk-build/rust-driver-makefile.toml b/crates/wdk-build/rust-driver-makefile.toml index 903af810..5db860a9 100644 --- a/crates/wdk-build/rust-driver-makefile.toml +++ b/crates/wdk-build/rust-driver-makefile.toml @@ -271,7 +271,7 @@ std::fs::copy(&source_file, &destination_file).expect(&format!( [tasks.stampinf] private = true dependencies = ["setup-wdk-config-env-vars", "copy-inx-to-output"] -env = { "WDK_BUILD_STAMPINF_WDF_FLAGS" = { source = "${WDK_BUILD_METADATA-DRIVER_MODEL-DRIVER_TYPE}", default_value = "", mapping = { "KMDF" = "-k ${WDK_BUILD_METADATA-DRIVER_MODEL-KMDF_VERSION_MAJOR}.${WDK_BUILD_METADATA-DRIVER_MODEL-TARGET_KMDF_VERSION_MINOR}", "UMDF" = "-u ${WDK_BUILD_METADATA-DRIVER_MODEL-UMDF_VERSION_MAJOR}.${WDK_BUILD_METADATA-DRIVER_MODEL-TARGET_UMDF_VERSION_MINOR}.0" } }, "WDK_BUILD_STAMPINF_ARCH" = { source = "${CARGO_MAKE_CRATE_TARGET_TRIPLE}", default_value = "UNKNOWN", mapping = { "x86_64-pc-windows-msvc" = "amd64", "aarch64-pc-windows-msvc" = "arm64" } } } +env = { "WDK_BUILD_STAMPINF_WDF_FLAGS" = { source = "${WDK_BUILD_METADATA-DRIVER_MODEL-DRIVER_TYPE}", default_value = "", mapping = { "KMDF" = "-k ${WDK_BUILD_METADATA-DRIVER_MODEL-KMDF_VERSION_MAJOR}.${WDK_BUILD_METADATA-DRIVER_MODEL-TARGET_KMDF_VERSION_MINOR}", "UMDF" = "-u ${WDK_BUILD_METADATA-DRIVER_MODEL-UMDF_VERSION_MAJOR}.${WDK_BUILD_METADATA-DRIVER_MODEL-TARGET_UMDF_VERSION_MINOR}.0" } }, "WDK_BUILD_STAMPINF_ARCH" = { source = "${CARGO_MAKE_CRATE_TARGET_TRIPLE}", default_value = "UNKNOWN", mapping = { "i686-pc-windows-msvc" = "x86", "x86_64-pc-windows-msvc" = "amd64", "aarch64-pc-windows-msvc" = "arm64" } } } command = "stampinf" args = [ "-f", @@ -396,7 +396,7 @@ wdk_build::cargo_make::copy_to_driver_package_folder( [tasks.inf2cat] private = true dependencies = ["copy-driver-binary-to-package", "copy-inf-to-package"] -env = { "WDK_BUILD_INF2CAT_OS" = { source = "${CARGO_MAKE_CRATE_TARGET_TRIPLE}", default_value = "UNKNOWN", mapping = { "x86_64-pc-windows-msvc" = "10_x64", "aarch64-pc-windows-msvc" = "Server10_arm64" } } } +env = { "WDK_BUILD_INF2CAT_OS" = { source = "${CARGO_MAKE_CRATE_TARGET_TRIPLE}", default_value = "UNKNOWN", mapping = { "i686-pc-windows-msvc" = "10_x86", "x86_64-pc-windows-msvc" = "10_x64", "aarch64-pc-windows-msvc" = "Server10_arm64" } } } command = "inf2cat" args = [ "/driver:${WDK_BUILD_OUTPUT_DIRECTORY}/${CARGO_MAKE_CRATE_FS_NAME}_package", diff --git a/crates/wdk-build/src/cargo_make.rs b/crates/wdk-build/src/cargo_make.rs index 26be9942..c5410f3a 100644 --- a/crates/wdk-build/src/cargo_make.rs +++ b/crates/wdk-build/src/cargo_make.rs @@ -525,6 +525,13 @@ pub fn setup_path() -> Result, ConfigError> { .canonicalize()? .strip_extended_length_path_prefix()?; let host_windows_sdk_ver_bin_path = match host_arch { + CpuArchitecture::X86 => wdk_bin_root + .join(host_arch.as_windows_str()) + .canonicalize()? + .strip_extended_length_path_prefix()? + .to_str() + .expect("x86 host_windows_sdk_ver_bin_path should only contain valid UTF8") + .to_string(), CpuArchitecture::Amd64 => wdk_bin_root .join(host_arch.as_windows_str()) .canonicalize()? diff --git a/crates/wdk-build/src/lib.rs b/crates/wdk-build/src/lib.rs index db2e8aa8..f96cf57b 100644 --- a/crates/wdk-build/src/lib.rs +++ b/crates/wdk-build/src/lib.rs @@ -80,6 +80,8 @@ enum DeserializableDriverConfig { /// The CPU architecture that's configured to be compiled for #[derive(Debug, Clone, Copy, Serialize, Deserialize, PartialEq, Eq)] pub enum CpuArchitecture { + /// Intel CPU architecture. Also known as i386 or i586 or i686. + X86, /// AMD64 CPU architecture. Also known as x64 or x86-64. Amd64, /// ARM64 CPU architecture. Also known as aarch64. @@ -520,6 +522,11 @@ impl Config { // .into_iter() // .map(|(key, value)| (key.to_string(), value.map(|v| v.to_string()))) match self.cpu_architecture { + // Definitions sourced from `Program Files\Windows + // Kits\10\build\10.0.22621.0\WindowsDriver.win32.props` + CpuArchitecture::X86 => { + vec![("_X86_", None), ("i386", None), ("STD_CALL", None)] + } // Definitions sourced from `Program Files\Windows // Kits\10\build\10.0.22621.0\WindowsDriver.x64.props` CpuArchitecture::Amd64 => { @@ -833,6 +840,7 @@ impl CpuArchitecture { #[must_use] pub const fn as_windows_str(&self) -> &str { match self { + Self::X86 => "x86", Self::Amd64 => "x64", Self::Arm64 => "ARM64", } @@ -846,6 +854,7 @@ impl CpuArchitecture { // Specifically not using the [`std::convert::TryFrom`] trait to be more // explicit in function name, since only arch strings from cargo are handled. match cargo_str.as_ref() { + "x86" => Some(Self::X86), "x86_64" => Some(Self::Amd64), "aarch64" => Some(Self::Arm64), _ => None, From 630019b5f5ffddb227c7a6f314bc55cac37304a0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=ED=9D=AC=EC=84=B1?= Date: Fri, 13 Dec 2024 15:51:07 +0900 Subject: [PATCH 2/2] Add `i686-pc-windows-msvc` in pipeline --- .github/workflows/build.yaml | 1 + .github/workflows/codeql.yml | 1 + .github/workflows/docs.yaml | 1 + .github/workflows/lint.yaml | 1 + .github/workflows/local-development-makefile.yaml | 1 + .github/workflows/test.yaml | 1 + 6 files changed, 6 insertions(+) diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 3c916bf9..ac5a5174 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -34,6 +34,7 @@ jobs: - release target_triple: + - i686-pc-windows-msvc - x86_64-pc-windows-msvc - aarch64-pc-windows-msvc diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index f7b28a66..8946c363 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -32,6 +32,7 @@ jobs: - release target_triple: + - i686-pc-windows-msvc - x86_64-pc-windows-msvc - aarch64-pc-windows-msvc diff --git a/.github/workflows/docs.yaml b/.github/workflows/docs.yaml index 56f9412b..797b64c8 100644 --- a/.github/workflows/docs.yaml +++ b/.github/workflows/docs.yaml @@ -32,6 +32,7 @@ jobs: - release target_triple: + - i686-pc-windows-msvc - x86_64-pc-windows-msvc - aarch64-pc-windows-msvc diff --git a/.github/workflows/lint.yaml b/.github/workflows/lint.yaml index 6bef9782..083ab3a3 100644 --- a/.github/workflows/lint.yaml +++ b/.github/workflows/lint.yaml @@ -31,6 +31,7 @@ jobs: - release target_triple: + - i686-pc-windows-msvc - x86_64-pc-windows-msvc - aarch64-pc-windows-msvc diff --git a/.github/workflows/local-development-makefile.yaml b/.github/workflows/local-development-makefile.yaml index 79cf5bad..d90ae4d6 100644 --- a/.github/workflows/local-development-makefile.yaml +++ b/.github/workflows/local-development-makefile.yaml @@ -23,6 +23,7 @@ jobs: - 17.0.6 target_triple: + - i686-pc-windows-msvc - x86_64-pc-windows-msvc # - aarch64-pc-windows-msvc FIXME: find a way to validate the local makefile on aarch64 diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index 2f63b1e1..4166a229 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -29,6 +29,7 @@ jobs: - release target_triple: + - i686-pc-windows-msvc - x86_64-pc-windows-msvc # - aarch64-pc-windows-msvc FIXME: Add support for executing ARM64 tests. Maybe use target specific test runner in emulator: https://doc.rust-lang.org/cargo/reference/config.html#target