From cc49440689a1798af23cb237381104d3a2a43a08 Mon Sep 17 00:00:00 2001 From: YX Cao Date: Tue, 12 Dec 2023 15:58:20 -0800 Subject: [PATCH] Fix windows build (#337) * add CI for windows build with only `std` feature * fix windows build * bump version --- Cargo.lock | 2 +- ci.sh | 12 ++++++++---- mbedtls/Cargo.toml | 49 ++++++++++++++++++++++++++++------------------ 3 files changed, 39 insertions(+), 24 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 3a12768a9..c59ad999a 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -485,7 +485,7 @@ checksum = "7ffc5c5338469d4d3ea17d269fa8ea3512ad247247c30bd2df69e68309ed0a08" [[package]] name = "mbedtls" -version = "0.12.0" +version = "0.12.1" dependencies = [ "async-stream", "bit-vec", diff --git a/ci.sh b/ci.sh index 739fb0aaa..f1f7d6439 100755 --- a/ci.sh +++ b/ci.sh @@ -43,15 +43,19 @@ case "$TRAVIS_RUST_VERSION" in cargo nextest run --no-default-features --features "$FEAT"no_std_deps,rdrand,time --target $TARGET cargo nextest run --no-default-features --features "$FEAT"no_std_deps --target $TARGET fi - if [ "$TARGET" == "x86_64-apple-darwin" ]; then - cargo nextest run --no-default-features --features no_std_deps --target $TARGET - fi - else cargo +$TRAVIS_RUST_VERSION test --no-run --features "$FEAT" --target=$TARGET fi done + if [ "$TARGET" == "x86_64-apple-darwin" ]; then + cargo nextest run --no-default-features --features no_std_deps --target $TARGET + fi + # special case: mbedtls should compile successfully on windows only with `std` feature + if [[ "$TARGET" =~ ^x86_64-pc-windows- ]]; then + cargo nextest run --no-default-features --features std --target $TARGET + fi + # The SGX target cannot be run under test like a ELF binary if [ "$TARGET" != "x86_64-fortanix-unknown-sgx" ]; then cargo nextest run --test async_session --features=async-rt,ssl --target $TARGET diff --git a/mbedtls/Cargo.toml b/mbedtls/Cargo.toml index 77451e98b..78086e825 100644 --- a/mbedtls/Cargo.toml +++ b/mbedtls/Cargo.toml @@ -2,7 +2,7 @@ name = "mbedtls" # We jumped from v0.9 to v0.12 because v0.10 and v0.11 were based on mbedtls 3.X, which # we decided not to support. -version = "0.12.0" +version = "0.12.1" authors = ["Jethro Beekman "] build = "build.rs" edition = "2018" @@ -17,14 +17,17 @@ environment.""" readme = "../README.md" repository = "https://github.com/fortanix/rust-mbedtls" documentation = "https://docs.rs/mbedtls/" -keywords = ["MbedTLS","mbed","TLS","SSL","cryptography"] +keywords = ["MbedTLS", "mbed", "TLS", "SSL", "cryptography"] [dependencies] bitflags = "1" serde = { version = "1.0.7", default-features = false, features = ["alloc"] } serde_derive = "1.0.7" byteorder = { version = "1.0.0", default-features = false } -yasna = { version = "0.2", optional = true, features = ["num-bigint", "bit-vec"] } +yasna = { version = "0.2", optional = true, features = [ + "num-bigint", + "bit-vec", +] } num-bigint = { version = "0.2", optional = true } bit-vec = { version = "0.5", optional = true } cbc = { version = "0.1.2", optional = true } @@ -33,18 +36,15 @@ cfg-if = "1.0.0" tokio = { version = "1.16.1", optional = true } chrono = { version = "0.4", optional = true } -[target.x86_64-fortanix-unknown-sgx.dependencies] -rs-libc = "0.2.0" +mbedtls-sys-auto = { path = "../mbedtls-sys", version = "2.25.0", default-features = false, features = [ + "trusted_cert_callback", + "threading", +] } -[dependencies.mbedtls-sys-auto] -version = "2.25.0" -default-features = false -features = ["trusted_cert_callback", "threading"] -path = "../mbedtls-sys" +mbedtls-platform-support = { version = "0.1", path = "../mbedtls-platform-support" } -[dependencies.mbedtls-platform-support] -version = "0.1" -path = "../mbedtls-platform-support" +[target.x86_64-fortanix-unknown-sgx.dependencies] +rs-libc = "0.2.0" [dev-dependencies] libc = "0.2.0" @@ -62,10 +62,15 @@ pin-project-lite = "0.2" cc = "1.0" # feature 'time` is necessary under windows -[target.'cfg(target_os = "windows")'.mbedtls-platform-support] -version = "0.1" -path = "../mbedtls-platform-support" -features = ["time"] +[target.'cfg(target_env = "msvc")'.dependencies] +mbedtls-platform-support = { version = "0.1", path = "../mbedtls-platform-support", features = [ + "time", +] } +mbedtls-sys-auto = { path = "../mbedtls-sys", version = "2.25.0", default-features = false, features = [ + "trusted_cert_callback", + "threading", + "time", +] } [features] # Features are documented in the README @@ -74,7 +79,13 @@ x509 = [] ssl = ["x509"] default = ["std", "aesni", "time", "padlock"] -std = ["byteorder/std", "mbedtls-sys-auto/std", "serde/std", "yasna", "mbedtls-platform-support/std"] +std = [ + "byteorder/std", + "mbedtls-sys-auto/std", + "serde/std", + "yasna", + "mbedtls-platform-support/std", +] debug = ["mbedtls-sys-auto/debug"] no_std_deps = ["mbedtls-platform-support/spin", "serde/alloc"] force_aesni_support = ["mbedtls-platform-support/force_aesni_support", "aesni"] @@ -88,7 +99,7 @@ dsa = ["std", "yasna", "num-bigint", "bit-vec"] pkcs12 = ["std", "yasna", "x509"] pkcs12_rc2 = ["pkcs12", "rc2", "cbc"] legacy_protocols = ["mbedtls-sys-auto/legacy_protocols", "ssl"] -async = ["std", "tokio","tokio/net","tokio/io-util", "tokio/macros"] +async = ["std", "tokio", "tokio/net", "tokio/io-util", "tokio/macros"] async-rt = ["async", "tokio/rt", "tokio/sync", "tokio/rt-multi-thread"] [[example]]