[head tinderbox] failure on arm/arm
Giorgos Keramidas
keramida at freebsd.org
Sun Nov 12 14:43:12 UTC 2006
On 2006-11-12 17:00, Ruslan Ermilov <ru at freebsd.org> wrote:
> > /src/lib/libelf/elf_rand.c: In function `elf_rand':
> > /src/lib/libelf/elf_rand.c:47: warning: cast increases required alignment of target type
> > *** Error code 1
> >
> > Stop in /src/lib/libelf.
> > *** Error code 1
>
> This looks like a GCC bug to me. The following code snippet,
> when compiled on FreeBSD/arm, causes a -Wcast-align warning
> which doesn't look right:
>
> %%%
> $ cat a.c
> struct foo {
> char x;
> };
>
> struct foo *
> bubu(char *s)
> {
>
> return (struct foo *)s;
> }
> $ cc -c -Wcast-align a.c
> a.c: In function `bubu':
> a.c:9: warning: cast increases required alignment of target type
> %%%
>
> (None of other supported architecutes see the issue here.)
You can't cast any random (char *) pointer to a pointer of a type which
is (potentially) larger than 1 byte. It's the same sort of warning you
will get if you try to:
char ch[] = "\x00\x00\x00\x00";
char *p = &(ch[0]);
unsigned long *lptr = (unsigned long *)p;
You cannot guarantee that `ch' is stored in an address that is properly
aligned for (unsigned long), and this is what GCC warns about here.
On 2006-11-12 15:27, Stefan Farfeleder <stefan at fafoe.narf.at> wrote:
> What is sizeof(struct foo)? If it's > 1 it makes sense.
Exactly :)
More information about the freebsd-arm
mailing list