Message ID | 20201120094900.1489-8-paul@xen.org (mailing list archive) |
---|---|
State | Superseded |
Headers | show |
Series | viridian: add support for ExProcessorMasks | expand |
On 20.11.2020 10:48, Paul Durrant wrote: > From: Paul Durrant <pdurrant@amazon.com> > > Co-locate it with the definition of offsetof() (since this is also in stddef.h > in the Linux kernel source). This macro will be needed in a subsequent patch. > > Signed-off-by: Paul Durrant <pdurrant@amazon.com> Acked-by: Jan Beulich <jbeulich@suse.com> You don't fancy replacing in the tree what is now effectively open-coding this construct, I guess? I'll try to remember to do so once this has gone in... Jan
> -----Original Message----- > From: Jan Beulich <jbeulich@suse.com> > Sent: 20 November 2020 15:16 > To: Paul Durrant <paul@xen.org> > Cc: Paul Durrant <pdurrant@amazon.com>; Andrew Cooper <andrew.cooper3@citrix.com>; George Dunlap > <george.dunlap@citrix.com>; Ian Jackson <iwj@xenproject.org>; Julien Grall <julien@xen.org>; Stefano > Stabellini <sstabellini@kernel.org>; Wei Liu <wl@xen.org>; xen-devel@lists.xenproject.org > Subject: Re: [PATCH v2 07/12] xen/include: import sizeof_field() macro from Linux stddef.h > > On 20.11.2020 10:48, Paul Durrant wrote: > > From: Paul Durrant <pdurrant@amazon.com> > > > > Co-locate it with the definition of offsetof() (since this is also in stddef.h > > in the Linux kernel source). This macro will be needed in a subsequent patch. > > > > Signed-off-by: Paul Durrant <pdurrant@amazon.com> > > Acked-by: Jan Beulich <jbeulich@suse.com> > > You don't fancy replacing in the tree what is now effectively > open-coding this construct, I guess? I'll try to remember to > do so once this has gone in... > I'll see what I can find after this series is in, unless you get there first :-) Paul
diff --git a/xen/include/xen/compiler.h b/xen/include/xen/compiler.h index c0e0ee9f27be..676c6ea1b0a0 100644 --- a/xen/include/xen/compiler.h +++ b/xen/include/xen/compiler.h @@ -76,6 +76,14 @@ #define offsetof(a,b) __builtin_offsetof(a,b) +/** + * sizeof_field(TYPE, MEMBER) + * + * @TYPE: The structure containing the field of interest + * @MEMBER: The field to return the size of + */ +#define sizeof_field(TYPE, MEMBER) sizeof((((TYPE *)0)->MEMBER)) + #if !defined(__STDC_VERSION__) || __STDC_VERSION__ < 201112L #define alignof __alignof__ #endif