forked from kata-containers/kata-containers
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Initial VFIO-AP support (kata-containers#578) was simple, but somewhat hacky; a different code path would be chosen for performing the hotplug, and agent-side device handling was bound to knowing the assigned queue numbers (APQNs) through some other means; plus the code for awaiting them was written for the Go agent and never released. This code also artificially increased the hotplug timeout to wait for the (relatively expensive, thus limited to 5 seconds at the quickest) AP rescan, which is impractical for e.g. common k8s timeouts. Since then, the general handling logic was improved (kata-containers#1190), but it assumed PCI in several places. In the runtime, introduce and parse AP devices. Annotate them as such when passing to the agent, and information about the enabled APQNs is included. The agent awaits the passed APQNs through uevents and triggers a rescan directly. Fixes: kata-containers#3678 Signed-off-by: Jakob Naucke <[email protected]>
- Loading branch information
1 parent
821c756
commit 44ed889
Showing
10 changed files
with
277 additions
and
20 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
// Copyright (c) IBM Corp. 2022 | ||
// | ||
// SPDX-License-Identifier: Apache-2.0 | ||
// | ||
|
||
use std::fmt; | ||
use std::str::FromStr; | ||
|
||
use anyhow::{anyhow, Context}; | ||
|
||
// IBM Adjunct Processor (AP) is the bus used by IBM Crypto Express hardware security modules on | ||
// IBM Z & LinuxONE (s390x) | ||
// AP bus ID follow the format <xx>.<xxxx> [1, p. 476], where | ||
// - <xx> is the adapter ID, i.e. the card and | ||
// - <xxxx> is the adapter domain. | ||
// [1] https://www.ibm.com/docs/en/linuxonibm/pdf/lku5dd05.pdf | ||
|
||
#[derive(Debug)] | ||
pub struct Address { | ||
pub adapter_id: u8, | ||
pub adapter_domain: u16, | ||
} | ||
|
||
impl Address { | ||
pub fn new(adapter_id: u8, adapter_domain: u16) -> Address { | ||
Address { | ||
adapter_id, | ||
adapter_domain, | ||
} | ||
} | ||
} | ||
|
||
impl FromStr for Address { | ||
type Err = anyhow::Error; | ||
|
||
fn from_str(s: &str) -> anyhow::Result<Self> { | ||
let split: Vec<&str> = s.split('.').collect(); | ||
if split.len() != 2 { | ||
return Err(anyhow!( | ||
"Wrong AP bus format. It needs to be in the form <xx>.<xxxx>, got {:?}", | ||
s | ||
)); | ||
} | ||
|
||
let adapter_id = u8::from_str_radix(split[0], 16).context(format!( | ||
"Wrong AP bus format. AP ID needs to be in the form <xx>, got {:?}", | ||
split[0] | ||
))?; | ||
let adapter_domain = u16::from_str_radix(split[1], 16).context(format!( | ||
"Wrong AP bus format. AP domain needs to be in the form <xxxx>, got {:?}", | ||
split[1] | ||
))?; | ||
|
||
Ok(Address::new(adapter_id, adapter_domain)) | ||
} | ||
} | ||
|
||
impl fmt::Display for Address { | ||
fn fmt(&self, f: &mut fmt::Formatter) -> Result<(), fmt::Error> { | ||
write!(f, "{:02x}.{:04x}", self.adapter_id, self.adapter_domain) | ||
} | ||
} | ||
|
||
#[cfg(test)] | ||
mod tests { | ||
use super::*; | ||
|
||
#[test] | ||
fn test_from_str() { | ||
let device = Address::from_str("a.1").unwrap(); | ||
assert_eq!(format!("{}", device), "0a.0001"); | ||
|
||
assert!(Address::from_str("").is_err()); | ||
assert!(Address::from_str(".").is_err()); | ||
assert!(Address::from_str("0.0.0").is_err()); | ||
assert!(Address::from_str("0g.0000").is_err()); | ||
assert!(Address::from_str("0a.10000").is_err()); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -78,6 +78,7 @@ mod tracer; | |
|
||
cfg_if! { | ||
if #[cfg(target_arch = "s390x")] { | ||
mod ap; | ||
mod ccw; | ||
} | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.