This is the mail archive of the gcc@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]

Re: How to stop gcc padding structs???


> 
> I'm again fighting with gcc trying (and failing) to get it to
> stop putting padding bytes into structs.  Has anybody figured
> out how to prevent gcc from padding structs?
> 
> I ran into this problem before and gave up, finally having to
> use hand-calculated constants instead of "sizeof (struct foo)"
> in numerous places.  For example, it's impossible to define an
> Ethernet header structure that ends up having a size of 14
> bytes!

Relying on sizeof to do this is *very* non-portable.

> 
> In the following example, gcc insists that each of the "high"
> structs occupies four bytes despite my putting a "packed"
> attribute evryplace that doesn't generate a syntax warning.
> 
> $ arm-elf-gcc -v   
> Reading specs from /usr/local/lib/gcc-lib/arm-elf/2.95.2/specs
> gcc version 2.95.2 19991024 (release)
> 
> 
> typedef struct
> {
>   volatile unsigned char data __attribute__((packed));
>   volatile unsigned char _xxx __attribute__((packed));
> } high __attribute((packed));

Try:

typedef struct
{
  volatile unsigned char data;
  volatile unsigned char _xxx;
} __attribute((packed)) high;

etc.

The following also works:

struct foo
{
  volatile unsigned char data;
  volatile unsigned char _xxx;
} __attribute((packed));

typedef struct foo high;

IMO it's a long-standing bug in gcc's parser grammar that your example 
doesn't pack things as expected but doesn't generate a diagnostic either.

R.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]