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:
Raph Levien 2022-12-05 13:26:16 -08:00
parent 571822248c
commit e2469fbcaa
2 changed files with 6 additions and 3 deletions

View file

@ -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;

View file

@ -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(