|  | @@ -81,13 +81,9 @@ async fn remote_provider<C: 'static + Creds + Send + Sync>(
 | 
											
												
													
														|  |      Ok(client)
 |  |      Ok(client)
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -async fn run_daemon(
 |  | 
 | 
											
												
													
														|  | -    config: Config,
 |  | 
 | 
											
												
													
														|  | -    mounted_signal: Option<oneshot::Sender<()>>,
 |  | 
 | 
											
												
													
														|  | -    stop_signal: Option<oneshot::Receiver<()>>,
 |  | 
 | 
											
												
													
														|  | -) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +async fn run_daemon(config: Config, mounted_signal: Option<oneshot::Sender<()>>) {
 | 
											
												
													
														|  |      let node_creds = Arc::new(
 |  |      let node_creds = Arc::new(
 | 
											
												
													
														|  | -        node_creds(config.tpm_state_file, &config.tabrmd).expect("failed to get node creds")
 |  | 
 | 
											
												
													
														|  | 
 |  | +        node_creds(config.tpm_state_file, &config.tabrmd).expect("failed to get node creds"),
 | 
											
												
													
														|  |      );
 |  |      );
 | 
											
												
													
														|  |      let fallback_path = {
 |  |      let fallback_path = {
 | 
											
												
													
														|  |          let writecap = node_creds
 |  |          let writecap = node_creds
 | 
											
										
											
												
													
														|  | @@ -129,14 +125,7 @@ async fn run_daemon(
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |      .expect("failed to create FUSE daemon");
 |  |      .expect("failed to create FUSE daemon");
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -    if let Some(stop_signal) = stop_signal {
 |  | 
 | 
											
												
													
														|  | -        tokio::select! {
 |  | 
 | 
											
												
													
														|  | -            _  = daemon.finished() => (),
 |  | 
 | 
											
												
													
														|  | -            _ = stop_signal => (),
 |  | 
 | 
											
												
													
														|  | -        };
 |  | 
 | 
											
												
													
														|  | -    } else {
 |  | 
 | 
											
												
													
														|  | -        daemon.finished().await;
 |  | 
 | 
											
												
													
														|  | -    }
 |  | 
 | 
											
												
													
														|  | 
 |  | +    daemon.finished().await;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #[tokio::main]
 |  |  #[tokio::main]
 | 
											
										
											
												
													
														|  | @@ -151,7 +140,7 @@ async fn main() {
 | 
											
												
													
														|  |          .with_tabrmd(from_envvar(ENVVARS.tabrmd).unwrap())
 |  |          .with_tabrmd(from_envvar(ENVVARS.tabrmd).unwrap())
 | 
											
												
													
														|  |          .with_mnt_options(from_envvar(ENVVARS.mnt_options).unwrap());
 |  |          .with_mnt_options(from_envvar(ENVVARS.mnt_options).unwrap());
 | 
											
												
													
														|  |      let config = builder.build();
 |  |      let config = builder.build();
 | 
											
												
													
														|  | -    run_daemon(config, None, None).await;
 |  | 
 | 
											
												
													
														|  | 
 |  | +    run_daemon(config, None).await;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #[cfg(test)]
 |  |  #[cfg(test)]
 | 
											
										
											
												
													
														|  | @@ -165,7 +154,7 @@ mod test {
 | 
											
												
													
														|  |      use std::{
 |  |      use std::{
 | 
											
												
													
														|  |          ffi::{OsStr, OsString},
 |  |          ffi::{OsStr, OsString},
 | 
											
												
													
														|  |          fs::Permissions,
 |  |          fs::Permissions,
 | 
											
												
													
														|  | -        io::SeekFrom,
 |  | 
 | 
											
												
													
														|  | 
 |  | +        io::{BufRead, SeekFrom},
 | 
											
												
													
														|  |          net::{IpAddr, Ipv6Addr},
 |  |          net::{IpAddr, Ipv6Addr},
 | 
											
												
													
														|  |          num::NonZeroUsize,
 |  |          num::NonZeroUsize,
 | 
											
												
													
														|  |          os::unix::fs::PermissionsExt,
 |  |          os::unix::fs::PermissionsExt,
 | 
											
										
											
												
													
														|  | @@ -195,11 +184,39 @@ mod test {
 | 
											
												
													
														|  |          env_logger::Builder::from_default_env().btformat().init();
 |  |          env_logger::Builder::from_default_env().btformat().init();
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +    /// Reads `/etc/mtab` to determine if `mnt_path` is mounted. Returns true if it is and false
 | 
											
												
													
														|  | 
 |  | +    /// otherwise.
 | 
											
												
													
														|  | 
 |  | +    fn mounted(mnt_path: &str) -> bool {
 | 
											
												
													
														|  | 
 |  | +        let file = std::fs::OpenOptions::new()
 | 
											
												
													
														|  | 
 |  | +            .read(true)
 | 
											
												
													
														|  | 
 |  | +            .write(false)
 | 
											
												
													
														|  | 
 |  | +            .create(false)
 | 
											
												
													
														|  | 
 |  | +            .open("/etc/mtab")
 | 
											
												
													
														|  | 
 |  | +            .unwrap();
 | 
											
												
													
														|  | 
 |  | +        let mut reader = std::io::BufReader::new(file);
 | 
											
												
													
														|  | 
 |  | +        let mut line = String::with_capacity(64);
 | 
											
												
													
														|  | 
 |  | +        loop {
 | 
											
												
													
														|  | 
 |  | +            line.clear();
 | 
											
												
													
														|  | 
 |  | +            let read = reader.read_line(&mut line).unwrap();
 | 
											
												
													
														|  | 
 |  | +            if 0 == read {
 | 
											
												
													
														|  | 
 |  | +                break;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            let path = line.split(' ').skip(1).next().unwrap();
 | 
											
												
													
														|  | 
 |  | +            if path == mnt_path {
 | 
											
												
													
														|  | 
 |  | +                return true;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        false
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |      /// Unmounts the file system at the given path.
 |  |      /// Unmounts the file system at the given path.
 | 
											
												
													
														|  |      fn unmount<P: AsRef<Path>>(mnt_path: P) {
 |  |      fn unmount<P: AsRef<Path>>(mnt_path: P) {
 | 
											
												
													
														|  | 
 |  | +        let mnt_path = mnt_path.as_ref();
 | 
											
												
													
														|  | 
 |  | +        if !mounted(mnt_path.to_str().unwrap()) {
 | 
											
												
													
														|  | 
 |  | +            return;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  |          const PROG: &str = "fusermount";
 |  |          const PROG: &str = "fusermount";
 | 
											
												
													
														|  |          let mnt_path = mnt_path
 |  |          let mnt_path = mnt_path
 | 
											
												
													
														|  | -            .as_ref()
 |  | 
 | 
											
												
													
														|  |              .as_os_str()
 |  |              .as_os_str()
 | 
											
												
													
														|  |              .to_str()
 |  |              .to_str()
 | 
											
												
													
														|  |              .expect("failed to convert mnt_path to `str`");
 |  |              .expect("failed to convert mnt_path to `str`");
 | 
											
										
											
												
													
														|  | @@ -228,7 +245,7 @@ mod test {
 | 
											
												
													
														|  |          config: Config,
 |  |          config: Config,
 | 
											
												
													
														|  |          handle: Option<JoinHandle<()>>,
 |  |          handle: Option<JoinHandle<()>>,
 | 
											
												
													
														|  |          node_principal: OsString,
 |  |          node_principal: OsString,
 | 
											
												
													
														|  | -        stop_tx: Option<oneshot::Sender<()>>,
 |  | 
 | 
											
												
													
														|  | 
 |  | +        stop_flag: Option<()>,
 | 
											
												
													
														|  |          // Note that the drop order of these fields is significant.
 |  |          // Note that the drop order of these fields is significant.
 | 
											
												
													
														|  |          _receiver: Option<R>,
 |  |          _receiver: Option<R>,
 | 
											
												
													
														|  |          _cred_store: TpmCredStore,
 |  |          _cred_store: TpmCredStore,
 | 
											
										
											
												
													
														|  | @@ -247,7 +264,6 @@ mod test {
 | 
											
												
													
														|  |      async fn new(remote: bool) -> TestCase<impl Receiver> {
 |  |      async fn new(remote: bool) -> TestCase<impl Receiver> {
 | 
											
												
													
														|  |          let tmp = TempDir::new("btfuse").unwrap();
 |  |          let tmp = TempDir::new("btfuse").unwrap();
 | 
											
												
													
														|  |          let (mounted_tx, mounted_rx) = oneshot::channel();
 |  |          let (mounted_tx, mounted_rx) = oneshot::channel();
 | 
											
												
													
														|  | -        let (stop_tx, stop_rx) = oneshot::channel();
 |  | 
 | 
											
												
													
														|  |          let (swtpm, cred_store) = swtpm();
 |  |          let (swtpm, cred_store) = swtpm();
 | 
											
												
													
														|  |          let builder = Config::builder()
 |  |          let builder = Config::builder()
 | 
											
												
													
														|  |              .with_threads(Some(NonZeroUsize::new(1).unwrap()))
 |  |              .with_threads(Some(NonZeroUsize::new(1).unwrap()))
 | 
											
										
											
												
													
														|  | @@ -273,9 +289,7 @@ mod test {
 | 
											
												
													
														|  |          };
 |  |          };
 | 
											
												
													
														|  |          let config_clone = config.clone();
 |  |          let config_clone = config.clone();
 | 
											
												
													
														|  |          let handle = tokio::spawn(async move {
 |  |          let handle = tokio::spawn(async move {
 | 
											
												
													
														|  | -            let mnt_dir = config_clone.mnt_dir.clone();
 |  | 
 | 
											
												
													
														|  | -            run_daemon(config_clone, Some(mounted_tx), Some(stop_rx)).await;
 |  | 
 | 
											
												
													
														|  | -            unmount(mnt_dir);
 |  | 
 | 
											
												
													
														|  | 
 |  | +            run_daemon(config_clone, Some(mounted_tx)).await;
 | 
											
												
													
														|  |          });
 |  |          });
 | 
											
												
													
														|  |          if let Some(timeout) = TIMEOUT {
 |  |          if let Some(timeout) = TIMEOUT {
 | 
											
												
													
														|  |              tokio::time::timeout(timeout, mounted_rx)
 |  |              tokio::time::timeout(timeout, mounted_rx)
 | 
											
										
											
												
													
														|  | @@ -291,7 +305,7 @@ mod test {
 | 
											
												
													
														|  |              config,
 |  |              config,
 | 
											
												
													
														|  |              handle: Some(handle),
 |  |              handle: Some(handle),
 | 
											
												
													
														|  |              node_principal,
 |  |              node_principal,
 | 
											
												
													
														|  | -            stop_tx: Some(stop_tx),
 |  | 
 | 
											
												
													
														|  | 
 |  | +            stop_flag: Some(()),
 | 
											
												
													
														|  |              _receiver: receiver,
 |  |              _receiver: receiver,
 | 
											
												
													
														|  |              _temp_dir: tmp,
 |  |              _temp_dir: tmp,
 | 
											
												
													
														|  |              _swtpm: swtpm,
 |  |              _swtpm: swtpm,
 | 
											
										
											
												
													
														|  | @@ -325,10 +339,8 @@ mod test {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          /// Signals to the daemon that it must stop.
 |  |          /// Signals to the daemon that it must stop.
 | 
											
												
													
														|  |          fn signal_stop(&mut self) {
 |  |          fn signal_stop(&mut self) {
 | 
											
												
													
														|  | -            if let Some(stop_tx) = self.stop_tx.take() {
 |  | 
 | 
											
												
													
														|  | -                if let Err(_) = stop_tx.send(()) {
 |  | 
 | 
											
												
													
														|  | -                    log::error!("failed to send the TestCase stop signal");
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | 
 |  | +            if let Some(_) = self.stop_flag.take() {
 | 
											
												
													
														|  | 
 |  | +                unmount(&self.config.mnt_dir)
 | 
											
												
													
														|  |              }
 |  |              }
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -728,6 +740,7 @@ mod test {
 | 
											
												
													
														|  |          fill(&mut buf, 1);
 |  |          fill(&mut buf, 1);
 | 
											
												
													
														|  |          assert_eq!(buf, actual);
 |  |          assert_eq!(buf, actual);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +        drop(file);
 | 
											
												
													
														|  |          case.stop().await;
 |  |          case.stop().await;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 |