From: Jan Kiszka <jan.kiszka@siemens.com>
To: Paolo Bonzini <pbonzini@redhat.com>
Cc: Peter Maydell <peter.maydell@linaro.org>,
Anthony Liguori <aliguori@us.ibm.com>,
Ed Maste <emaste@freebsd.org>,
qemu-devel@nongnu.org, Stefan Hajnoczi <stefanha@redhat.com>
Subject: Re: [Qemu-devel] [PATCH 2/2] qemu-thread: add TLS wrappers
Date: Thu, 04 Jul 2013 18:27:13 +0200 [thread overview]
Message-ID: <51D5A261.8050702@siemens.com> (raw)
In-Reply-To: <51D15699.6060708@redhat.com>
On 2013-07-01 12:14, Paolo Bonzini wrote:
> Il 01/07/2013 11:54, Peter Maydell ha scritto:
>> On 1 July 2013 10:35, Stefan Hajnoczi <stefanha@redhat.com> wrote:
>>> From: Paolo Bonzini <pbonzini@redhat.com>
>>>
>>> Fast TLS is not available on some platforms, but it is always nice to
>>> use it. This wrapper implementation falls back to pthread_get/setspecific
>>> on POSIX systems that lack __thread, but uses the dynamic linker's TLS
>>> support on Linux and Windows.
>>>
>>> The user shall call tls_alloc_foo() in every thread that needs to access
>>> the variable---exactly once and before any access. foo is the name of
>>> the variable as passed to DECLARE_TLS and DEFINE_TLS. Then,
>>> tls_get_foo() will return the address of the variable. It is guaranteed
>>> to remain the same across the lifetime of a thread, so you can cache it.
>>
>>> ##########################################
>>> +# check for TLS runtime
>>> +
>>> +# Some versions of mingw include the "magic" definitions that make
>>> +# TLS work, some don't. Check for it.
>>> +
>>> +if test "$mingw32" = yes; then
>>> + cat > $TMPC << EOF
>>> +int main(void) {}
>>
>> Execution falls off the end of function without returning a value
>> (I would expect the compiler to issue a warning about this.)
>>
>>> +#ifndef QEMU_TLS_H
>>> +#define QEMU_TLS_H
>>> +
>>> +#if defined __linux__
>>> +#define DECLARE_TLS(type, x) \
>>> +extern __thread typeof(type) x; \
>>> + \
>>> +static inline typeof(type) *tls_get_##x(void) \
>>> +{ \
>>> + return &x; \
>>> +} \
>>> + \
>>> +static inline typeof(type) *tls_alloc_##x(void) \
>>> +{ \
>>> + return &x; \
>>> +} \
>>> + \
>>> +extern int dummy_##__LINE__
>>
>> What's this for?
>
> It lets you use it as
>
> DECLARE_TLS(type, x);
>
> Many editors impose an indent without the trailing semicolon (they parse
> it as a K&R function definition).
This workaround causes troubles here with gcc-4.5.1:
In file included from /data/qemu/include/exec/memory.h:29:0,
from /data/qemu/include/exec/ioport.h:29,
from /data/qemu/include/hw/hw.h:11,
from /data/qemu/exec.c:30:
/data/qemu/include/qemu/rcu.h:88:339: warning: redundant redeclaration of ‘dummy___LINE__’
/data/qemu/include/exec/cpu-all.h:362:359: note: previous declaration of ‘dummy___LINE__’ was here
/data/qemu/exec.c:77:24: warning: function declaration isn’t a prototype
/data/qemu/exec.c:77:41: error: invalid storage class for function ‘tls_get_cpu_single_env’
/data/qemu/exec.c:77:41: error: conflicting types for ‘tls_get_cpu_single_env’
/data/qemu/include/exec/cpu-all.h:362:148: note: previous definition of ‘tls_get_cpu_single_env’ was here
Jan
--
Siemens AG, Corporate Technology, CT RTC ITP SES-DE
Corporate Competence Center Embedded Linux
next prev parent reply other threads:[~2013-07-04 16:27 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-07-01 9:35 [Qemu-devel] [PATCH 0/2] Fast Thread-Local Storage support Stefan Hajnoczi
2013-07-01 9:35 ` [Qemu-devel] [PATCH 1/2] exec: do not use qemu/tls.h Stefan Hajnoczi
2013-07-01 9:51 ` Peter Maydell
2013-07-01 10:15 ` Paolo Bonzini
2013-07-01 10:47 ` Andreas Färber
2013-07-01 9:35 ` [Qemu-devel] [PATCH 2/2] qemu-thread: add TLS wrappers Stefan Hajnoczi
2013-07-01 9:54 ` Peter Maydell
2013-07-01 10:14 ` Paolo Bonzini
2013-07-04 16:27 ` Jan Kiszka [this message]
2013-07-04 16:38 ` Paolo Bonzini
2013-07-01 12:34 ` Stefan Hajnoczi
2013-07-01 18:52 ` Ed Maste
2013-07-01 19:25 ` Peter Maydell
2013-07-01 20:00 ` Ed Maste
2013-07-01 20:30 ` Richard Henderson
2013-07-02 7:54 ` Paolo Bonzini
2013-07-02 7:50 ` Stefan Hajnoczi
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=51D5A261.8050702@siemens.com \
--to=jan.kiszka@siemens.com \
--cc=aliguori@us.ibm.com \
--cc=emaste@freebsd.org \
--cc=pbonzini@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.