On Mon, Mar 07, 2022 at 03:38:50PM +0000, Stefan Hajnoczi wrote: > The coroutine implementation uses __thread variables internally. Compiler > optimizations may cache Thread-Local Storage values across > qemu_coroutine_yield(), leading to stale values being used after the coroutine > is re-entered from another thread. > > Kevin pointed out that the coroutine implementation itself is vulnerable to > this problem. As a follow-up to my coroutine TLS patch series I'm sending these > patches to convert __thread variables to the new "qemu/coroutine-tls.h" macros > so they are safe. > > Stefan Hajnoczi (3): > coroutine-ucontext: use QEMU_DEFINE_STATIC_CO_TLS() > coroutine: use QEMU_DEFINE_STATIC_CO_TLS() > coroutine-win32: use QEMU_DEFINE_STATIC_CO_TLS() > > util/coroutine-ucontext.c | 38 +++++++++++++++++++++++------------- > util/coroutine-win32.c | 18 ++++++++++++----- > util/qemu-coroutine.c | 41 +++++++++++++++++++++++---------------- > 3 files changed, 61 insertions(+), 36 deletions(-) Kevin: Is this what you had in mind?