RFC: Update Intel386, x86-64 and IA MCU psABIs for passing/returning empty struct
Florian Weimer via cfe-commits
cfe-commits at lists.llvm.org
Sun Feb 7 12:08:17 PST 2016
* H. J. Lu:
>> Any syntactical array argument (at the C level) is should be passed as
>> a pointer. The language appears to change that.
>
> I didn't use aggregate so that array is excluded here.
>
>> For 2., static members and non-data members do not count.
>
> They do count here. That is why I used "POD for the purpose of
> layout.
Let's see what happens today.
struct s0 {
s0();
};
struct s1 {
static int a;
};
struct s2 {
void member();
};
struct s3 {
int a[0];
};
struct s4 {
s0 a[0];
};
struct s5 {
s1 a[1];
};
I tested GCC 5.3.1 and Clang 3.5.0.
GCC Clang
s0 non-empty non-empty
s1 non-empty empty
s2 non-empty empty
s3 empty empty
s4 empty empty
s5 non-empty empty
I believe s3, s4, s5 are non-empty according to your rules. Why put
both compilers in the wrong? That doesn't make sense to me.
Jason already indicated he intends GCC to move towards more empty
arguments, not fewer.
>> How do existing C++ compilers implement empty array members (an
>> extension)? Does the type of such members affect whether a class is a
>> standard-layout class?
> Are they "POD for the purpose of layout"? If yes, they are covered here.
The C++ standard does not define this.
More information about the cfe-commits
mailing list