diff options
author | Andreas Klebinger <klebinger.andreas@gmx.at> | 2020-04-19 17:29:58 +0200 |
---|---|---|
committer | Ben Gamari <ben@smart-cactus.org> | 2020-07-15 16:41:02 -0400 |
commit | 1d197f4bbe5bf6d7189c329a742917db3f67ad34 (patch) | |
tree | 15bce49cc7bfa4707ae421e7acbcc46a851ceffa /rts | |
parent | bc79f9f180b3fc73fe25439faf9cc5f19622acb3 (diff) | |
download | haskell-1d197f4bbe5bf6d7189c329a742917db3f67ad34.tar.gz |
winio: Mark outstanding_service_requests volatile.
As far as I know C(99) gives no guarantees for code like
bool condition;
...
while(condition)
sleep();
that condition will be updated if it's changed by another thread.
So we are explicit here and mark it as volatile, this will force
a reload from memory on each iteration.
Diffstat (limited to 'rts')
-rw-r--r-- | rts/win32/AsyncWinIO.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/rts/win32/AsyncWinIO.c b/rts/win32/AsyncWinIO.c index 1122f2760c..1a4c6414ce 100644 --- a/rts/win32/AsyncWinIO.c +++ b/rts/win32/AsyncWinIO.c @@ -134,8 +134,14 @@ uint64_t outstanding_requests = 0; /* Boolean controlling if the I/O manager is/should still be running. */ bool running = false; /* Boolean to indicate whether we have outstanding I/O requests that still need - to be processed by the I/O manager on the Haskell side. */ -bool outstanding_service_requests = false; + to be processed by the I/O manager on the Haskell side. + Set by: + notifyRtsOfFinishedCall (true) + servicedIOEntries (false) + Read by: + runner + */ +volatile bool outstanding_service_requests = false; /* Indicates wether we have hit one case where we serviced as much requests as we could because the buffer got full. In such cases for the next requests we expand the buffers so we have room to process requests in bigger |