Skip to content

Commit

Permalink
aio: fix qemu_bh_schedule() bh->ctx race condition
Browse files Browse the repository at this point in the history
qemu_bh_schedule() is supposed to be thread-safe at least the first time
it is called.  Unfortunately this is not quite true:

  bh->scheduled = 1;
  aio_notify(bh->ctx);

Since another thread may run the BH callback once it has been scheduled,
there is a race condition if the callback frees the BH before
aio_notify(bh->ctx) has a chance to run.

Reported-by: Stefan Priebe <[email protected]>
Signed-off-by: Stefan Hajnoczi <[email protected]>
Reviewed-by: Paolo Bonzini <[email protected]>
Tested-by: Stefan Priebe <[email protected]>
  • Loading branch information
stefanhaRH committed Jun 4, 2014
1 parent e00fcfe commit 924fe12
Showing 1 changed file with 10 additions and 4 deletions.
14 changes: 10 additions & 4 deletions async.c
Original file line number Diff line number Diff line change
Expand Up @@ -117,15 +117,21 @@ void qemu_bh_schedule_idle(QEMUBH *bh)

void qemu_bh_schedule(QEMUBH *bh)
{
AioContext *ctx;

if (bh->scheduled)
return;
ctx = bh->ctx;
bh->idle = 0;
/* Make sure that idle & any writes needed by the callback are done
* before the locations are read in the aio_bh_poll.
/* Make sure that:
* 1. idle & any writes needed by the callback are done before the
* locations are read in the aio_bh_poll.
* 2. ctx is loaded before scheduled is set and the callback has a chance
* to execute.
*/
smp_wmb();
smp_mb();
bh->scheduled = 1;
aio_notify(bh->ctx);
aio_notify(ctx);
}


Expand Down

0 comments on commit 924fe12

Please sign in to comment.