mirror of
https://github.com/italicsjenga/vello.git
synced 2025-01-10 12:41:30 +11:00
Give buffers names when buffer_labels
feature is enabled (#254)
This commit is contained in:
parent
c428e650d0
commit
db4fc4e449
|
@ -27,3 +27,6 @@ bytemuck = { version = "1.12.1", features = ["derive"] }
|
||||||
smallvec = "1.8.0"
|
smallvec = "1.8.0"
|
||||||
moscato = { git = "https://github.com/dfrg/pinot" }
|
moscato = { git = "https://github.com/dfrg/pinot" }
|
||||||
peniko = { git = "https://github.com/linebender/peniko" }
|
peniko = { git = "https://github.com/linebender/peniko" }
|
||||||
|
|
||||||
|
[features]
|
||||||
|
buffer_labels = []
|
||||||
|
|
|
@ -9,7 +9,7 @@ publish = false
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
wgpu = "0.14"
|
wgpu = "0.14"
|
||||||
vello = { path = "../../" }
|
vello = { path = "../../", features = ["buffer_labels"] }
|
||||||
winit = "0.27.5"
|
winit = "0.27.5"
|
||||||
pollster = "0.2.5"
|
pollster = "0.2.5"
|
||||||
# for picosvg
|
# for picosvg
|
||||||
|
|
107
src/engine.rs
107
src/engine.rs
|
@ -58,6 +58,7 @@ pub struct Recording {
|
||||||
pub struct BufProxy {
|
pub struct BufProxy {
|
||||||
size: u64,
|
size: u64,
|
||||||
id: Id,
|
id: Id,
|
||||||
|
name: &'static str,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Copy, Clone, PartialEq, Eq)]
|
#[derive(Copy, Clone, PartialEq, Eq)]
|
||||||
|
@ -118,15 +119,29 @@ pub enum BindType {
|
||||||
// TODO: Uniform, Sampler, maybe others
|
// TODO: Uniform, Sampler, maybe others
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct BindMapBuffer {
|
||||||
|
buffer: Buffer,
|
||||||
|
#[cfg_attr(not(feature = "buffer_labels"), allow(unused))]
|
||||||
|
label: &'static str,
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
struct BindMap {
|
struct BindMap {
|
||||||
buf_map: HashMap<Id, Buffer>,
|
buf_map: HashMap<Id, BindMapBuffer>,
|
||||||
image_map: HashMap<Id, (Texture, TextureView)>,
|
image_map: HashMap<Id, (Texture, TextureView)>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Hash, PartialEq, Eq)]
|
||||||
|
struct BufferProperties {
|
||||||
|
size: u64,
|
||||||
|
usages: BufferUsages,
|
||||||
|
#[cfg(feature = "buffer_labels")]
|
||||||
|
name: &'static str,
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
struct ResourcePool {
|
struct ResourcePool {
|
||||||
bufs: HashMap<(u64, BufferUsages), Vec<Buffer>>,
|
bufs: HashMap<BufferProperties, Vec<Buffer>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Engine {
|
impl Engine {
|
||||||
|
@ -147,11 +162,12 @@ impl Engine {
|
||||||
pub fn add_shader(
|
pub fn add_shader(
|
||||||
&mut self,
|
&mut self,
|
||||||
device: &Device,
|
device: &Device,
|
||||||
|
label: &'static str,
|
||||||
wgsl: Cow<'static, str>,
|
wgsl: Cow<'static, str>,
|
||||||
layout: &[BindType],
|
layout: &[BindType],
|
||||||
) -> Result<ShaderId, Error> {
|
) -> Result<ShaderId, Error> {
|
||||||
let shader_module = device.create_shader_module(wgpu::ShaderModuleDescriptor {
|
let shader_module = device.create_shader_module(wgpu::ShaderModuleDescriptor {
|
||||||
label: None,
|
label: Some(label),
|
||||||
source: wgpu::ShaderSource::Wgsl(wgsl),
|
source: wgpu::ShaderSource::Wgsl(wgsl),
|
||||||
});
|
});
|
||||||
let entries = layout
|
let entries = layout
|
||||||
|
@ -213,7 +229,7 @@ impl Engine {
|
||||||
push_constant_ranges: &[],
|
push_constant_ranges: &[],
|
||||||
});
|
});
|
||||||
let pipeline = device.create_compute_pipeline(&wgpu::ComputePipelineDescriptor {
|
let pipeline = device.create_compute_pipeline(&wgpu::ComputePipelineDescriptor {
|
||||||
label: None,
|
label: Some(label),
|
||||||
layout: Some(&compute_pipeline_layout),
|
layout: Some(&compute_pipeline_layout),
|
||||||
module: &shader_module,
|
module: &shader_module,
|
||||||
entry_point: "main",
|
entry_point: "main",
|
||||||
|
@ -243,18 +259,18 @@ impl Engine {
|
||||||
Command::Upload(buf_proxy, bytes) => {
|
Command::Upload(buf_proxy, bytes) => {
|
||||||
let usage =
|
let usage =
|
||||||
BufferUsages::COPY_SRC | BufferUsages::COPY_DST | BufferUsages::STORAGE;
|
BufferUsages::COPY_SRC | BufferUsages::COPY_DST | BufferUsages::STORAGE;
|
||||||
let buf = self.pool.get_buf(bytes.len() as u64, usage, device);
|
let buf = self.pool.get_buf(buf_proxy, usage, device);
|
||||||
// TODO: if buffer is newly created, might be better to make it mapped at creation
|
// TODO: if buffer is newly created, might be better to make it mapped at creation
|
||||||
// and copy. However, we expect reuse will be most common.
|
// and copy. However, we expect reuse will be most common.
|
||||||
queue.write_buffer(&buf, 0, bytes);
|
queue.write_buffer(&buf, 0, bytes);
|
||||||
bind_map.insert_buf(buf_proxy.id, buf);
|
bind_map.insert_buf(buf_proxy, buf);
|
||||||
}
|
}
|
||||||
Command::UploadUniform(buf_proxy, bytes) => {
|
Command::UploadUniform(buf_proxy, bytes) => {
|
||||||
let usage = BufferUsages::UNIFORM | BufferUsages::COPY_DST;
|
let usage = BufferUsages::UNIFORM | BufferUsages::COPY_DST;
|
||||||
// Same consideration as above
|
// Same consideration as above
|
||||||
let buf = self.pool.get_buf(bytes.len() as u64, usage, device);
|
let buf = self.pool.get_buf(buf_proxy, usage, device);
|
||||||
queue.write_buffer(&buf, 0, bytes);
|
queue.write_buffer(&buf, 0, bytes);
|
||||||
bind_map.insert_buf(buf_proxy.id, buf);
|
bind_map.insert_buf(buf_proxy, buf);
|
||||||
}
|
}
|
||||||
Command::UploadImage(image_proxy, bytes) => {
|
Command::UploadImage(image_proxy, bytes) => {
|
||||||
let buf = device.create_buffer_init(&wgpu::util::BufferInitDescriptor {
|
let buf = device.create_buffer_init(&wgpu::util::BufferInitDescriptor {
|
||||||
|
@ -326,12 +342,12 @@ impl Engine {
|
||||||
Command::Download(proxy) => {
|
Command::Download(proxy) => {
|
||||||
let src_buf = bind_map.buf_map.get(&proxy.id).ok_or("buffer not in map")?;
|
let src_buf = bind_map.buf_map.get(&proxy.id).ok_or("buffer not in map")?;
|
||||||
let buf = device.create_buffer(&wgpu::BufferDescriptor {
|
let buf = device.create_buffer(&wgpu::BufferDescriptor {
|
||||||
label: None,
|
label: Some(proxy.name),
|
||||||
size: proxy.size,
|
size: proxy.size,
|
||||||
usage: wgpu::BufferUsages::MAP_READ | wgpu::BufferUsages::COPY_DST,
|
usage: wgpu::BufferUsages::MAP_READ | wgpu::BufferUsages::COPY_DST,
|
||||||
mapped_at_creation: false,
|
mapped_at_creation: false,
|
||||||
});
|
});
|
||||||
encoder.copy_buffer_to_buffer(src_buf, 0, &buf, 0, proxy.size);
|
encoder.copy_buffer_to_buffer(&src_buf.buffer, 0, &buf, 0, proxy.size);
|
||||||
downloads.buf_map.insert(proxy.id, buf);
|
downloads.buf_map.insert(proxy.id, buf);
|
||||||
}
|
}
|
||||||
Command::Clear(proxy, offset, size) => {
|
Command::Clear(proxy, offset, size) => {
|
||||||
|
@ -351,16 +367,16 @@ impl Recording {
|
||||||
self.commands.push(cmd);
|
self.commands.push(cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn upload(&mut self, data: impl Into<Vec<u8>>) -> BufProxy {
|
pub fn upload(&mut self, name: &'static str, data: impl Into<Vec<u8>>) -> BufProxy {
|
||||||
let data = data.into();
|
let data = data.into();
|
||||||
let buf_proxy = BufProxy::new(data.len() as u64);
|
let buf_proxy = BufProxy::new(data.len() as u64, name);
|
||||||
self.push(Command::Upload(buf_proxy, data));
|
self.push(Command::Upload(buf_proxy, data));
|
||||||
buf_proxy
|
buf_proxy
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn upload_uniform(&mut self, data: impl Into<Vec<u8>>) -> BufProxy {
|
pub fn upload_uniform(&mut self, name: &'static str, data: impl Into<Vec<u8>>) -> BufProxy {
|
||||||
let data = data.into();
|
let data = data.into();
|
||||||
let buf_proxy = BufProxy::new(data.len() as u64);
|
let buf_proxy = BufProxy::new(data.len() as u64, name);
|
||||||
self.push(Command::UploadUniform(buf_proxy, data));
|
self.push(Command::UploadUniform(buf_proxy, data));
|
||||||
buf_proxy
|
buf_proxy
|
||||||
}
|
}
|
||||||
|
@ -400,11 +416,12 @@ impl Recording {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl BufProxy {
|
impl BufProxy {
|
||||||
pub fn new(size: u64) -> Self {
|
pub fn new(size: u64, name: &'static str) -> Self {
|
||||||
let id = Id::next();
|
let id = Id::next();
|
||||||
BufProxy {
|
BufProxy {
|
||||||
id,
|
id,
|
||||||
size: size.max(16),
|
size: size.max(16),
|
||||||
|
name,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -431,8 +448,8 @@ impl ImageProxy {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ResourceProxy {
|
impl ResourceProxy {
|
||||||
pub fn new_buf(size: u64) -> Self {
|
pub fn new_buf(size: u64, name: &'static str) -> Self {
|
||||||
Self::Buf(BufProxy::new(size))
|
Self::Buf(BufProxy::new(size, name))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn new_image(width: u32, height: u32, format: ImageFormat) -> Self {
|
pub fn new_image(width: u32, height: u32, format: ImageFormat) -> Self {
|
||||||
|
@ -475,8 +492,14 @@ impl Id {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl BindMap {
|
impl BindMap {
|
||||||
fn insert_buf(&mut self, id: Id, buf: Buffer) {
|
fn insert_buf(&mut self, proxy: &BufProxy, buffer: Buffer) {
|
||||||
self.buf_map.insert(id, buf);
|
self.buf_map.insert(
|
||||||
|
proxy.id,
|
||||||
|
BindMapBuffer {
|
||||||
|
buffer,
|
||||||
|
label: proxy.name,
|
||||||
|
},
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn insert_image(&mut self, id: Id, image: Texture, image_view: TextureView) {
|
fn insert_image(&mut self, id: Id, image: Texture, image_view: TextureView) {
|
||||||
|
@ -530,8 +553,11 @@ impl BindMap {
|
||||||
if let Entry::Vacant(v) = self.buf_map.entry(proxy.id) {
|
if let Entry::Vacant(v) = self.buf_map.entry(proxy.id) {
|
||||||
let usage =
|
let usage =
|
||||||
BufferUsages::COPY_SRC | BufferUsages::COPY_DST | BufferUsages::STORAGE;
|
BufferUsages::COPY_SRC | BufferUsages::COPY_DST | BufferUsages::STORAGE;
|
||||||
let buf = pool.get_buf(proxy.size, usage, device);
|
let buf = pool.get_buf(&proxy, usage, device);
|
||||||
v.insert(buf);
|
v.insert(BindMapBuffer {
|
||||||
|
buffer: buf,
|
||||||
|
label: proxy.name,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ResourceProxy::Image(proxy) => {
|
ResourceProxy::Image(proxy) => {
|
||||||
|
@ -573,7 +599,7 @@ impl BindMap {
|
||||||
.map(|(i, proxy)| match proxy {
|
.map(|(i, proxy)| match proxy {
|
||||||
ResourceProxy::Buf(proxy) => {
|
ResourceProxy::Buf(proxy) => {
|
||||||
let buf = find_buf(external_resources, proxy)
|
let buf = find_buf(external_resources, proxy)
|
||||||
.or_else(|| self.buf_map.get(&proxy.id))
|
.or_else(|| self.buf_map.get(&proxy.id).map(|buf| &buf.buffer))
|
||||||
.unwrap();
|
.unwrap();
|
||||||
Ok(wgpu::BindGroupEntry {
|
Ok(wgpu::BindGroupEntry {
|
||||||
binding: i as u32,
|
binding: i as u32,
|
||||||
|
@ -606,11 +632,16 @@ impl BindMap {
|
||||||
pool: &mut ResourcePool,
|
pool: &mut ResourcePool,
|
||||||
) -> Result<&Buffer, Error> {
|
) -> Result<&Buffer, Error> {
|
||||||
match self.buf_map.entry(proxy.id) {
|
match self.buf_map.entry(proxy.id) {
|
||||||
Entry::Occupied(occupied) => Ok(occupied.into_mut()),
|
Entry::Occupied(occupied) => Ok(&occupied.into_mut().buffer),
|
||||||
Entry::Vacant(vacant) => {
|
Entry::Vacant(vacant) => {
|
||||||
let usage = BufferUsages::COPY_SRC | BufferUsages::COPY_DST | BufferUsages::STORAGE;
|
let usage = BufferUsages::COPY_SRC | BufferUsages::COPY_DST | BufferUsages::STORAGE;
|
||||||
let buf = pool.get_buf(proxy.size, usage, device);
|
let buf = pool.get_buf(&proxy, usage, device);
|
||||||
Ok(vacant.insert(buf))
|
Ok(&vacant
|
||||||
|
.insert(BindMapBuffer {
|
||||||
|
buffer: buf,
|
||||||
|
label: proxy.name,
|
||||||
|
})
|
||||||
|
.buffer)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -656,14 +687,23 @@ const SIZE_CLASS_BITS: u32 = 1;
|
||||||
|
|
||||||
impl ResourcePool {
|
impl ResourcePool {
|
||||||
/// Get a buffer from the pool or create one.
|
/// Get a buffer from the pool or create one.
|
||||||
fn get_buf(&mut self, size: u64, usage: BufferUsages, device: &Device) -> Buffer {
|
fn get_buf(&mut self, proxy: &BufProxy, usage: BufferUsages, device: &Device) -> Buffer {
|
||||||
let rounded_size = Self::size_class(size, SIZE_CLASS_BITS);
|
let rounded_size = Self::size_class(proxy.size, SIZE_CLASS_BITS);
|
||||||
if let Some(buf_vec) = self.bufs.get_mut(&(rounded_size, usage)) {
|
let props = BufferProperties {
|
||||||
|
size: rounded_size,
|
||||||
|
usages: usage,
|
||||||
|
#[cfg(feature = "buffer_labels")]
|
||||||
|
name: proxy.name,
|
||||||
|
};
|
||||||
|
if let Some(buf_vec) = self.bufs.get_mut(&props) {
|
||||||
if let Some(buf) = buf_vec.pop() {
|
if let Some(buf) = buf_vec.pop() {
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
device.create_buffer(&wgpu::BufferDescriptor {
|
device.create_buffer(&wgpu::BufferDescriptor {
|
||||||
|
#[cfg(feature = "buffer_labels")]
|
||||||
|
label: Some(proxy.name),
|
||||||
|
#[cfg(not(feature = "buffer_labels"))]
|
||||||
label: None,
|
label: None,
|
||||||
size: rounded_size,
|
size: rounded_size,
|
||||||
usage,
|
usage,
|
||||||
|
@ -673,9 +713,14 @@ impl ResourcePool {
|
||||||
|
|
||||||
fn reap_bindmap(&mut self, bind_map: BindMap) {
|
fn reap_bindmap(&mut self, bind_map: BindMap) {
|
||||||
for (_id, buf) in bind_map.buf_map {
|
for (_id, buf) in bind_map.buf_map {
|
||||||
let size = buf.size();
|
let size = buf.buffer.size();
|
||||||
let usage = buf.usage();
|
let props = BufferProperties {
|
||||||
self.bufs.entry((size, usage)).or_default().push(buf);
|
size,
|
||||||
|
usages: buf.buffer.usage(),
|
||||||
|
#[cfg(feature = "buffer_labels")]
|
||||||
|
name: buf.label,
|
||||||
|
};
|
||||||
|
self.bufs.entry(props).or_default().push(buf.buffer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -77,10 +77,10 @@ fn render(scene: &Scene, shaders: &Shaders) -> (Recording, BufProxy) {
|
||||||
pathdata_base,
|
pathdata_base,
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let scene_buf = recording.upload(scene);
|
let scene_buf = recording.upload("scene", scene);
|
||||||
let config_buf = recording.upload_uniform(bytemuck::bytes_of(&config));
|
let config_buf = recording.upload_uniform("config", bytemuck::bytes_of(&config));
|
||||||
|
|
||||||
let reduced_buf = BufProxy::new(pathtag_wgs as u64 * TAG_MONOID_SIZE);
|
let reduced_buf = BufProxy::new(pathtag_wgs as u64 * TAG_MONOID_SIZE, "reduced_buf");
|
||||||
// TODO: really only need pathtag_wgs - 1
|
// TODO: really only need pathtag_wgs - 1
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.pathtag_reduce,
|
shaders.pathtag_reduce,
|
||||||
|
@ -88,8 +88,10 @@ fn render(scene: &Scene, shaders: &Shaders) -> (Recording, BufProxy) {
|
||||||
[config_buf, scene_buf, reduced_buf],
|
[config_buf, scene_buf, reduced_buf],
|
||||||
);
|
);
|
||||||
|
|
||||||
let tagmonoid_buf =
|
let tagmonoid_buf = BufProxy::new(
|
||||||
BufProxy::new(pathtag_wgs as u64 * shaders::PATHTAG_REDUCE_WG as u64 * TAG_MONOID_SIZE);
|
pathtag_wgs as u64 * shaders::PATHTAG_REDUCE_WG as u64 * TAG_MONOID_SIZE,
|
||||||
|
"tagmonoid_buf",
|
||||||
|
);
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.pathtag_scan,
|
shaders.pathtag_scan,
|
||||||
(pathtag_wgs as u32, 1, 1),
|
(pathtag_wgs as u32, 1, 1),
|
||||||
|
@ -99,8 +101,8 @@ fn render(scene: &Scene, shaders: &Shaders) -> (Recording, BufProxy) {
|
||||||
let path_coarse_wgs =
|
let path_coarse_wgs =
|
||||||
(n_pathtag as u32 + shaders::PATH_COARSE_WG - 1) / shaders::PATH_COARSE_WG;
|
(n_pathtag as u32 + shaders::PATH_COARSE_WG - 1) / shaders::PATH_COARSE_WG;
|
||||||
// TODO: more principled size calc
|
// TODO: more principled size calc
|
||||||
let tiles_buf = BufProxy::new(4097 * 8);
|
let tiles_buf = BufProxy::new(4097 * 8, "tiles_buf");
|
||||||
let segments_buf = BufProxy::new(256 * 24);
|
let segments_buf = BufProxy::new(256 * 24, "segments_buf");
|
||||||
recording.clear_all(tiles_buf);
|
recording.clear_all(tiles_buf);
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.path_coarse,
|
shaders.path_coarse,
|
||||||
|
@ -119,7 +121,7 @@ fn render(scene: &Scene, shaders: &Shaders) -> (Recording, BufProxy) {
|
||||||
[config_buf, tiles_buf],
|
[config_buf, tiles_buf],
|
||||||
);
|
);
|
||||||
let out_buf_size = config.width_in_tiles * config.height_in_tiles * 256;
|
let out_buf_size = config.width_in_tiles * config.height_in_tiles * 256;
|
||||||
let out_buf = BufProxy::new(out_buf_size as u64);
|
let out_buf = BufProxy::new(out_buf_size as u64, "out_buf");
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.fine,
|
shaders.fine,
|
||||||
(config.width_in_tiles, config.height_in_tiles, 1),
|
(config.width_in_tiles, config.height_in_tiles, 1),
|
||||||
|
@ -180,8 +182,9 @@ pub fn render_encoding_full(
|
||||||
layout: packed.layout,
|
layout: packed.layout,
|
||||||
};
|
};
|
||||||
// println!("{:?}", config);
|
// println!("{:?}", config);
|
||||||
let scene_buf = ResourceProxy::Buf(recording.upload(packed.data));
|
let scene_buf = ResourceProxy::Buf(recording.upload("scene", packed.data));
|
||||||
let config_buf = ResourceProxy::Buf(recording.upload_uniform(bytemuck::bytes_of(&config)));
|
let config_buf =
|
||||||
|
ResourceProxy::Buf(recording.upload_uniform("config", bytemuck::bytes_of(&config)));
|
||||||
|
|
||||||
let pathtag_wgs = pathtag_padded / (4 * shaders::PATHTAG_REDUCE_WG as usize);
|
let pathtag_wgs = pathtag_padded / (4 * shaders::PATHTAG_REDUCE_WG as usize);
|
||||||
let pathtag_large = pathtag_wgs > shaders::PATHTAG_REDUCE_WG as usize;
|
let pathtag_large = pathtag_wgs > shaders::PATHTAG_REDUCE_WG as usize;
|
||||||
|
@ -190,7 +193,8 @@ pub fn render_encoding_full(
|
||||||
} else {
|
} else {
|
||||||
pathtag_wgs
|
pathtag_wgs
|
||||||
};
|
};
|
||||||
let reduced_buf = ResourceProxy::new_buf(reduced_size as u64 * TAG_MONOID_FULL_SIZE);
|
let reduced_buf =
|
||||||
|
ResourceProxy::new_buf(reduced_size as u64 * TAG_MONOID_FULL_SIZE, "reduced_buf");
|
||||||
// TODO: really only need pathtag_wgs - 1
|
// TODO: really only need pathtag_wgs - 1
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.pathtag_reduce,
|
shaders.pathtag_reduce,
|
||||||
|
@ -200,13 +204,17 @@ pub fn render_encoding_full(
|
||||||
let mut pathtag_parent = reduced_buf;
|
let mut pathtag_parent = reduced_buf;
|
||||||
if pathtag_large {
|
if pathtag_large {
|
||||||
let reduced2_size = shaders::PATHTAG_REDUCE_WG as usize;
|
let reduced2_size = shaders::PATHTAG_REDUCE_WG as usize;
|
||||||
let reduced2_buf = ResourceProxy::new_buf(reduced2_size as u64 * TAG_MONOID_FULL_SIZE);
|
let reduced2_buf =
|
||||||
|
ResourceProxy::new_buf(reduced2_size as u64 * TAG_MONOID_FULL_SIZE, "reduced2_buf");
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.pathtag_reduce2,
|
shaders.pathtag_reduce2,
|
||||||
(reduced2_size as u32, 1, 1),
|
(reduced2_size as u32, 1, 1),
|
||||||
[reduced_buf, reduced2_buf],
|
[reduced_buf, reduced2_buf],
|
||||||
);
|
);
|
||||||
let reduced_scan_buf = ResourceProxy::new_buf(pathtag_wgs as u64 * TAG_MONOID_FULL_SIZE);
|
let reduced_scan_buf = ResourceProxy::new_buf(
|
||||||
|
pathtag_wgs as u64 * TAG_MONOID_FULL_SIZE,
|
||||||
|
"reduced_scan_buf",
|
||||||
|
);
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.pathtag_scan1,
|
shaders.pathtag_scan1,
|
||||||
(reduced_size as u32 / shaders::PATHTAG_REDUCE_WG, 1, 1),
|
(reduced_size as u32 / shaders::PATHTAG_REDUCE_WG, 1, 1),
|
||||||
|
@ -217,6 +225,7 @@ pub fn render_encoding_full(
|
||||||
|
|
||||||
let tagmonoid_buf = ResourceProxy::new_buf(
|
let tagmonoid_buf = ResourceProxy::new_buf(
|
||||||
pathtag_wgs as u64 * shaders::PATHTAG_REDUCE_WG as u64 * TAG_MONOID_FULL_SIZE,
|
pathtag_wgs as u64 * shaders::PATHTAG_REDUCE_WG as u64 * TAG_MONOID_FULL_SIZE,
|
||||||
|
"tagmonoid_buf",
|
||||||
);
|
);
|
||||||
let pathtag_scan = if pathtag_large {
|
let pathtag_scan = if pathtag_large {
|
||||||
shaders.pathtag_scan_large
|
shaders.pathtag_scan_large
|
||||||
|
@ -229,13 +238,13 @@ pub fn render_encoding_full(
|
||||||
[config_buf, scene_buf, pathtag_parent, tagmonoid_buf],
|
[config_buf, scene_buf, pathtag_parent, tagmonoid_buf],
|
||||||
);
|
);
|
||||||
let drawobj_wgs = (n_drawobj + shaders::PATH_BBOX_WG - 1) / shaders::PATH_BBOX_WG;
|
let drawobj_wgs = (n_drawobj + shaders::PATH_BBOX_WG - 1) / shaders::PATH_BBOX_WG;
|
||||||
let path_bbox_buf = ResourceProxy::new_buf(n_paths as u64 * PATH_BBOX_SIZE);
|
let path_bbox_buf = ResourceProxy::new_buf(n_paths as u64 * PATH_BBOX_SIZE, "path_bbox_buf");
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.bbox_clear,
|
shaders.bbox_clear,
|
||||||
(drawobj_wgs, 1, 1),
|
(drawobj_wgs, 1, 1),
|
||||||
[config_buf, path_bbox_buf],
|
[config_buf, path_bbox_buf],
|
||||||
);
|
);
|
||||||
let cubic_buf = ResourceProxy::new_buf(n_pathtag as u64 * CUBIC_SIZE);
|
let cubic_buf = ResourceProxy::new_buf(n_pathtag as u64 * CUBIC_SIZE, "cubic_buf");
|
||||||
let path_coarse_wgs =
|
let path_coarse_wgs =
|
||||||
(n_pathtag as u32 + shaders::PATH_COARSE_WG - 1) / shaders::PATH_COARSE_WG;
|
(n_pathtag as u32 + shaders::PATH_COARSE_WG - 1) / shaders::PATH_COARSE_WG;
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
|
@ -249,15 +258,18 @@ pub fn render_encoding_full(
|
||||||
cubic_buf,
|
cubic_buf,
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
let draw_reduced_buf = ResourceProxy::new_buf(drawobj_wgs as u64 * DRAWMONOID_SIZE);
|
let draw_reduced_buf =
|
||||||
|
ResourceProxy::new_buf(drawobj_wgs as u64 * DRAWMONOID_SIZE, "draw_reduced_buf");
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.draw_reduce,
|
shaders.draw_reduce,
|
||||||
(drawobj_wgs, 1, 1),
|
(drawobj_wgs, 1, 1),
|
||||||
[config_buf, scene_buf, draw_reduced_buf],
|
[config_buf, scene_buf, draw_reduced_buf],
|
||||||
);
|
);
|
||||||
let draw_monoid_buf = ResourceProxy::new_buf(n_drawobj as u64 * DRAWMONOID_SIZE);
|
let draw_monoid_buf =
|
||||||
let info_bin_data_buf = ResourceProxy::new_buf(1 << 20);
|
ResourceProxy::new_buf(n_drawobj as u64 * DRAWMONOID_SIZE, "draw_monoid_buf");
|
||||||
let clip_inp_buf = ResourceProxy::new_buf(encoding.n_clips as u64 * CLIP_INP_SIZE);
|
let info_bin_data_buf = ResourceProxy::new_buf(1 << 20, "info_bin_data_buf");
|
||||||
|
let clip_inp_buf =
|
||||||
|
ResourceProxy::new_buf(encoding.n_clips as u64 * CLIP_INP_SIZE, "clip_inp_buf");
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.draw_leaf,
|
shaders.draw_leaf,
|
||||||
(drawobj_wgs, 1, 1),
|
(drawobj_wgs, 1, 1),
|
||||||
|
@ -271,9 +283,11 @@ pub fn render_encoding_full(
|
||||||
clip_inp_buf,
|
clip_inp_buf,
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
let clip_el_buf = ResourceProxy::new_buf(encoding.n_clips as u64 * CLIP_EL_SIZE);
|
let clip_el_buf = ResourceProxy::new_buf(encoding.n_clips as u64 * CLIP_EL_SIZE, "clip_el_buf");
|
||||||
let clip_bic_buf =
|
let clip_bic_buf = ResourceProxy::new_buf(
|
||||||
ResourceProxy::new_buf((n_clip / shaders::CLIP_REDUCE_WG) as u64 * CLIP_BIC_SIZE);
|
(n_clip / shaders::CLIP_REDUCE_WG) as u64 * CLIP_BIC_SIZE,
|
||||||
|
"clip_bic_buf",
|
||||||
|
);
|
||||||
let clip_wg_reduce = n_clip.saturating_sub(1) / shaders::CLIP_REDUCE_WG;
|
let clip_wg_reduce = n_clip.saturating_sub(1) / shaders::CLIP_REDUCE_WG;
|
||||||
if clip_wg_reduce > 0 {
|
if clip_wg_reduce > 0 {
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
|
@ -289,7 +303,7 @@ pub fn render_encoding_full(
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
let clip_wg = (n_clip + shaders::CLIP_REDUCE_WG - 1) / shaders::CLIP_REDUCE_WG;
|
let clip_wg = (n_clip + shaders::CLIP_REDUCE_WG - 1) / shaders::CLIP_REDUCE_WG;
|
||||||
let clip_bbox_buf = ResourceProxy::new_buf(n_clip as u64 * CLIP_BBOX_SIZE);
|
let clip_bbox_buf = ResourceProxy::new_buf(n_clip as u64 * CLIP_BBOX_SIZE, "clip_bbox_buf");
|
||||||
if clip_wg > 0 {
|
if clip_wg > 0 {
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.clip_leaf,
|
shaders.clip_leaf,
|
||||||
|
@ -305,11 +319,14 @@ pub fn render_encoding_full(
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
let draw_bbox_buf = ResourceProxy::new_buf(n_paths as u64 * DRAW_BBOX_SIZE);
|
let draw_bbox_buf = ResourceProxy::new_buf(n_paths as u64 * DRAW_BBOX_SIZE, "draw_bbox_buf");
|
||||||
let bump_buf = BufProxy::new(BUMP_SIZE);
|
let bump_buf = BufProxy::new(BUMP_SIZE, "bump_buf");
|
||||||
let width_in_bins = (config.width_in_tiles + 15) / 16;
|
let width_in_bins = (config.width_in_tiles + 15) / 16;
|
||||||
let height_in_bins = (config.height_in_tiles + 15) / 16;
|
let height_in_bins = (config.height_in_tiles + 15) / 16;
|
||||||
let bin_header_buf = ResourceProxy::new_buf((256 * drawobj_wgs) as u64 * BIN_HEADER_SIZE);
|
let bin_header_buf = ResourceProxy::new_buf(
|
||||||
|
(256 * drawobj_wgs) as u64 * BIN_HEADER_SIZE,
|
||||||
|
"bin_header_buf",
|
||||||
|
);
|
||||||
recording.clear_all(bump_buf);
|
recording.clear_all(bump_buf);
|
||||||
let bump_buf = ResourceProxy::Buf(bump_buf);
|
let bump_buf = ResourceProxy::Buf(bump_buf);
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
|
@ -329,8 +346,8 @@ pub fn render_encoding_full(
|
||||||
// Note: this only needs to be rounded up because of the workaround to store the tile_offset
|
// Note: this only needs to be rounded up because of the workaround to store the tile_offset
|
||||||
// in storage rather than workgroup memory.
|
// in storage rather than workgroup memory.
|
||||||
let n_path_aligned = align_up(n_paths as usize, 256);
|
let n_path_aligned = align_up(n_paths as usize, 256);
|
||||||
let path_buf = ResourceProxy::new_buf(n_path_aligned as u64 * PATH_SIZE);
|
let path_buf = ResourceProxy::new_buf(n_path_aligned as u64 * PATH_SIZE, "path_buf");
|
||||||
let tile_buf = ResourceProxy::new_buf(1 << 24);
|
let tile_buf = ResourceProxy::new_buf(1 << 24, "tile_buf");
|
||||||
let path_wgs = (n_paths + shaders::PATH_BBOX_WG - 1) / shaders::PATH_BBOX_WG;
|
let path_wgs = (n_paths + shaders::PATH_BBOX_WG - 1) / shaders::PATH_BBOX_WG;
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.tile_alloc,
|
shaders.tile_alloc,
|
||||||
|
@ -345,7 +362,7 @@ pub fn render_encoding_full(
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
|
|
||||||
let segments_buf = ResourceProxy::new_buf(1 << 24);
|
let segments_buf = ResourceProxy::new_buf(1 << 24, "segments_buf");
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.path_coarse,
|
shaders.path_coarse,
|
||||||
(path_coarse_wgs, 1, 1),
|
(path_coarse_wgs, 1, 1),
|
||||||
|
@ -365,7 +382,7 @@ pub fn render_encoding_full(
|
||||||
(path_wgs, 1, 1),
|
(path_wgs, 1, 1),
|
||||||
[config_buf, path_buf, tile_buf],
|
[config_buf, path_buf, tile_buf],
|
||||||
);
|
);
|
||||||
let ptcl_buf = ResourceProxy::new_buf(1 << 24);
|
let ptcl_buf = ResourceProxy::new_buf(1 << 24, "ptcl_buf");
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
shaders.coarse,
|
shaders.coarse,
|
||||||
(width_in_bins, height_in_bins, 1),
|
(width_in_bins, height_in_bins, 1),
|
||||||
|
|
|
@ -73,11 +73,13 @@ pub fn init_shaders(device: &Device, engine: &mut Engine) -> Result<Shaders, Err
|
||||||
let empty = HashSet::new();
|
let empty = HashSet::new();
|
||||||
let pathtag_reduce = engine.add_shader(
|
let pathtag_reduce = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"pathtag_reduce",
|
||||||
preprocess::preprocess(shader!("pathtag_reduce"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("pathtag_reduce"), &empty, &imports).into(),
|
||||||
&[BindType::Uniform, BindType::BufReadOnly, BindType::Buffer],
|
&[BindType::Uniform, BindType::BufReadOnly, BindType::Buffer],
|
||||||
)?;
|
)?;
|
||||||
let pathtag_scan = engine.add_shader(
|
let pathtag_scan = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"pathtag_scan",
|
||||||
preprocess::preprocess(shader!("pathtag_scan"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("pathtag_scan"), &empty, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -91,6 +93,7 @@ pub fn init_shaders(device: &Device, engine: &mut Engine) -> Result<Shaders, Err
|
||||||
|
|
||||||
let path_coarse = engine.add_shader(
|
let path_coarse = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"path_coarse",
|
||||||
preprocess::preprocess(shader!("path_coarse"), &path_coarse_config, &imports).into(),
|
preprocess::preprocess(shader!("path_coarse"), &path_coarse_config, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -102,11 +105,13 @@ pub fn init_shaders(device: &Device, engine: &mut Engine) -> Result<Shaders, Err
|
||||||
)?;
|
)?;
|
||||||
let backdrop = engine.add_shader(
|
let backdrop = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"backdrop",
|
||||||
preprocess::preprocess(shader!("backdrop"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("backdrop"), &empty, &imports).into(),
|
||||||
&[BindType::Uniform, BindType::Buffer],
|
&[BindType::Uniform, BindType::Buffer],
|
||||||
)?;
|
)?;
|
||||||
let fine = engine.add_shader(
|
let fine = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"fine",
|
||||||
preprocess::preprocess(shader!("fine"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("fine"), &empty, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -137,16 +142,19 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
small_config.insert("small".into());
|
small_config.insert("small".into());
|
||||||
let pathtag_reduce = engine.add_shader(
|
let pathtag_reduce = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"pathtag_reduce",
|
||||||
preprocess::preprocess(shader!("pathtag_reduce"), &full_config, &imports).into(),
|
preprocess::preprocess(shader!("pathtag_reduce"), &full_config, &imports).into(),
|
||||||
&[BindType::Uniform, BindType::BufReadOnly, BindType::Buffer],
|
&[BindType::Uniform, BindType::BufReadOnly, BindType::Buffer],
|
||||||
)?;
|
)?;
|
||||||
let pathtag_reduce2 = engine.add_shader(
|
let pathtag_reduce2 = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"pathtag_reduce2",
|
||||||
preprocess::preprocess(shader!("pathtag_reduce2"), &full_config, &imports).into(),
|
preprocess::preprocess(shader!("pathtag_reduce2"), &full_config, &imports).into(),
|
||||||
&[BindType::BufReadOnly, BindType::Buffer],
|
&[BindType::BufReadOnly, BindType::Buffer],
|
||||||
)?;
|
)?;
|
||||||
let pathtag_scan1 = engine.add_shader(
|
let pathtag_scan1 = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"pathtag_scan1",
|
||||||
preprocess::preprocess(shader!("pathtag_scan1"), &full_config, &imports).into(),
|
preprocess::preprocess(shader!("pathtag_scan1"), &full_config, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::BufReadOnly,
|
BindType::BufReadOnly,
|
||||||
|
@ -156,6 +164,7 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let pathtag_scan = engine.add_shader(
|
let pathtag_scan = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"pathtag_scan",
|
||||||
preprocess::preprocess(shader!("pathtag_scan"), &small_config, &imports).into(),
|
preprocess::preprocess(shader!("pathtag_scan"), &small_config, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -166,6 +175,7 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let pathtag_scan_large = engine.add_shader(
|
let pathtag_scan_large = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"pathtag_scan",
|
||||||
preprocess::preprocess(shader!("pathtag_scan"), &full_config, &imports).into(),
|
preprocess::preprocess(shader!("pathtag_scan"), &full_config, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -176,11 +186,13 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let bbox_clear = engine.add_shader(
|
let bbox_clear = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"bbox_clear",
|
||||||
preprocess::preprocess(shader!("bbox_clear"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("bbox_clear"), &empty, &imports).into(),
|
||||||
&[BindType::Uniform, BindType::Buffer],
|
&[BindType::Uniform, BindType::Buffer],
|
||||||
)?;
|
)?;
|
||||||
let pathseg = engine.add_shader(
|
let pathseg = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"pathseg",
|
||||||
preprocess::preprocess(shader!("pathseg"), &full_config, &imports).into(),
|
preprocess::preprocess(shader!("pathseg"), &full_config, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -192,11 +204,13 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let draw_reduce = engine.add_shader(
|
let draw_reduce = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"draw_reduce",
|
||||||
preprocess::preprocess(shader!("draw_reduce"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("draw_reduce"), &empty, &imports).into(),
|
||||||
&[BindType::Uniform, BindType::BufReadOnly, BindType::Buffer],
|
&[BindType::Uniform, BindType::BufReadOnly, BindType::Buffer],
|
||||||
)?;
|
)?;
|
||||||
let draw_leaf = engine.add_shader(
|
let draw_leaf = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"draw_leaf",
|
||||||
preprocess::preprocess(shader!("draw_leaf"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("draw_leaf"), &empty, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -210,6 +224,7 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let clip_reduce = engine.add_shader(
|
let clip_reduce = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"clip_reduce",
|
||||||
preprocess::preprocess(shader!("clip_reduce"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("clip_reduce"), &empty, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -221,6 +236,7 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let clip_leaf = engine.add_shader(
|
let clip_leaf = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"clip_leaf",
|
||||||
preprocess::preprocess(shader!("clip_leaf"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("clip_leaf"), &empty, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -234,6 +250,7 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let binning = engine.add_shader(
|
let binning = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"binning",
|
||||||
preprocess::preprocess(shader!("binning"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("binning"), &empty, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -248,6 +265,7 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let tile_alloc = engine.add_shader(
|
let tile_alloc = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"tile_alloc",
|
||||||
preprocess::preprocess(shader!("tile_alloc"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("tile_alloc"), &empty, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -261,6 +279,7 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
|
|
||||||
let path_coarse = engine.add_shader(
|
let path_coarse = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"path_coarse_full",
|
||||||
preprocess::preprocess(shader!("path_coarse_full"), &full_config, &imports).into(),
|
preprocess::preprocess(shader!("path_coarse_full"), &full_config, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -275,11 +294,13 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let backdrop = engine.add_shader(
|
let backdrop = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"backdrop_dyn",
|
||||||
preprocess::preprocess(shader!("backdrop_dyn"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("backdrop_dyn"), &empty, &imports).into(),
|
||||||
&[BindType::Uniform, BindType::BufReadOnly, BindType::Buffer],
|
&[BindType::Uniform, BindType::BufReadOnly, BindType::Buffer],
|
||||||
)?;
|
)?;
|
||||||
let coarse = engine.add_shader(
|
let coarse = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"coarse",
|
||||||
preprocess::preprocess(shader!("coarse"), &empty, &imports).into(),
|
preprocess::preprocess(shader!("coarse"), &empty, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
@ -295,6 +316,7 @@ pub fn full_shaders(device: &Device, engine: &mut Engine) -> Result<FullShaders,
|
||||||
)?;
|
)?;
|
||||||
let fine = engine.add_shader(
|
let fine = engine.add_shader(
|
||||||
device,
|
device,
|
||||||
|
"fine",
|
||||||
preprocess::preprocess(shader!("fine"), &full_config, &imports).into(),
|
preprocess::preprocess(shader!("fine"), &full_config, &imports).into(),
|
||||||
&[
|
&[
|
||||||
BindType::Uniform,
|
BindType::Uniform,
|
||||||
|
|
Loading…
Reference in a new issue