qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH 2/3] qobject: assume base of a qobject is at off


From: Paolo Bonzini
Subject: Re: [Qemu-devel] [PATCH 2/3] qobject: assume base of a qobject is at offset 0
Date: Wed, 21 Mar 2018 17:23:57 +0100
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0

On 21/03/2018 17:11, Marc-André Lureau wrote:
> Hi
> 
> On Wed, Mar 21, 2018 at 5:00 PM, Paolo Bonzini <address@hidden> wrote:
>> On 21/03/2018 16:55, Marc-André Lureau wrote:
>>> That would work with an anonymous union though:
>>>
>>> struct QObject {
>>>     union {
>>>         QType type;
>>>         QType base;
>>>     };
>>>     size_t refcnt;
>>> };
>>>
>>> If it's acceptable, I think I'll take this approach.
>>
>> You don't need QEMU_GENERIC at all then, don't you?
> 
> Ah ah, that's what I thought too, but the type of QObject * &x->base
> isn't QObject * :)
> 
> I don't think we can fool it there (without loosing some type safety)

Hmm, perhaps by making it "struct {} base"?

Or even:

struct QObjectCommon {
    QType type;
    size_t refcnt;
}

struct QObject {
    QObjectCommon base;
}

struct QString {
    QObjectCommon base;
    ...
}

Paolo




reply via email to

[Prev in Thread] Current Thread [Next in Thread]