acpi module failing to load in 1.9.0 preview #4?
YONETANI Tomokazu
qhwt+dfly at les.ath.cx
Tue May 29 09:51:56 PDT 2007
On Tue, May 29, 2007 at 12:28:43PM +0200, Simon 'corecode' Schubert wrote:
> YONETANI Tomokazu wrote:
> >On Mon, May 28, 2007 at 11:56:27AM -0700, Matthew Dillon wrote:
> >>:Yup, adding back the static and removing the initialiser also fixed the
> >>:problem.
> >>:
> >>:So my fault for building with GCC 4, contrary to the instructions. :-)
> >>:
> >>:It's the only problem I've found so far, though (apart from a barrel
> >>:load of warnings!).
> >But a question remains: why the asm code can't see a static variable
> >with initializer only when it's compiled with GCC4.1?
>
> I just tried with the initializer and gcc41 and I can not reproduce this
> problem. Can we get some more data points?
I think I managed to reproduce this with a smaller code, if OP
has -O2 in his CFLAG (this is with gcc 4.0.1 on Mac OS X, so you need
to remove the extra underscores before function and variable names
to try it on DragonFly).
%%%%
$ cat a.c
#include <stdio.h>
static int foo = 1;
int get_foo(void);
__asm__("\n\
.text \n\
.p2align 2, 0x90 \n\
_get_foo: \n\
movl _foo,%eax \n\
movl $1,_foo \n\
ret \n\
");
int
main()
{
printf("foo: %d\n", get_foo());
return 0;
}
$ gcc -W -Wall a.c
a.c:3: warning: 'foo' defined but not used
$ gcc -O2 -W -Wall a.c
a.c:3: warning: 'foo' defined but not used
/usr/bin/ld: Undefined symbols:
_foo
collect2: ld returned 1 exit status
%%%%
Apparently gcc-4 has no idea(or no longer cares?) that __asm__() code
does modify foo and it happily optimized the variable away to a constant.
Cheers.
More information about the Bugs
mailing list