diff options
author | camthesaxman <camthesaxman@users.noreply.github.com> | 2020-01-29 18:17:43 -0600 |
---|---|---|
committer | camthesaxman <camthesaxman@users.noreply.github.com> | 2020-01-29 18:17:43 -0600 |
commit | cdc6e2c50f96119bdc4c1205ff5901ca82ec8357 (patch) | |
tree | 3e9217eabcf444e166008411f445315606dded59 /gcc_arm/testsuite/consistency.vlad/layout/s-pointer-s-pointer.c | |
parent | 27176890c4a688ea7de44d3f55af32827016a9fd (diff) |
add old compiler with ARM support
Diffstat (limited to 'gcc_arm/testsuite/consistency.vlad/layout/s-pointer-s-pointer.c')
-rwxr-xr-x | gcc_arm/testsuite/consistency.vlad/layout/s-pointer-s-pointer.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/gcc_arm/testsuite/consistency.vlad/layout/s-pointer-s-pointer.c b/gcc_arm/testsuite/consistency.vlad/layout/s-pointer-s-pointer.c new file mode 100755 index 0000000..90da933 --- /dev/null +++ b/gcc_arm/testsuite/consistency.vlad/layout/s-pointer-s-pointer.c @@ -0,0 +1,17 @@ +#include <stdio.h> + +static struct sss{ + char * f; + struct {char * m;} snd; +} sss; + +#define _offsetof(st,f) ((char *)&((st *) 16)->f - (char *) 16) + +int main (void) { + printf ("+++Struct pointer inside struct starting with pointer:\n"); + printf ("size=%d,align=%d\n", sizeof (sss), __alignof__ (sss)); + printf ("offset-pointer=%d,offset-sss-pointer=%d,\nalign-pointer=%d,align-sss-pointer=%d\n", + _offsetof (struct sss, f), _offsetof (struct sss, snd), + __alignof__ (sss.f), __alignof__ (sss.snd)); + return 0; +} |