use crate::shared::Architecture;
pub enum AMDArchitecture {
GFX12,
GFX11,
GFX10,
GFX908,
GFX90A,
GFX94,
Other,
}
impl AMDArchitecture {
pub fn parse(arg: &str) -> Result<Self, String> {
let norm = arg.to_lowercase();
if norm.starts_with("gfx12") {
Ok(AMDArchitecture::GFX12)
} else if norm.starts_with("gfx11") {
Ok(AMDArchitecture::GFX11)
} else if norm.starts_with("gfx10") {
Ok(AMDArchitecture::GFX10)
} else if norm == "gfx908" {
Ok(AMDArchitecture::GFX908)
} else if norm == "gfx90a" {
Ok(AMDArchitecture::GFX90A)
} else if norm.starts_with("gfx94") {
Ok(AMDArchitecture::GFX94)
} else {
Ok(AMDArchitecture::Other)
}
}
}
impl Architecture for AMDArchitecture {
fn warp_size(&self) -> u32 {
match self {
AMDArchitecture::GFX10 | AMDArchitecture::GFX11 | AMDArchitecture::GFX12 => 32,
AMDArchitecture::GFX908 | AMDArchitecture::GFX90A | AMDArchitecture::GFX94 => 64,
AMDArchitecture::Other => 0,
}
}
fn is_wmma_capable(&self) -> bool {
matches!(
self,
AMDArchitecture::GFX10 | AMDArchitecture::GFX11 | AMDArchitecture::GFX12
)
}
fn is_mfma_capable(&self) -> bool {
matches!(
self,
AMDArchitecture::GFX908 | AMDArchitecture::GFX90A | AMDArchitecture::GFX94
)
}
}