[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH 0/3] coroutine: use QEMU_DEFINE_STATIC_CO_TLS()
|
From: |
Stefan Hajnoczi |
|
Subject: |
Re: [PATCH 0/3] coroutine: use QEMU_DEFINE_STATIC_CO_TLS() |
|
Date: |
Wed, 16 Mar 2022 13:28:57 +0000 |
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?
signature.asc
Description: PGP signature