software: dependencies the Werner way
authorSebastien Bourdeauducq <sebastien@milkymist.org>
Fri, 3 Feb 2012 11:25:55 +0000 (12:25 +0100)
committerSebastien Bourdeauducq <sebastien@milkymist.org>
Fri, 3 Feb 2012 11:25:55 +0000 (12:25 +0100)
software/include.mak
software/libbase/Makefile

index b0a774a14bf711d20d1f69f47e946034e8b2b091..f417bba00c93c744861aa0df928feff78ff60097 100644 (file)
@@ -7,14 +7,14 @@ AR_normal := $(CROSS_COMPILER)ar
 AS_normal := $(CROSS_COMPILER)as
 LD_normal := $(CROSS_COMPILER)ld
 OBJCOPY_normal := $(CROSS_COMPILER)objcopy
-RANLIB_normal  := $(CROSS_COMPILER)ranlib
+RANLIB_normal := $(CROSS_COMPILER)ranlib
 
 CC_quiet = @echo " CC " $@ && $(CROSS_COMPILER)gcc
 AR_quiet = @echo " AR " $@ && $(CROSS_COMPILER)ar
 AS_quiet = @echo " AS " $@ && $(CROSS_COMPILER)as
 LD_quiet = @echo " LD " $@ && $(CROSS_COMPILER)ld
 OBJCOPY_quiet = @echo " OBJCOPY " $@ && $(CROSS_COMPILER)objcopy
-RANLIB_quiet  = @echo " RANLIB  " $@ && $(CROSS_COMPILER)ranlib
+RANLIB_quiet = @echo " RANLIB  " $@ && $(CROSS_COMPILER)ranlib
 
 ifeq ($(V),1)
     CC = $(CC_normal)
@@ -22,14 +22,14 @@ ifeq ($(V),1)
     AS = $(AS_normal)
     LD = $(LD_normal)
     OBJCOPY = $(OBJCOPY_normal)
-    RANLIB  = $(RANLIB_normal)
+    RANLIB = $(RANLIB_normal)
 else
     CC = $(CC_quiet)
     AR = $(AR_quiet)
     AS = $(AS_quiet)
     LD = $(LD_quiet)
     OBJCOPY = $(OBJCOPY_quiet)
-    RANLIB  = $(RANLIB_quiet)
+    RANLIB = $(RANLIB_quiet)
 endif
 
 # Toolchain options
@@ -43,3 +43,15 @@ CFLAGS = -O9 -Wall -Wstrict-prototypes -Wold-style-definition -Wshadow \
         -msign-extend-enabled -fno-builtin -fsigned-char \
         -fsingle-precision-constant $(INCLUDES)
 LDFLAGS = -nostdlib -nodefaultlibs
+
+# compile and generate dependencies, based on
+# http://scottmcpeak.com/autodepend/autodepend.html
+
+%.o: %.c
+       $(CC) -c $(CFLAGS) $*.c -o $*.o
+       @$(CC_normal) -MM $(CFLAGS) $*.c > $*.d
+       @mv -f $*.d $*.d.tmp
+       @sed -e 's|.*:|$*.o:|' < $*.d.tmp > $*.d
+       @sed -e 's/.*://' -e 's/\\$$//' < $*.d.tmp | fmt -1 | \
+         sed -e 's/^ *//' -e 's/$$/:/' >> $*.d
+       @rm -f $*.d.tmp
index a9027a272f692911d3e472eeda4885abf176eb99..b01fc7f9f920b038f0a49426672db7ce3ba252f9 100644 (file)
@@ -3,6 +3,9 @@ include $(MMDIR)/software/include.mak
 
 OBJECTS=divsi3.o libc.o console.o system.o board.o uart.o softfloat.o softfloat-glue.o vsnprintf.o atof.o
 
+# pull in dependency info for *existing* .o files
+-include $(OBJECTS:.o=.d)
+
 all: libbase.a
 
 libbase.a: $(OBJECTS)
@@ -12,4 +15,4 @@ libbase.a: $(OBJECTS)
 .PHONY: clean
 
 clean:
-       rm -f *.o libbase.a .*~ *~ Makefile.bak
+       rm -f $(OBJECTS) $(OBJECTS:.o=.d) libbase.a .*~ *~ Makefile.bak