What is structure padding?where it is used in real time applications?

Showing Answers 1 - 2 of 2 Answers

rr

  • Feb 20th, 2007
 

Those are 3 different things.

Structure Padding

Most processors require specific memory alignment on variables certain types. Normally the minimum alignment is the size of the basic type in question, fo instance this is common

char variables can be byte aligned and appear at any byte boundary

short (2 byte) variables must be 2 byte aligned, they can appear at any even byte boundary. This means that 0x10004567 is not a valid location for a short variable but 0x10004566 is.

long (4 byte) variables must be 4 byte aligned, they can only appear at byte boundarys that are a multiple of 4 bytes. This means that 0x10004566 is not a valid location for a long variable but 0x10004568 is.

Structure padding occurs because the members of the structure must appear at the correect byte boundary, to achieve this the compiler puts in padding bytes (or bits if bit fields are in use) so that the structure members appear in the correct location. Additionally the size of the structure must be such that in an array of the structures all the structures are correctly aligned in memory so there may be padding bytes at the end of the structure too

struct example {
char c1;
short s1;
char c2;
long l1;
char c3;
}

In this structure, assuming the alignment scheme I have previously stated then

c1 can appear at any byte boundary, however s1 must appear at a 2 byte boundary so there is a padding byte between c1 and s1.

c2 can then appear in the available memory location, however l1 must be at a 4 byte boundary so there are 3 padding bytes between c2 and l1

c3 then appear in the available memory location, however because the structure contains a long member the structure must be 4 byte aligned and must be a multiple of 4 bytes in size. Therefore there are 3 padding bytes at the end of the structure. it would appear in memory in this order

c1
padding byte
s1 byte 1
s1 byte 2
c2
padding byte
padding byte
padding byte
l1 byte 1
l1 byte 2
l1 byte 3
l1 byte 4
c3
padding byte
padding byte
padding byte

The structure would be 16 bytes long.

re-written like this

struct example {
long l1;
short s1;
char c1;
char c2;
char c3;
}

Then l1 appears at the correct byte alignment, s1 will be correctly aligned so no need for padding between l1 and s1. c1, c2, c3 can appear at any location. The structure must be a multiple of 4 bytes in size since it contains a long so 3 padding bytes appear after c3

It appears in memory in the order

l1 byte 1
l1 byte 2
l1 byte 3
l1 byte 4
s1 byte 1
s1 byte 2
c1
c2
c3
padding byte
padding byte
padding byte

and is only 12 bytes long.


I should point out that structure packing is platform and compiler (and in some cases compiler switch) dependent.

  Was this answer useful?  Yes

fcawad_03

  • Feb 21st, 2007
 

I understand that some compilers pad some bytes to the aggregate data types in order to access the members of the aggregate data types(i.e. structure) fast. This depends on the architectures. Some architectures cannot access the data which will be stored on the odd addresses or they may find difficult to access it. This is the reason for padding extra bytes. Now consider the following structure: struct { int i; // 4 bytes char c; // 1 byte char b; // 1 byte }a;[/color]Okay. Layout can be compiler specific.If want to see the exact layout of a structure with different packings,we can play with this code:#include // Works for DJGPP 2.03 and OW 1.3#ifdef __DJGPP__#define HANDLE_PRAGMA_PACK_PUSH_POP 1#endif// default alignmentstruct {unsigned int i;unsigned char c;unsigned long a;unsigned short e;unsigned char b;} s0;#pragma pack(push,1)struct {unsigned int i;unsigned char c;unsigned long a;unsigned short e;unsigned char b;} s1;#pragma pack(pop)#pragma pack(push,2)struct {unsigned int i;unsigned char c;unsigned long a;unsigned short e;unsigned char b;} s2;#pragma pack(pop)#pragma pack(push,4)struct {unsigned int i;unsigned char c;unsigned long a;unsigned short e;unsigned char b;} s3;#pragma pack(pop)void print_s(unsigned char *s, int size){int i;printf("%d ",size);for(i=0;i

  Was this answer useful?  Yes

Give your answer:

If you think the above answer is not correct, Please select a reason and add your answer below.

 

Related Answered Questions

 

Related Open Questions