Data Representation and Alignment Topics Simple static allocation and alignment of basic types and data structures Policies Mechanisms
– 2 – Data Representations Sizes of C Objects (in Bytes) C Data Type Intel IA32 int 4 (1 word) long int4 char1 short2 float4 double 8 (2 words) char *4 »Or any other pointer A word is 4 bytes
– 3 – Alignment Aligned Data Primitive data type requires K bytes Address must be multiple of K Required on some machines; advised on Intel Motivation for Aligning Data Memory accessed by aligned double words (or quad-words) Inefficient to load or store datum that spans quad word boundariesCompiler Inserts gaps in structure to ensure correct alignment of fields
– 4 – struct rec { int i; int a[3]; int *p; }; Structures Concept Contiguously-allocated region of memory Refer to members within structure by names Members may be of different types Memory Layout iap
– 5 – Specific Cases of Alignment Size of Primitive Data Type: 1 byte (e.g., char) no restrictions on address 2 bytes (e.g., short ) lowest 1 bit of address is 0 (2) 4 bytes (e.g., int, float, char *, etc.) lowest 2 bits of address - 00 (2) 8 bytes (e.g., double ) lowest 3 bits of address 000 (2)
– 6 – Satisfying Alignment with Structures Offsets Within Structure Must satisfy element’s alignment requirement Overall Structure Placement Each structure has alignment requirement K Largest alignment of any element Initial address & structure length must be multiples of K
– 7 – Example (under Linux) K = 4, due to int element K = 4, due to int element struct S1 { char c; int i[2]; } *p; ci[0]i[1] p+0p+4p+8 Multiple of 4 p+12
– 8 – Overall Alignment Requirement struct S2{ float x[2]; int i[2]; char c; } *p; ci[0]i[1] p+0p+12p+8p+16p+20 x[0]x[1] p+4 p must be multiple of 4
– 9 – Arrays of Structures Principle Allocated by repeating allocation for array type a[0] a+0 a[1]a[2] a+12a+24a+36 a+12a+20a+16a+24 struct S3 { short i; float v; short j; } a[10]; a[1].ia[1].ja[1].v
– 10 – Satisfying Alignment within Structure Achieving Alignment Starting address of structure array must be multiple of worst-case alignment for any element a must be multiple of 4 Offset of element within structure must be multiple of element’s alignment requirement v ’s offset of 4 is a multiple of 4 Overall size of structure must be multiple of worst-case alignment for any element Structure padded with unused space to be 12 bytes struct S3 { short i; float v; short j; } a[10]; a[0] a+0 a[i] a+12i a+12ia+12i+4 a[1].ia[1].ja[1].v Multiple of 4
Array Allocation Basic Principle T A[ L ]; Array of data type T and length L Contiguously allocated region of L * sizeof( T ) bytes char string[12]; xx + 12 int val[5]; x x + 4x + 8x + 12x + 16x + 20 double a[3]; x + 24 x x + 8x + 16 char *p[3]; x x + 4x + 8x + 12
Multidimensional (Nested) Arrays Declaration T A[ R ][ C ]; 2D array of data type T R rows, C columns T element requires K bytes Array Size R * C * K bytesArrangement Row-Major Ordering (C code) A[0][0]A[0][C-1] A[R-1][0] A[R-1][C-1] int A[R][C]; A [0] A [0] [C-1] A [1] [0] A [1] [C-1] A [R-1] [0] A [R-1] [C-1] 4*R*C Bytes
– 13 – Summary Arrays in C Contiguous allocation of memory Pointer to first element No bounds checkingStructures Allocate bytes in order declared Pad in middle and at end to satisfy alignment
– 14 – Misc: Boolean (“Bitwise”) Operators Operate on numbers as Bit Vectors Operations applied bitwise & | ^ ~