mirror of
https://github.com/italicsjenga/vello.git
synced 2025-01-10 12:41:30 +11:00
Increase sizes of binning buffers
Increase the size of the bin header and path buffers to accommodate the actual extents accessed by the shaders. Also add a missing workgroup barrier, not essential to fixing this bug but found while auditing the code. Fixes #222
This commit is contained in:
parent
571822248c
commit
e2469fbcaa
|
@ -62,6 +62,7 @@ fn main(
|
||||||
for (var i = 0u; i < N_SLICE; i += 1u) {
|
for (var i = 0u; i < N_SLICE; i += 1u) {
|
||||||
atomicStore(&sh_bitmaps[i][local_id.x], 0u);
|
atomicStore(&sh_bitmaps[i][local_id.x], 0u);
|
||||||
}
|
}
|
||||||
|
workgroupBarrier();
|
||||||
|
|
||||||
// Read inputs and determine coverage of bins
|
// Read inputs and determine coverage of bins
|
||||||
let element_ix = global_id.x;
|
let element_ix = global_id.x;
|
||||||
|
|
|
@ -334,8 +334,7 @@ pub fn render_full(
|
||||||
let bump_buf = BufProxy::new(BUMP_SIZE);
|
let bump_buf = BufProxy::new(BUMP_SIZE);
|
||||||
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 n_bins = width_in_bins * height_in_bins;
|
let bin_header_buf = ResourceProxy::new_buf((256 * drawobj_wgs) as u64 * BIN_HEADER_SIZE);
|
||||||
let bin_header_buf = ResourceProxy::new_buf((n_bins * drawobj_wgs) as u64 * BIN_HEADER_SIZE);
|
|
||||||
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(
|
||||||
|
@ -352,7 +351,10 @@ pub fn render_full(
|
||||||
bin_header_buf,
|
bin_header_buf,
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
let path_buf = ResourceProxy::new_buf(n_path as u64 * PATH_SIZE);
|
// Note: this only needs to be rounded up because of the workaround to store the tile_offset
|
||||||
|
// in storage rather than workgroup memory.
|
||||||
|
let n_path_aligned = align_up(n_path as usize, 256);
|
||||||
|
let path_buf = ResourceProxy::new_buf(n_path_aligned as u64 * PATH_SIZE);
|
||||||
let tile_buf = ResourceProxy::new_buf(1 << 20);
|
let tile_buf = ResourceProxy::new_buf(1 << 20);
|
||||||
let path_wgs = (n_path + shaders::PATH_BBOX_WG - 1) / shaders::PATH_BBOX_WG;
|
let path_wgs = (n_path + shaders::PATH_BBOX_WG - 1) / shaders::PATH_BBOX_WG;
|
||||||
recording.dispatch(
|
recording.dispatch(
|
||||||
|
|
Loading…
Reference in a new issue