mirror of
https://github.com/italicsjenga/vello.git
synced 2025-01-25 18:56:35 +11:00
Put memory barrier reliably before flag write
This commit is contained in:
parent
e50d5c1f58
commit
95aad3e6c7
2 changed files with 5 additions and 2 deletions
|
@ -220,14 +220,16 @@ void main() {
|
||||||
|
|
||||||
// Publish aggregate for this partition
|
// Publish aggregate for this partition
|
||||||
if (gl_LocalInvocationID.x == WG_SIZE - 1) {
|
if (gl_LocalInvocationID.x == WG_SIZE - 1) {
|
||||||
// Note: with memory model, we'd want to generate the atomic store version of this.
|
|
||||||
State_write(state_aggregate_ref(part_ix), agg);
|
State_write(state_aggregate_ref(part_ix), agg);
|
||||||
|
if (part_ix == 0) {
|
||||||
|
State_write(state_prefix_ref(part_ix), agg);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
// Write flag with release semantics; this is done portably with a barrier.
|
||||||
memoryBarrierBuffer();
|
memoryBarrierBuffer();
|
||||||
if (gl_LocalInvocationID.x == WG_SIZE - 1) {
|
if (gl_LocalInvocationID.x == WG_SIZE - 1) {
|
||||||
uint flag = FLAG_AGGREGATE_READY;
|
uint flag = FLAG_AGGREGATE_READY;
|
||||||
if (part_ix == 0) {
|
if (part_ix == 0) {
|
||||||
State_write(state_prefix_ref(part_ix), agg);
|
|
||||||
flag = FLAG_PREFIX_READY;
|
flag = FLAG_PREFIX_READY;
|
||||||
}
|
}
|
||||||
state[state_flag_index(part_ix)] = flag;
|
state[state_flag_index(part_ix)] = flag;
|
||||||
|
@ -239,6 +241,7 @@ void main() {
|
||||||
State their_agg;
|
State their_agg;
|
||||||
uint their_ix = 0;
|
uint their_ix = 0;
|
||||||
while (true) {
|
while (true) {
|
||||||
|
// Read flag with acquire semantics.
|
||||||
if (gl_LocalInvocationID.x == WG_SIZE - 1) {
|
if (gl_LocalInvocationID.x == WG_SIZE - 1) {
|
||||||
sh_flag = state[state_flag_index(look_back_ix)];
|
sh_flag = state[state_flag_index(look_back_ix)];
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
Loading…
Add table
Reference in a new issue