mirror of
https://github.com/italicsjenga/vello.git
synced 2025-01-25 18:56:35 +11:00
Add capability to function as a guest in Metal
WIP
This commit is contained in:
parent
41c7118e91
commit
5e221d2e91
3 changed files with 47 additions and 36 deletions
|
@ -16,7 +16,7 @@ mod macros;
|
||||||
mod mux;
|
mod mux;
|
||||||
|
|
||||||
pub use crate::mux::{
|
pub use crate::mux::{
|
||||||
DescriptorSet, Fence, Instance, Pipeline, QueryPool, Sampler, Semaphore, ShaderCode, Surface,
|
DescriptorSet, Device, Fence, Instance, Pipeline, QueryPool, Sampler, Semaphore, ShaderCode, Surface,
|
||||||
Swapchain,
|
Swapchain,
|
||||||
};
|
};
|
||||||
pub use bufwrite::BufWrite;
|
pub use bufwrite::BufWrite;
|
||||||
|
|
|
@ -153,41 +153,7 @@ impl MtlInstance {
|
||||||
pub fn device(&self, _surface: Option<&MtlSurface>) -> Result<MtlDevice, Error> {
|
pub fn device(&self, _surface: Option<&MtlSurface>) -> Result<MtlDevice, Error> {
|
||||||
if let Some(device) = metal::Device::system_default() {
|
if let Some(device) = metal::Device::system_default() {
|
||||||
let cmd_queue = device.new_command_queue();
|
let cmd_queue = device.new_command_queue();
|
||||||
let is_mac = device.supports_feature_set(MTLFeatureSet::macOS_GPUFamily1_v1);
|
Ok(MtlDevice::new_from_raw_mtl(device, cmd_queue))
|
||||||
let is_ios = device.supports_feature_set(MTLFeatureSet::iOS_GPUFamily1_v1);
|
|
||||||
let version = NSOperatingSystemVersion::get();
|
|
||||||
|
|
||||||
let use_staging_buffers =
|
|
||||||
if (is_mac && version.at_least(10, 15)) || (is_ios && version.at_least(13, 0)) {
|
|
||||||
!device.has_unified_memory()
|
|
||||||
} else {
|
|
||||||
!device.is_low_power()
|
|
||||||
};
|
|
||||||
// TODO: these are conservative; we need to derive these from
|
|
||||||
// supports_feature_set queries.
|
|
||||||
let gpu_info = GpuInfo {
|
|
||||||
has_descriptor_indexing: false,
|
|
||||||
has_subgroups: false,
|
|
||||||
subgroup_size: None,
|
|
||||||
// The workgroup limits are taken from the minimum of a desktop installation;
|
|
||||||
// we don't support iOS right now, but in case of testing on those devices it might
|
|
||||||
// need to change these (or just queried properly).
|
|
||||||
workgroup_limits: WorkgroupLimits {
|
|
||||||
max_size: [1024, 1024, 64],
|
|
||||||
max_invocations: 1024,
|
|
||||||
},
|
|
||||||
has_memory_model: false,
|
|
||||||
use_staging_buffers,
|
|
||||||
};
|
|
||||||
let helpers = Arc::new(Helpers {
|
|
||||||
clear_pipeline: clear::make_clear_pipeline(&device),
|
|
||||||
});
|
|
||||||
Ok(MtlDevice {
|
|
||||||
device,
|
|
||||||
cmd_queue: Arc::new(Mutex::new(cmd_queue)),
|
|
||||||
gpu_info,
|
|
||||||
helpers,
|
|
||||||
})
|
|
||||||
} else {
|
} else {
|
||||||
Err("can't create system default Metal device".into())
|
Err("can't create system default Metal device".into())
|
||||||
}
|
}
|
||||||
|
@ -212,6 +178,46 @@ impl MtlInstance {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl MtlDevice {
|
||||||
|
pub fn new_from_raw_mtl(device: metal::Device, cmd_queue: metal::CommandQueue) -> MtlDevice {
|
||||||
|
let is_mac = device.supports_feature_set(MTLFeatureSet::macOS_GPUFamily1_v1);
|
||||||
|
let is_ios = device.supports_feature_set(MTLFeatureSet::iOS_GPUFamily1_v1);
|
||||||
|
let version = NSOperatingSystemVersion::get();
|
||||||
|
|
||||||
|
let use_staging_buffers =
|
||||||
|
if (is_mac && version.at_least(10, 15)) || (is_ios && version.at_least(13, 0)) {
|
||||||
|
!device.has_unified_memory()
|
||||||
|
} else {
|
||||||
|
!device.is_low_power()
|
||||||
|
};
|
||||||
|
// TODO: these are conservative; we need to derive these from
|
||||||
|
// supports_feature_set queries.
|
||||||
|
let gpu_info = GpuInfo {
|
||||||
|
has_descriptor_indexing: false,
|
||||||
|
has_subgroups: false,
|
||||||
|
subgroup_size: None,
|
||||||
|
// The workgroup limits are taken from the minimum of a desktop installation;
|
||||||
|
// we don't support iOS right now, but in case of testing on those devices it might
|
||||||
|
// need to change these (or just queried properly).
|
||||||
|
workgroup_limits: WorkgroupLimits {
|
||||||
|
max_size: [1024, 1024, 64],
|
||||||
|
max_invocations: 1024,
|
||||||
|
},
|
||||||
|
has_memory_model: false,
|
||||||
|
use_staging_buffers,
|
||||||
|
};
|
||||||
|
let helpers = Arc::new(Helpers {
|
||||||
|
clear_pipeline: clear::make_clear_pipeline(&device),
|
||||||
|
});
|
||||||
|
MtlDevice {
|
||||||
|
device,
|
||||||
|
cmd_queue: Arc::new(Mutex::new(cmd_queue)),
|
||||||
|
gpu_info,
|
||||||
|
helpers,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl crate::backend::Device for MtlDevice {
|
impl crate::backend::Device for MtlDevice {
|
||||||
type Buffer = Buffer;
|
type Buffer = Buffer;
|
||||||
|
|
||||||
|
|
|
@ -208,6 +208,11 @@ impl Instance {
|
||||||
// but not doing so lets us diverge more easily (at the moment, the divergence is
|
// but not doing so lets us diverge more easily (at the moment, the divergence is
|
||||||
// missing functionality).
|
// missing functionality).
|
||||||
impl Device {
|
impl Device {
|
||||||
|
#[cfg(target_os = "macos")]
|
||||||
|
pub fn new_from_raw_mtl(device: &::metal::DeviceRef, queue: &::metal::CommandQueueRef) -> Device {
|
||||||
|
Device::Mtl(metal::MtlDevice::new_from_raw_mtl(device.to_owned(), queue.to_owned()))
|
||||||
|
}
|
||||||
|
|
||||||
pub fn query_gpu_info(&self) -> GpuInfo {
|
pub fn query_gpu_info(&self) -> GpuInfo {
|
||||||
mux_match! { self;
|
mux_match! { self;
|
||||||
Device::Vk(d) => d.query_gpu_info(),
|
Device::Vk(d) => d.query_gpu_info(),
|
||||||
|
|
Loading…
Add table
Reference in a new issue