Question

Any reason

cc -g -lm -DBLITZ_HOST_IS_LITTLE_ENDIAN

would produce an error with code using math.h? Is it possible there's a difference between GCC version 4.0.3 (documented working version) and version 4.6.3 (my current version)?

makefile and asm.c @ https://gist.github.com/3801291

This is on ubuntu 12.04

My terminal output is a comment in the gist.

Was it helpful?

Solution

Instead of

cc -g -lm -DBLITZ_HOST_IS_LITTLE_ENDIAN foo.c

Try:

cc -g -DBLITZ_HOST_IS_LITTLE_ENDIAN foo.c -lm

When the linker searches a library, it links in modules that contain definitions for previously-undefined symbols.

If the linker searches -lm before foo.o, then pow() is not yet undefined. Conversely, if foo.o comes first, it undefines pow(), which -lm can then resolve.


EDIT: To accomplish this advice in your makefile, make these changes:

CFLAGS=-g -DBLITZ_HOST_IS_LITTLE_ENDIAN
LDLIBS=-lm

...

asm: asm.c
        $(CC) $(CFLAGS) asm.c $(LDLIBS) -o asm

OTHER TIPS

I've recently suffer this problem using an automatic builder, namely drone.io.

The problem was that gcc in Ubuntu 12.04 was linking by default with -Wl,--as-needed. In my case, the project was using autotools, which means I was too lazy to write anything to modify the compilation order. Instead, modifying as-needed flag fixed the problem.

-gabriel_LDFLAGS = $(GLIB2_LIBS) $(DBUS_LIBS) -lssh
+gabriel_LDFLAGS = -Wl,--no-as-needed $(GLIB2_LIBS) $(DBUS_LIBS) -lssh

For full info, you can check the fixing commit in https://bitbucket.org/kikeenrique/gabriel/commits/f08eefdca3f7bb90f48f5a6fbfc8839422572508

You can take a look to the log with errors BEFORE applying the fix and also you can take a look to the log without errors AFTER applying the fix.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top