public inbox for ecos-discuss@sourceware.org
 help / color / mirror / Atom feed
* Re: [ECOS] How to stop gcc padding structs???
@ 2001-01-28 13:34 Lewin A.R.W. Edwards
  0 siblings, 0 replies; 7+ messages in thread
From: Lewin A.R.W. Edwards @ 2001-01-28 13:34 UTC (permalink / raw)
  To: ecos-discuss

>I'm again fighting with gcc trying (and failing) to get it to
>stop putting padding bytes into structs.  Have any eCosians
>figured out how to prevent gcc from padding structs?

I have had the same type of problem trying to get it working on a 
structure-by-structure basis and I am running with the entire OS compiled 
with packed structures.

Warning!!!! am not sure if it is caused by this act, but I have run into 
another problem since doing this, and it caused much head-scratching. It 
seems that if I pass a parameter by reference, and then pass that reference 
down into another function, the lower function gets a pointer to garbage 
rather than a pointer to the real value. So it can't properly work with or 
update the parameter.

The solution to this is to create a local variable in the upper function, 
and pass THAT down to the lower function, and copy the value across 
afterwards. But it's very annoying.

=== Lewin A.R.W. Edwards (Embedded Engineer)
Work: http://www.digi-frame.com/
Personal: http://www.zws.com/ and http://www.larwe.com/

"Und setzet ihr nicht das Leben ein,
Nie wird euch das Leben gewonnen sein."

^ permalink raw reply	[flat|nested] 7+ messages in thread
* [ECOS] How to stop gcc padding structs???
@ 2001-01-28 10:37 Grant Edwards
  2001-01-29  0:27 ` Andrew Lunn
                   ` (2 more replies)
  0 siblings, 3 replies; 7+ messages in thread
From: Grant Edwards @ 2001-01-28 10:37 UTC (permalink / raw)
  To: ecos-discuss

I'm again fighting with gcc trying (and failing) to get it to
stop putting padding bytes into structs.  Have any eCosians
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!

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.

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

typedef struct
{
  high  a __attribute__((packed));
  high  b __attribute__((packed));
  high  c __attribute__((packed));
} tDemo __attribute__((packed));

tDemo foo;

void *addr[] =
{
  &foo,
  &foo.a,
  &foo.b,
  &foo.c
};

testit:     file format elf32-bigarm
Disassembly of section .data:
00008000 <addr>:
    8000:	00008010 	andeq	r8, r0, r0, lsl r0
    8004:	00008010 	andeq	r8, r0, r0, lsl r0
    8008:	00008014 	andeq	r8, r0, r4, lsl r0
    800c:	00008018 	andeq	r8, r0, r8, lsl r0

-- 
Grant Edwards
grante@visi.com

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2001-01-29 14:15 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2001-01-28 13:34 [ECOS] How to stop gcc padding structs??? Lewin A.R.W. Edwards
  -- strict thread matches above, loose matches on Subject: below --
2001-01-28 10:37 Grant Edwards
2001-01-29  0:27 ` Andrew Lunn
2001-01-29  7:24   ` Grant Edwards
2001-01-29  9:49 ` Jonathan Larmour
2001-01-29  9:53   ` Grant Edwards
2001-01-29 14:15 ` Jesper Skov

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).