Signed-off-by: Philipp Schuster <philipp.schuster@cyberus-technology.de> On-behalf-of: SAP philipp.schuster@sap.com
64 lines
1.9 KiB
Rust
64 lines
1.9 KiB
Rust
// Copyright © 2021 Intel Corporation
|
|
//
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
//
|
|
|
|
use std::panic::AssertUnwindSafe;
|
|
use std::thread::{self, JoinHandle};
|
|
|
|
use seccompiler::{SeccompAction, apply_filter};
|
|
use vmm_sys_util::eventfd::EventFd;
|
|
|
|
use crate::ActivateError;
|
|
use crate::epoll_helper::EpollHelperError;
|
|
use crate::seccomp_filters::{Thread, get_seccomp_filter};
|
|
|
|
pub(crate) fn spawn_virtio_thread<F>(
|
|
name: &str,
|
|
seccomp_action: &SeccompAction,
|
|
thread_type: Thread,
|
|
epoll_threads: &mut Vec<JoinHandle<()>>,
|
|
exit_evt: &EventFd,
|
|
f: F,
|
|
) -> Result<(), ActivateError>
|
|
where
|
|
F: FnOnce() -> std::result::Result<(), EpollHelperError>,
|
|
F: Send + 'static,
|
|
{
|
|
let seccomp_filter = get_seccomp_filter(seccomp_action, thread_type)
|
|
.map_err(ActivateError::CreateSeccompFilter)?;
|
|
|
|
let thread_exit_evt = exit_evt
|
|
.try_clone()
|
|
.map_err(ActivateError::CloneExitEventFd)?;
|
|
let thread_name = name.to_string();
|
|
|
|
thread::Builder::new()
|
|
.name(name.to_string())
|
|
.spawn(move || {
|
|
if !seccomp_filter.is_empty()
|
|
&& let Err(e) = apply_filter(&seccomp_filter)
|
|
{
|
|
error!("Error applying seccomp filter: {e:?}");
|
|
thread_exit_evt.write(1).ok();
|
|
return;
|
|
}
|
|
match std::panic::catch_unwind(AssertUnwindSafe(f)) {
|
|
Err(_) => {
|
|
error!("{thread_name} thread panicked");
|
|
thread_exit_evt.write(1).ok();
|
|
}
|
|
Ok(r) => {
|
|
if let Err(e) = r {
|
|
error!("Error running worker: {e:?}");
|
|
thread_exit_evt.write(1).ok();
|
|
}
|
|
}
|
|
}
|
|
})
|
|
.map(|thread| epoll_threads.push(thread))
|
|
.map_err(|e| {
|
|
error!("Failed to spawn thread for {name}: {e}");
|
|
ActivateError::ThreadSpawn(e)
|
|
})
|
|
}
|