From 69cec37883ad41b18ac28f04fb77ead84e79d9c7 Mon Sep 17 00:00:00 2001 From: Jesper Brynolf Date: Fri, 13 Sep 2024 22:02:11 +0200 Subject: [PATCH] Adds a TBS TctiNameConf. When #477 got merged it became possible to build using a path to the ```tpm2-tss``` installation instead of depending on ```pkg-config```. This made it possible to build under Windows. To further increase the support for the windows platform this commit moves the option for TBS TCTI that is being introduced in #523 into a separate commit. This commit also updates the documentation regarding building using an installation folder. Co-authored-by: Thomas Epperson Signed-off-by: Jesper Brynolf --- tss-esapi-sys/README.md | 22 ++++++++++++++++++++++ tss-esapi/src/tcti_ldr.rs | 15 +++++++++++++++ 2 files changed, 37 insertions(+) diff --git a/tss-esapi-sys/README.md b/tss-esapi-sys/README.md index 6d347dba..e353796e 100644 --- a/tss-esapi-sys/README.md +++ b/tss-esapi-sys/README.md @@ -62,4 +62,26 @@ wrapper script around `pkg-config` can be seen Be advised that in some cases the linker used might need to be set manually in `.cargo/config`. +## Locally built tpm2-tss +It is now possible to specify an installation path when building the crate. This will +make the build process trying to find all the libraries and header files it needs from +installation path instead of using `pkg-config`. + +The `TPM2_TSS_PATH` environment variable name is used to specify the path to the installation. +The installation is required to have a specific layout. + +```md +Installation folder +├── bin (Optional) +│ ├── tss2-*.dll (Windows) +├── include (Required) +│ ├── tss2 +│ │ ├── tss2_*.h +├── lib (Required) +│ ├── tss2-*.lib (Windows) +│ ├── tss2-*.so (Nix) +│ ├── tss2-*.pdb (Windows) +└── VERSION (Required) +``` + *Copyright 2021 Contributors to the Parsec project.* diff --git a/tss-esapi/src/tcti_ldr.rs b/tss-esapi/src/tcti_ldr.rs index 9b4a0fa2..1b745064 100644 --- a/tss-esapi/src/tcti_ldr.rs +++ b/tss-esapi/src/tcti_ldr.rs @@ -22,6 +22,7 @@ const MSSIM: &str = "mssim"; const SWTPM: &str = "swtpm"; const TABRMD: &str = "tabrmd"; const LIBTPMS: &str = "libtpms"; +const TBS: &str = "tbs"; /// TCTI Context created via a TCTI Loader Library. /// Wrapper around the TSS2_TCTI_CONTEXT structure. @@ -148,6 +149,10 @@ pub enum TctiNameConf { /// /// For more information about configuration, see [this page](https://www.mankier.com/3/Tss2_Tcti_Tabrmd_Init) Tabrmd(TabrmdConfig), + /// Connect to the tpm using the Trusted Platform Module (TPM) Base Services (TBS) on Windows. + /// + /// For more information about TBS, see [this page](https://learn.microsoft.com/en-us/windows/win32/tbs/about-tbs) + Tbs, } impl TctiNameConf { @@ -180,6 +185,7 @@ impl TryFrom for CString { TctiNameConf::Swtpm(..) => SWTPM, TctiNameConf::Tabrmd(..) => TABRMD, TctiNameConf::LibTpms { .. } => LIBTPMS, + TctiNameConf::Tbs => TBS, }; let tcti_conf = match tcti { @@ -213,6 +219,7 @@ impl TryFrom for CString { TctiNameConf::LibTpms { state } => { state.map(|s| s.display().to_string()).unwrap_or_default() } + TctiNameConf::Tbs => String::new(), }; if tcti_conf.is_empty() { @@ -265,6 +272,10 @@ impl FromStr for TctiNameConf { }); } + if config_str.trim() == TBS { + return Ok(TctiNameConf::Tbs); + } + Err(Error::WrapperError(WrapperErrorKind::InvalidParam)) } } @@ -356,6 +367,10 @@ fn validate_from_str_tcti() { let tcti = TctiNameConf::from_str("libtpms").unwrap(); assert_eq!(tcti, TctiNameConf::LibTpms { state: None }); + + let tcti_tbs = TctiNameConf::from_str("tbs") + .expect("It should be possible to convert the string 'tbs' into a TctiNameConf object."); + assert_eq!(tcti_tbs, TctiNameConf::Tbs); } /// Configuration for a Device TCTI context